diff options
author | Zeeshan Ali <zeenix@gmail.com> | 2003-01-30 20:24:26 +0000 |
---|---|---|
committer | Zeeshan Ali <zeenix@gmail.com> | 2003-01-30 20:24:26 +0000 |
commit | 1c6ceb5c0bc0e572a47e0889818d06ea54365355 (patch) | |
tree | b6614304f5c72b05a5654e75ae76a0c476539400 | |
parent | 0d1b9d28becf937c3514ad1d79f8736d0741991e (diff) | |
download | gst-plugins-bad-1c6ceb5c0bc0e572a47e0889818d06ea54365355.tar.gz gst-plugins-bad-1c6ceb5c0bc0e572a47e0889818d06ea54365355.tar.bz2 gst-plugins-bad-1c6ceb5c0bc0e572a47e0889818d06ea54365355.zip |
The first attempt to support MAS. Dont expect it to work :)
Original commit message from CVS:
The first attempt to support MAS. Dont expect it to work :)
-rw-r--r-- | configure.ac | 10 | ||||
-rw-r--r-- | ext/Makefile.am | 10 | ||||
-rw-r--r-- | ext/mas/Makefile.am | 10 | ||||
-rw-r--r-- | ext/mas/Makefile.in | 498 | ||||
-rw-r--r-- | ext/mas/massink.c | 546 | ||||
-rw-r--r-- | ext/mas/massink.h | 94 | ||||
-rw-r--r-- | gst/videocrop/gstvideocrop.c | 15 |
7 files changed, 1178 insertions, 5 deletions
diff --git a/configure.ac b/configure.ac index 675d17bf..4ae65d84 100644 --- a/configure.ac +++ b/configure.ac @@ -497,6 +497,15 @@ GST_CHECK_FEATURE(DVDNAV, [dvdnav library], dvdnavsrc, [ AS_SCRUB_INCLUDE(DVDNAV_CFLAGS) ]) +dnl *** MAS *** +translit(dnm, m, l) AM_CONDITIONAL(USE_MAS, true) +GST_CHECK_FEATURE(MAS, [mas library], massink, [ + translit(dnm, m, l) AC_SUBST(MAS_LIBS) + translit(dnm, m, l) AC_SUBST(MAS_CFLAGS) + GST_CHECK_CONFIGPROG(MAS, mas-config) + AS_SCRUB_INCLUDE(MAS_CFLAGS) +]) + dnl **** ESound **** translit(dnm, m, l) AM_CONDITIONAL(USE_ESD, true) GST_CHECK_FEATURE(ESD, [esound plug-ins], esdsink esdmon, [ @@ -1097,6 +1106,7 @@ ext/lcs/Makefile ext/libfame/Makefile ext/libpng/Makefile ext/mad/Makefile +ext/mas/Makefile ext/mikmod/Makefile ext/mjpegtools/Makefile ext/mpeg2dec/Makefile diff --git a/ext/Makefile.am b/ext/Makefile.am index d31f7fe6..0d107fc5 100644 --- a/ext/Makefile.am +++ b/ext/Makefile.am @@ -64,6 +64,12 @@ else ESD_DIR= endif +if USE_MAS +MAS_DIR=mas +else +MAS_DIR= +endif + ## if USE_FESTIVAL ## FESTIVAL_DIR=festival ## else @@ -253,7 +259,7 @@ endif SUBDIRS=$(A52DEC_DIR) $(AALIB_DIR) $(ALSA_DIR) \ $(ARTS_DIR) $(ARTSC_DIR) $(AUDIOFILE_DIR) \ $(AVIFILE_DIR) $(CDPARANOIA_DIR) \ - $(DVDREAD_DIR) $(DVDNAV_DIR) $(ESD_DIR) \ + $(DVDREAD_DIR) $(DVDNAV_DIR) $(ESD_DIR) $(MAS_DIR) \ $(FFMPEG_DIR) $(FLAC_DIR) $(GNOMEVFS_DIR) $(GSM_DIR) \ $(HERMES_DIR) $(HTTP_DIR) $(JACK_DIR) $(JPEG_DIR) \ $(LADSPA_DIR) $(LAME_DIR) $(LCS_DIR) \ @@ -268,7 +274,7 @@ DIST_SUBDIRS=\ a52dec aalib alsa \ arts artsd avifile \ audiofile cdparanoia dv \ - dvdread dvdnav esd ffmpeg \ + dvdread dvdnav esd mas ffmpeg \ flac gnomevfs gsm \ hermes http jack jpeg \ ladspa lame lcs libfame libpng \ diff --git a/ext/mas/Makefile.am b/ext/mas/Makefile.am new file mode 100644 index 00000000..9e6781f4 --- /dev/null +++ b/ext/mas/Makefile.am @@ -0,0 +1,10 @@ +plugindir = $(libdir)/gstreamer-@GST_MAJORMINOR@ + +plugin_LTLIBRARIES = libgstmassink.la + +libgstmassink_la_SOURCES = massink.c +libgstmassink_la_CFLAGS = $(GST_CFLAGS) $(MAS_CFLAGS) +libgstmassink_la_LDFLAGS = $(GST_PLUGIN_LDFLAGS) $(MAS_LIBS) + +noinst_HEADERS = massink.h +EXTRA_DIST = README diff --git a/ext/mas/Makefile.in b/ext/mas/Makefile.in new file mode 100644 index 00000000..7a9b0824 --- /dev/null +++ b/ext/mas/Makefile.in @@ -0,0 +1,498 @@ +# Makefile.in generated by automake 1.6.3 from Makefile.am. +# @configure_input@ + +# Copyright 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002 +# Free Software Foundation, Inc. +# This Makefile.in is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY, to the extent permitted by law; without +# even the implied warranty of MERCHANTABILITY or FITNESS FOR A +# PARTICULAR PURPOSE. + +@SET_MAKE@ +SHELL = @SHELL@ + +srcdir = @srcdir@ +top_srcdir = @top_srcdir@ +VPATH = @srcdir@ +prefix = @prefix@ +exec_prefix = @exec_prefix@ + +bindir = @bindir@ +sbindir = @sbindir@ +libexecdir = @libexecdir@ +datadir = @datadir@ +sysconfdir = @sysconfdir@ +sharedstatedir = @sharedstatedir@ +localstatedir = @localstatedir@ +libdir = @libdir@ +infodir = @infodir@ +mandir = @mandir@ +includedir = @includedir@ +oldincludedir = /usr/include +pkgdatadir = $(datadir)/@PACKAGE@ +pkglibdir = $(libdir)/@PACKAGE@ +pkgincludedir = $(includedir)/@PACKAGE@ +top_builddir = ../.. + +ACLOCAL = @ACLOCAL@ +AUTOCONF = @AUTOCONF@ +AUTOMAKE = @AUTOMAKE@ +AUTOHEADER = @AUTOHEADER@ + +am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd +INSTALL = @INSTALL@ +INSTALL_PROGRAM = @INSTALL_PROGRAM@ +INSTALL_DATA = @INSTALL_DATA@ +install_sh_DATA = $(install_sh) -c -m 644 +install_sh_PROGRAM = $(install_sh) -c +install_sh_SCRIPT = $(install_sh) -c +INSTALL_SCRIPT = @INSTALL_SCRIPT@ +INSTALL_HEADER = $(INSTALL_DATA) +transform = @program_transform_name@ +NORMAL_INSTALL = : +PRE_INSTALL = : +POST_INSTALL = : +NORMAL_UNINSTALL = : +PRE_UNINSTALL = : +POST_UNINSTALL = : +host_alias = @host_alias@ +host_triplet = @host@ + +EXEEXT = @EXEEXT@ +OBJEXT = @OBJEXT@ +PATH_SEPARATOR = @PATH_SEPARATOR@ +A52DEC_CFLAGS = @A52DEC_CFLAGS@ +A52DEC_LIBS = @A52DEC_LIBS@ +AALIB_CFLAGS = @AALIB_CFLAGS@ +AALIB_CONFIG = @AALIB_CONFIG@ +AALIB_LIBS = @AALIB_LIBS@ +ACLOCAL_AMFLAGS = @ACLOCAL_AMFLAGS@ +ALSA_CFLAGS = @ALSA_CFLAGS@ +ALSA_LIBS = @ALSA_LIBS@ +AMTAR = @AMTAR@ +ARTSC_CFLAGS = @ARTSC_CFLAGS@ +ARTSC_CONFIG = @ARTSC_CONFIG@ +ARTSC_LIBS = @ARTSC_LIBS@ +ARTS_CONFIG = @ARTS_CONFIG@ +ARTS_CXXFLAGS = @ARTS_CXXFLAGS@ +ARTS_LIBS = @ARTS_LIBS@ +AS = @AS@ +AUDIOFILE_CFLAGS = @AUDIOFILE_CFLAGS@ +AUDIOFILE_LIBS = @AUDIOFILE_LIBS@ +AVIFILE_CONFIG = @AVIFILE_CONFIG@ +AVIFILE_CXXFLAGS = @AVIFILE_CXXFLAGS@ +AVIFILE_LDFLAGS = @AVIFILE_LDFLAGS@ +AWK = @AWK@ +CC = @CC@ +CCAS = @CCAS@ +CCASFLAGS = @CCASFLAGS@ +CDPARANOIA_LIBS = @CDPARANOIA_LIBS@ +CPPFLAGS = @CPPFLAGS@ +CXX = @CXX@ +CXXCPP = @CXXCPP@ +CXXFLAGS = @CXXFLAGS@ +DEPDIR = @DEPDIR@ +DLLTOOL = @DLLTOOL@ +DVDNAV_CFLAGS = @DVDNAV_CFLAGS@ +DVDNAV_LIBS = @DVDNAV_LIBS@ +DVDREAD_LIBS = @DVDREAD_LIBS@ +ECHO = @ECHO@ +ESD_CFLAGS = @ESD_CFLAGS@ +ESD_CONFIG = @ESD_CONFIG@ +ESD_LIBS = @ESD_LIBS@ +FLAC_LIBS = @FLAC_LIBS@ +FT2_CFLAGS = @FT2_CFLAGS@ +FT2_CONFIG = @FT2_CONFIG@ +FT2_LIBS = @FT2_LIBS@ +GCONFTOOL = @GCONFTOOL@ +GCONF_CFLAGS = @GCONF_CFLAGS@ +GCONF_LIBS = @GCONF_LIBS@ +GCONF_SCHEMA_CONFIG_SOURCE = @GCONF_SCHEMA_CONFIG_SOURCE@ +GCONF_SCHEMA_FILE_DIR = @GCONF_SCHEMA_FILE_DIR@ +GLIB2_REQ = @GLIB2_REQ@ +GLIB_CFLAGS = @GLIB_CFLAGS@ +GLIB_LIBS = @GLIB_LIBS@ +GNOME_VFS_CFLAGS = @GNOME_VFS_CFLAGS@ +GNOME_VFS_LIBS = @GNOME_VFS_LIBS@ +GSM_LIBS = @GSM_LIBS@ +GST_CFLAGS = @GST_CFLAGS@ +GST_CONTROL_LIBS = @GST_CONTROL_LIBS@ +GST_DISABLE_ = @GST_DISABLE_@ +GST_HTTPSRC_GET_TYPE = @GST_HTTPSRC_GET_TYPE@ +GST_LIBS = @GST_LIBS@ +GST_MAJORMINOR = @GST_MAJORMINOR@ +GST_PLUGINS_ALL = @GST_PLUGINS_ALL@ +GST_PLUGINS_SELECTED = @GST_PLUGINS_SELECTED@ +GST_PLUGIN_LDFLAGS = @GST_PLUGIN_LDFLAGS@ +GST_TOOLS_DIR = @GST_TOOLS_DIR@ +GTK_CFLAGS = @GTK_CFLAGS@ +GTK_LIBS = @GTK_LIBS@ +HAVE_ = @HAVE_@ +HAVE_CXX = @HAVE_CXX@ +HAVE_GCONFTOOL = @HAVE_GCONFTOOL@ +HERMES_LIBS = @HERMES_LIBS@ +HTTP_LIBS = @HTTP_LIBS@ +INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ +JACK_CFLAGS = @JACK_CFLAGS@ +JACK_LIBS = @JACK_LIBS@ +JPEG_LIBS = @JPEG_LIBS@ +LAME_LIBS = @LAME_LIBS@ +LCS_CFLAGS = @LCS_CFLAGS@ +LCS_LIBS = @LCS_LIBS@ +LDFLAGS = @LDFLAGS@ +LIBDV_CFLAGS = @LIBDV_CFLAGS@ +LIBDV_LIBS = @LIBDV_LIBS@ +LIBFAME_CFLAGS = @LIBFAME_CFLAGS@ +LIBFAME_CONFIG = @LIBFAME_CONFIG@ +LIBFAME_LIBS = @LIBFAME_LIBS@ +LIBMIKMOD_CFLAGS = @LIBMIKMOD_CFLAGS@ +LIBMIKMOD_CONFIG = @LIBMIKMOD_CONFIG@ +LIBMIKMOD_LDADD = @LIBMIKMOD_LDADD@ +LIBMIKMOD_LIBS = @LIBMIKMOD_LIBS@ +LIBPNG_CFLAGS = @LIBPNG_CFLAGS@ +LIBPNG_LIBS = @LIBPNG_LIBS@ +LIBTOOL = @LIBTOOL@ +LN_S = @LN_S@ +MAD_LIBS = @MAD_LIBS@ +MAINT = @MAINT@ +MAS_CFLAGS = @MAS_CFLAGS@ +MAS_LIBS = @MAS_LIBS@ +MCOPIDL = @MCOPIDL@ +MIKMOD_CFLAGS = @MIKMOD_CFLAGS@ +MIKMOD_LIBS = @MIKMOD_LIBS@ +MJPEGTOOLS_CFLAGS = @MJPEGTOOLS_CFLAGS@ +MJPEGTOOLS_LIBS = @MJPEGTOOLS_LIBS@ +MPEG2DEC_CFLAGS = @MPEG2DEC_CFLAGS@ +MPEG2DEC_LIBS = @MPEG2DEC_LIBS@ +NASM_PATH = @NASM_PATH@ +OBJDUMP = @OBJDUMP@ +OPENQUICKTIME_LIBS = @OPENQUICKTIME_LIBS@ +PACKAGE = @PACKAGE@ +PKG_CONFIG = @PKG_CONFIG@ +RANLIB = @RANLIB@ +RAW1394_LIBS = @RAW1394_LIBS@ +RTP_LIBS = @RTP_LIBS@ +SDL_CFLAGS = @SDL_CFLAGS@ +SDL_CONFIG = @SDL_CONFIG@ +SDL_LIBS = @SDL_LIBS@ +SHOUT2_CFLAGS = @SHOUT2_CFLAGS@ +SHOUT2_LIBS = @SHOUT2_LIBS@ +SHOUT_LIBS = @SHOUT_LIBS@ +SIDPLAY_CFLAGS = @SIDPLAY_CFLAGS@ +SIDPLAY_LIBS = @SIDPLAY_LIBS@ +STRIP = @STRIP@ +SWFDEC_CFLAGS = @SWFDEC_CFLAGS@ +SWFDEC_LIBS = @SWFDEC_LIBS@ +VERSION = @VERSION@ +VORBISENC_LIBS = @VORBISENC_LIBS@ +VORBISFILE_LIBS = @VORBISFILE_LIBS@ +VORBIS_CFLAGS = @VORBIS_CFLAGS@ +VORBIS_LIBS = @VORBIS_LIBS@ +XMMS_CFLAGS = @XMMS_CFLAGS@ +XMMS_CONFIG = @XMMS_CONFIG@ +XMMS_DATA_DIR = @XMMS_DATA_DIR@ +XMMS_EFFECT_PLUGIN_DIR = @XMMS_EFFECT_PLUGIN_DIR@ +XMMS_GENERAL_PLUGIN_DIR = @XMMS_GENERAL_PLUGIN_DIR@ +XMMS_INPUT_PLUGIN_DIR = @XMMS_INPUT_PLUGIN_DIR@ +XMMS_LIBS = @XMMS_LIBS@ +XMMS_OUTPUT_PLUGIN_DIR = @XMMS_OUTPUT_PLUGIN_DIR@ +XMMS_PLUGIN_DIR = @XMMS_PLUGIN_DIR@ +XMMS_VERSION = @XMMS_VERSION@ +XMMS_VISUALIZATION_PLUGIN_DIR = @XMMS_VISUALIZATION_PLUGIN_DIR@ +XVIDEO_LIBS = @XVIDEO_LIBS@ +X_CFLAGS = @X_CFLAGS@ +X_EXTRA_LIBS = @X_EXTRA_LIBS@ +X_LIBS = @X_LIBS@ +X_PRE_LIBS = @X_PRE_LIBS@ +am__include = @am__include@ +am__quote = @am__quote@ +install_sh = @install_sh@ +plugindir = $(libdir)/gstreamer-@GST_MAJORMINOR@ + +plugin_LTLIBRARIES = libgstmassink.la + +libgstmassink_la_SOURCES = massink.c +libgstmassink_la_CFLAGS = $(GST_CFLAGS) $(MAS_CFLAGS) +libgstmassink_la_LDFLAGS = $(GST_PLUGIN_LDFLAGS) $(MAS_LIBS) + +noinst_HEADERS = massink.h +EXTRA_DIST = README +subdir = ext/mas +mkinstalldirs = $(SHELL) $(top_srcdir)/mkinstalldirs +CONFIG_HEADER = $(top_builddir)/config.h +CONFIG_CLEAN_FILES = +LTLIBRARIES = $(plugin_LTLIBRARIES) + +libgstmassink_la_LIBADD = +am_libgstmassink_la_OBJECTS = libgstmassink_la-massink.lo +libgstmassink_la_OBJECTS = $(am_libgstmassink_la_OBJECTS) + +DEFS = @DEFS@ +DEFAULT_INCLUDES = -I. -I$(srcdir) -I$(top_builddir) +LIBS = @LIBS@ +depcomp = $(SHELL) $(top_srcdir)/depcomp +am__depfiles_maybe = depfiles +@AMDEP_TRUE@DEP_FILES = ./$(DEPDIR)/libgstmassink_la-massink.Plo +COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ + $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) +LTCOMPILE = $(LIBTOOL) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) \ + $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) +CCLD = $(CC) +LINK = $(LIBTOOL) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ + $(AM_LDFLAGS) $(LDFLAGS) -o $@ +CFLAGS = @CFLAGS@ +DIST_SOURCES = $(libgstmassink_la_SOURCES) +HEADERS = $(noinst_HEADERS) + +DIST_COMMON = $(noinst_HEADERS) Makefile.am Makefile.in +SOURCES = $(libgstmassink_la_SOURCES) + +all: all-am + +.SUFFIXES: +.SUFFIXES: .c .lo .o .obj +$(srcdir)/Makefile.in: @MAINTAINER_MODE_TRUE@ Makefile.am $(top_srcdir)/configure.ac $(ACLOCAL_M4) + cd $(top_srcdir) && \ + $(AUTOMAKE) --gnu ext/mas/Makefile +Makefile: @MAINTAINER_MODE_TRUE@ $(srcdir)/Makefile.in $(top_builddir)/config.status + cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe) +pluginLTLIBRARIES_INSTALL = $(INSTALL) +install-pluginLTLIBRARIES: $(plugin_LTLIBRARIES) + @$(NORMAL_INSTALL) + $(mkinstalldirs) $(DESTDIR)$(plugindir) + @list='$(plugin_LTLIBRARIES)'; for p in $$list; do \ + if test -f $$p; then \ + f="`echo $$p | sed -e 's|^.*/||'`"; \ + echo " $(LIBTOOL) --mode=install $(pluginLTLIBRARIES_INSTALL) $(INSTALL_STRIP_FLAG) $$p $(DESTDIR)$(plugindir)/$$f"; \ + $(LIBTOOL) --mode=install $(pluginLTLIBRARIES_INSTALL) $(INSTALL_STRIP_FLAG) $$p $(DESTDIR)$(plugindir)/$$f; \ + else :; fi; \ + done + +uninstall-pluginLTLIBRARIES: + @$(NORMAL_UNINSTALL) + @list='$(plugin_LTLIBRARIES)'; for p in $$list; do \ + p="`echo $$p | sed -e 's|^.*/||'`"; \ + echo " $(LIBTOOL) --mode=uninstall rm -f $(DESTDIR)$(plugindir)/$$p"; \ + $(LIBTOOL) --mode=uninstall rm -f $(DESTDIR)$(plugindir)/$$p; \ + done + +clean-pluginLTLIBRARIES: + -test -z "$(plugin_LTLIBRARIES)" || rm -f $(plugin_LTLIBRARIES) + @list='$(plugin_LTLIBRARIES)'; for p in $$list; do \ + dir="`echo $$p | sed -e 's|/[^/]*$$||'`"; \ + test -z "$dir" && dir=.; \ + echo "rm -f \"$${dir}/so_locations\""; \ + rm -f "$${dir}/so_locations"; \ + done +libgstmassink_la-massink.lo: massink.c +libgstmassink.la: $(libgstmassink_la_OBJECTS) $(libgstmassink_la_DEPENDENCIES) + $(LINK) -rpath $(plugindir) $(libgstmassink_la_LDFLAGS) $(libgstmassink_la_OBJECTS) $(libgstmassink_la_LIBADD) $(LIBS) + +mostlyclean-compile: + -rm -f *.$(OBJEXT) core *.core + +distclean-compile: + -rm -f *.tab.c + +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libgstmassink_la-massink.Plo@am__quote@ + +distclean-depend: + -rm -rf ./$(DEPDIR) + +.c.o: +@AMDEP_TRUE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ +@AMDEP_TRUE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ +@AMDEP_TRUE@ $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ + $(COMPILE) -c `test -f '$<' || echo '$(srcdir)/'`$< + +.c.obj: +@AMDEP_TRUE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ +@AMDEP_TRUE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ +@AMDEP_TRUE@ $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ + $(COMPILE) -c `cygpath -w $<` + +.c.lo: +@AMDEP_TRUE@ source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ +@AMDEP_TRUE@ depfile='$(DEPDIR)/$*.Plo' tmpdepfile='$(DEPDIR)/$*.TPlo' @AMDEPBACKSLASH@ +@AMDEP_TRUE@ $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ + $(LTCOMPILE) -c -o $@ `test -f '$<' || echo '$(srcdir)/'`$< + +libgstmassink_la-massink.o: massink.c +@AMDEP_TRUE@ source='massink.c' object='libgstmassink_la-massink.o' libtool=no @AMDEPBACKSLASH@ +@AMDEP_TRUE@ depfile='$(DEPDIR)/libgstmassink_la-massink.Po' tmpdepfile='$(DEPDIR)/libgstmassink_la-massink.TPo' @AMDEPBACKSLASH@ +@AMDEP_TRUE@ $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ + $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libgstmassink_la_CFLAGS) $(CFLAGS) -c -o libgstmassink_la-massink.o `test -f 'massink.c' || echo '$(srcdir)/'`massink.c + +libgstmassink_la-massink.obj: massink.c +@AMDEP_TRUE@ source='massink.c' object='libgstmassink_la-massink.obj' libtool=no @AMDEPBACKSLASH@ +@AMDEP_TRUE@ depfile='$(DEPDIR)/libgstmassink_la-massink.Po' tmpdepfile='$(DEPDIR)/libgstmassink_la-massink.TPo' @AMDEPBACKSLASH@ +@AMDEP_TRUE@ $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ + $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libgstmassink_la_CFLAGS) $(CFLAGS) -c -o libgstmassink_la-massink.obj `cygpath -w massink.c` + +libgstmassink_la-massink.lo: massink.c +@AMDEP_TRUE@ source='massink.c' object='libgstmassink_la-massink.lo' libtool=yes @AMDEPBACKSLASH@ +@AMDEP_TRUE@ depfile='$(DEPDIR)/libgstmassink_la-massink.Plo' tmpdepfile='$(DEPDIR)/libgstmassink_la-massink.TPlo' @AMDEPBACKSLASH@ +@AMDEP_TRUE@ $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ + $(LIBTOOL) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(libgstmassink_la_CFLAGS) $(CFLAGS) -c -o libgstmassink_la-massink.lo `test -f 'massink.c' || echo '$(srcdir)/'`massink.c +CCDEPMODE = @CCDEPMODE@ + +mostlyclean-libtool: + -rm -f *.lo + +clean-libtool: + -rm -rf .libs _libs + +distclean-libtool: + -rm -f libtool +uninstall-info-am: + +ETAGS = etags +ETAGSFLAGS = + +tags: TAGS + +ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES) + list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ + unique=`for i in $$list; do \ + if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ + done | \ + $(AWK) ' { files[$$0] = 1; } \ + END { for (i in files) print i; }'`; \ + mkid -fID $$unique + +TAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ + $(TAGS_FILES) $(LISP) + tags=; \ + here=`pwd`; \ + list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ + unique=`for i in $$list; do \ + if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ + done | \ + $(AWK) ' { files[$$0] = 1; } \ + END { for (i in files) print i; }'`; \ + test -z "$(ETAGS_ARGS)$$tags$$unique" \ + || $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ + $$tags $$unique + +GTAGS: + here=`$(am__cd) $(top_builddir) && pwd` \ + && cd $(top_srcdir) \ + && gtags -i $(GTAGS_ARGS) $$here + +distclean-tags: + -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH +DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) + +top_distdir = ../.. +distdir = $(top_distdir)/$(PACKAGE)-$(VERSION) + +distdir: $(DISTFILES) + @list='$(DISTFILES)'; for file in $$list; do \ + if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ + dir=`echo "$$file" | sed -e 's,/[^/]*$$,,'`; \ + if test "$$dir" != "$$file" && test "$$dir" != "."; then \ + dir="/$$dir"; \ + $(mkinstalldirs) "$(distdir)$$dir"; \ + else \ + dir=''; \ + fi; \ + if test -d $$d/$$file; then \ + if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ + cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \ + fi; \ + cp -pR $$d/$$file $(distdir)$$dir || exit 1; \ + else \ + test -f $(distdir)/$$file \ + || cp -p $$d/$$file $(distdir)/$$file \ + || exit 1; \ + fi; \ + done +check-am: all-am +check: check-am +all-am: Makefile $(LTLIBRARIES) $(HEADERS) + +installdirs: + $(mkinstalldirs) $(DESTDIR)$(plugindir) + +install: install-am +install-exec: install-exec-am +install-data: install-data-am +uninstall: uninstall-am + +install-am: all-am + @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am + +installcheck: installcheck-am +install-strip: + $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ + INSTALL_STRIP_FLAG=-s \ + `test -z '$(STRIP)' || \ + echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install +mostlyclean-generic: + +clean-generic: + +distclean-generic: + -rm -f Makefile $(CONFIG_CLEAN_FILES) + +maintainer-clean-generic: + @echo "This command is intended for maintainers to use" + @echo "it deletes files that may require special tools to rebuild." +clean: clean-am + +clean-am: clean-generic clean-libtool clean-pluginLTLIBRARIES \ + mostlyclean-am + +distclean: distclean-am + +distclean-am: clean-am distclean-compile distclean-depend \ + distclean-generic distclean-libtool distclean-tags + +dvi: dvi-am + +dvi-am: + +info: info-am + +info-am: + +install-data-am: install-pluginLTLIBRARIES + +install-exec-am: + +install-info: install-info-am + +install-man: + +installcheck-am: + +maintainer-clean: maintainer-clean-am + +maintainer-clean-am: distclean-am maintainer-clean-generic + +mostlyclean: mostlyclean-am + +mostlyclean-am: mostlyclean-compile mostlyclean-generic \ + mostlyclean-libtool + +uninstall-am: uninstall-info-am uninstall-pluginLTLIBRARIES + +.PHONY: GTAGS all all-am check check-am clean clean-generic \ + clean-libtool clean-pluginLTLIBRARIES distclean \ + distclean-compile distclean-depend distclean-generic \ + distclean-libtool distclean-tags distdir dvi dvi-am info \ + info-am install install-am install-data install-data-am \ + install-exec install-exec-am install-info install-info-am \ + install-man install-pluginLTLIBRARIES install-strip \ + installcheck installcheck-am installdirs maintainer-clean \ + maintainer-clean-generic mostlyclean mostlyclean-compile \ + mostlyclean-generic mostlyclean-libtool tags uninstall \ + uninstall-am uninstall-info-am uninstall-pluginLTLIBRARIES + +# Tell versions [3.59,3.63) of GNU make to not export all variables. +# Otherwise a system limit (for SysV at least) may be exceeded. +.NOEXPORT: diff --git a/ext/mas/massink.c b/ext/mas/massink.c new file mode 100644 index 00000000..1b965beb --- /dev/null +++ b/ext/mas/massink.c @@ -0,0 +1,546 @@ +/* GStreamer + * Copyright (C) <1999> Erik Walthinsen <omega@cse.ogi.edu> + * + * Most of the code from maswavplay and esdsink + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Library General Public + * License as published by the Free Software Foundation; either + * version 2 of the License, or (at your option) any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Library General Public License for more details. + * + * You should have received a copy of the GNU Library General Public + * License along with this library; if not, write to the + * Free Software Foundation, Inc., 59 Temple Place - Suite 330, + * Boston, MA 02111-1307, USA. + */ + +#include "massink.h" + +#define BUFFER_SIZE 640 +#define BUFFER_TIME_NS 3628118 +#define FORCED_STABLE_LOOPS 10 +#define NANOSLEEP_GRANULARITY 100000 + + +/* elementfactory information */ +static GstElementDetails massink_details = { + "Esound audio sink", + "Sink/Audio", + "LGPL", + "Plays audio to a MAS server", + VERSION, + "Zeeshan Ali <zak147@yahoo.com>", + "(C) 2003", +}; + +/* Signals and args */ +enum { + /* FILL ME */ + LAST_SIGNAL +}; + +enum { + ARG_0, + ARG_MUTE, + ARG_DEPTH, + ARG_CHANNELS, + ARG_RATE, + ARG_HOST, +}; + +GST_PAD_TEMPLATE_FACTORY (sink_factory, + "sink", /* the name of the pads */ + GST_PAD_SINK, /* type of the pad */ + GST_PAD_ALWAYS, /* ALWAYS/SOMETIMES */ + GST_CAPS_NEW ( + "massink_sink8", /* the name of the caps */ + "audio/x-wav", /* the mime type of the caps */ + NULL + ) +); + +static void gst_massink_class_init (GstMassinkClass *klass); +static void gst_massink_init (GstMassink *massink); +static void gst_massink_set_clock (GstElement *element, GstClock *clock); +static gboolean gst_massink_open_audio (GstMassink *sink); +//static void gst_massink_close_audio (GstMassink *sink); +static GstElementStateReturn gst_massink_change_state (GstElement *element); +static gboolean gst_massink_sync_parms (GstMassink *massink); +static GstPadLinkReturn gst_massink_sinkconnect (GstPad *pad, GstCaps *caps); + +static void gst_massink_chain (GstPad *pad, GstBuffer *buf); + +static void gst_massink_set_property (GObject *object, guint prop_id, + const GValue *value, GParamSpec *pspec); +static void gst_massink_get_property (GObject *object, guint prop_id, + GValue *value, GParamSpec *pspec); + +#define GST_TYPE_MASSINK_DEPTHS (gst_massink_depths_get_type()) +static GType +gst_massink_depths_get_type (void) +{ + static GType massink_depths_type = 0; + static GEnumValue massink_depths[] = { + {8, "8", "8 Bits"}, + {16, "16", "16 Bits"}, + {0, NULL, NULL}, + }; + if (!massink_depths_type) { + massink_depths_type = g_enum_register_static("GstMassinkDepths", massink_depths); + } + return massink_depths_type; +} + +static GstElementClass *parent_class = NULL; +/*static guint gst_massink_signals[LAST_SIGNAL] = { 0 }; */ + +GType +gst_massink_get_type (void) +{ + static GType massink_type = 0; + + if (!massink_type) { + static const GTypeInfo massink_info = { + sizeof(GstMassinkClass), NULL, + NULL, + (GClassInitFunc)gst_massink_class_init, + NULL, + NULL, + sizeof(GstMassink), + 0, + (GInstanceInitFunc)gst_massink_init, + }; + massink_type = g_type_register_static(GST_TYPE_ELEMENT, "GstMassink", &massink_info, 0); + } + return massink_type; +} + +static void +gst_massink_class_init (GstMassinkClass *klass) +{ + GObjectClass *gobject_class; + GstElementClass *gstelement_class; + + gobject_class = (GObjectClass*)klass; + gstelement_class = (GstElementClass*)klass; + + parent_class = g_type_class_ref(GST_TYPE_ELEMENT); + + g_object_class_install_property(G_OBJECT_CLASS(klass), ARG_MUTE, + g_param_spec_boolean("mute","mute","mute", + TRUE,G_PARAM_READWRITE)); /* CHECKME */ + g_object_class_install_property(G_OBJECT_CLASS(klass), ARG_DEPTH, + g_param_spec_enum("depth","depth","depth", + GST_TYPE_MASSINK_DEPTHS,16,G_PARAM_READWRITE)); /* CHECKME! */ + g_object_class_install_property(G_OBJECT_CLASS(klass), ARG_RATE, + g_param_spec_int("frequency","frequency","frequency", + G_MININT,G_MAXINT,0,G_PARAM_READWRITE)); /* CHECKME */ + g_object_class_install_property(G_OBJECT_CLASS(klass), ARG_HOST, + g_param_spec_string("host","host","host", + NULL, G_PARAM_READWRITE)); /* CHECKME */ + + gobject_class->set_property = gst_massink_set_property; + gobject_class->get_property = gst_massink_get_property; + + gstelement_class->change_state = gst_massink_change_state; + gstelement_class->set_clock = gst_massink_set_clock; +} + +static void +gst_massink_set_clock (GstElement *element, GstClock *clock) +{ + GstMassink *massink; + + massink = GST_MASSINK (element); + + massink->clock = clock; +} + +static void +gst_massink_init(GstMassink *massink) +{ + massink->sinkpad = gst_pad_new_from_template ( + GST_PAD_TEMPLATE_GET (sink_factory), "sink"); + gst_element_add_pad(GST_ELEMENT(massink), massink->sinkpad); + gst_pad_set_chain_function(massink->sinkpad, GST_DEBUG_FUNCPTR(gst_massink_chain)); + gst_pad_set_link_function(massink->sinkpad, gst_massink_sinkconnect); + + massink->mute = FALSE; + massink->format = 16; + massink->depth = 16; + massink->channels = 2; + massink->frequency = 44100; + massink->host = NULL; +} + +static gboolean +gst_massink_sync_parms (GstMassink *massink) +{ + g_return_val_if_fail (massink != NULL, FALSE); + g_return_val_if_fail (GST_IS_MASSINK (massink), FALSE); + + //gst_massink_close_audio (massink); + //return gst_massink_open_audio (massink); + return 1; +} + +static GstPadLinkReturn +gst_massink_sinkconnect (GstPad *pad, GstCaps *caps) +{ + GstMassink *massink; + + massink = GST_MASSINK (gst_pad_get_parent (pad)); + + if (!GST_CAPS_IS_FIXED (caps)) + return GST_PAD_LINK_DELAYED; + + if (gst_massink_sync_parms (massink)) + return GST_PAD_LINK_OK; + + return GST_PAD_LINK_REFUSED; +} + +static void +gst_massink_chain (GstPad *pad, GstBuffer *buf) +{ + gint32 err; + + g_return_if_fail(pad != NULL); + g_return_if_fail(GST_IS_PAD(pad)); + g_return_if_fail(buf != NULL); + + GstMassink *massink = GST_MASSINK (gst_pad_get_parent (pad)); + + if (massink->clock) { + GstClockID id = gst_clock_new_single_shot_id (massink->clock, GST_BUFFER_TIMESTAMP (buf)); + + GST_DEBUG (0, "massink: clock wait: %llu\n", GST_BUFFER_TIMESTAMP (buf)); + gst_element_clock_wait (GST_ELEMENT (massink), id, NULL); + gst_clock_id_free (id); + } + + if (GST_BUFFER_DATA (buf) != NULL) { + if (!massink->mute) { + GST_DEBUG (0, "massink: data=%p size=%d", GST_BUFFER_DATA (buf), GST_BUFFER_SIZE (buf)); + if (GST_BUFFER_SIZE (buf) > BUFFER_SIZE) { + gst_buffer_unref (buf); + return; + } + + massink->data->length = GST_BUFFER_SIZE (buf); + + memcpy (massink->data->segment, GST_BUFFER_DATA (buf), GST_BUFFER_SIZE (buf)); + + err = mas_send (massink->audio_channel, massink->data); + + if (err < 0) { + g_print ("error sending data to MAS server\n"); + gst_buffer_unref (buf); + return; + } + + /* FIXME: Please correct the Timestamping if its wrong */ + massink->data->header.media_timestamp += massink->data->length / 4; + massink->data->header.sequence++; + } + } + + gst_buffer_unref (buf); +} + +static void +gst_massink_set_property (GObject *object, guint prop_id, const GValue *value, GParamSpec *pspec) +{ + GstMassink *massink; + + /* it's not null if we got it, but it might not be ours */ + g_return_if_fail(GST_IS_MASSINK(object)); + massink = GST_MASSINK(object); + + switch (prop_id) { + case ARG_MUTE: + massink->mute = g_value_get_boolean (value); + break; + case ARG_DEPTH: + massink->depth = g_value_get_enum (value); + gst_massink_sync_parms (massink); + break; + case ARG_CHANNELS: + massink->channels = g_value_get_enum (value); + gst_massink_sync_parms (massink); + break; + case ARG_RATE: + massink->frequency = g_value_get_int (value); + gst_massink_sync_parms (massink); + break; + case ARG_HOST: + if (massink->host != NULL) g_free(massink->host); + if (g_value_get_string (value) == NULL) + massink->host = NULL; + else + massink->host = g_strdup (g_value_get_string (value)); + break; + default: + break; + } +} + +static void +gst_massink_get_property (GObject *object, guint prop_id, GValue *value, GParamSpec *pspec) +{ + GstMassink *massink; + + /* it's not null if we got it, but it might not be ours */ + g_return_if_fail(GST_IS_MASSINK(object)); + massink = GST_MASSINK(object); + + switch (prop_id) { + case ARG_MUTE: + g_value_set_boolean (value, massink->mute); + break; + case ARG_DEPTH: + g_value_set_enum (value, massink->depth); + break; + case ARG_CHANNELS: + g_value_set_enum (value, massink->channels); + break; + case ARG_RATE: + g_value_set_int (value, massink->frequency); + break; + case ARG_HOST: + g_value_set_string (value, massink->host); + break; + default: + G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec); + break; + } +} + +static gboolean +plugin_init (GModule *module, GstPlugin *plugin) +{ + GstElementFactory *factory; + + factory = gst_element_factory_new("massink", GST_TYPE_MASSINK, + &massink_details); + g_return_val_if_fail(factory != NULL, FALSE); + + gst_element_factory_add_pad_template(factory, GST_PAD_TEMPLATE_GET (sink_factory)); + + gst_plugin_add_feature (plugin, GST_PLUGIN_FEATURE (factory)); + + return TRUE; +} + +GstPluginDesc plugin_desc = { + GST_VERSION_MAJOR, + GST_VERSION_MINOR, + "massink", + plugin_init +}; + +static gboolean +gst_massink_open_audio (GstMassink *massink) +{ + gint32 err; + char *ratestring = g_malloc (16); + char *bps = g_malloc (8); + + struct mas_data_characteristic* dc; + + g_print ("Connecting to MAS.\n"); + masc_log_verbosity (MAS_VERBLVL_DEBUG); + err = mas_init(); + + if (err < 0) { + GST_DEBUG(err, "connection with local MAS server failed."); + exit (1); + } + + GST_DEBUG (0, "Establishing audio output channel."); + mas_make_data_channel ("Gstreamer", &massink->audio_channel, &massink->audio_source, &massink->audio_sink); + mas_asm_get_port_by_name (0, "default_mix_sink", &massink->mix_sink); + + GST_DEBUG (0, "Instantiating endian device."); + err = mas_asm_instantiate_device ("endian", 0, 0, &massink->endian); + + if (err < 0) { + GST_DEBUG(0, "Failed to instantiate endian converter device"); + exit(1); + } + + mas_asm_get_port_by_name (massink->endian, "endian_sink", &massink->endian_sink); + mas_asm_get_port_by_name (massink->endian, "endian_source", &massink->endian_source); + + sprintf (bps, "%u", massink->depth); + sprintf (ratestring, "%u", massink->frequency); + + GST_DEBUG (0, "Connecting net -> endian."); + masc_make_dc (&dc, 6); + + /* wav weirdness: 8 bit data is unsigned, >8 data is signed. */ + masc_append_dc_key_value (dc, "format", (massink->depth==8) ? "ulinear":"linear"); + masc_append_dc_key_value (dc, "resolution", bps); + masc_append_dc_key_value (dc, "sampling rate", ratestring); + masc_append_dc_key_value (dc, "channels", "2"); + masc_append_dc_key_value (dc, "endian", "little"); + err = mas_asm_connect_source_sink (massink->audio_source, massink->endian_sink, dc); + + if ( err < 0 ) { + GST_DEBUG(err, "Failed to connect net audio output to endian"); + return -1; + } + + /* The next device is 'if needed' only. After the following if() + statement, open_source will contain the current unconnected + source in the path (will be either endian_source or + squant_source in this case) + */ + + massink->open_source = massink->endian_source; + + if (massink->depth != 16) { + GST_DEBUG (0, "Sample resolution is not 16 bit/sample, instantiating squant device."); + err = mas_asm_instantiate_device ("squant", 0, 0, &massink->squant); + if (err < 0) { + GST_DEBUG(err, "Failed to instantiate squant device"); + return -1; + } + + mas_asm_get_port_by_name (massink->squant, "squant_sink", &massink->squant_sink); + mas_asm_get_port_by_name (massink->squant, "squant_source", &massink->squant_source); + + GST_DEBUG (0, "Connecting endian -> squant."); + + masc_make_dc (&dc, 6); + masc_append_dc_key_value (dc,"format",(massink->depth==8) ? "ulinear":"linear"); + masc_append_dc_key_value (dc, "resolution", bps); + masc_append_dc_key_value (dc, "sampling rate", ratestring); + masc_append_dc_key_value (dc, "channels", "2"); + masc_append_dc_key_value (dc, "endian", "host"); + err = mas_asm_connect_source_sink (massink->endian_source, massink->squant_sink, dc); + + if (err < 0) { + GST_DEBUG(err, "Failed to connect endian output to squant"); + return -1; + } + + /* sneaky: the squant device is optional -> pretend it isn't there */ + massink->open_source = massink->squant_source; + } + + + /* Another 'if necessary' device, as above */ + if (massink->frequency != 44100) { + GST_DEBUG (0, "Sample rate is not 44100, instantiating srate device."); + err = mas_asm_instantiate_device ("srate", 0, 0, &massink->srate); + + if (err < 0) { + GST_DEBUG (err, "Failed to instantiate srate device"); + return -1; + } + + mas_asm_get_port_by_name (massink->srate, "sink", &massink->srate_sink); + mas_asm_get_port_by_name (massink->srate, "source", &massink->srate_source); + + GST_DEBUG (0, "Connecting to srate."); + masc_make_dc (&dc, 6); + masc_append_dc_key_value (dc, "format", "linear"); + masc_append_dc_key_value (dc, "resolution", "16"); + masc_append_dc_key_value (dc, "sampling rate", ratestring); + masc_append_dc_key_value (dc, "channels", "2"); + masc_append_dc_key_value (dc, "endian", "host"); + + err = mas_asm_connect_source_sink (massink->open_source, massink->srate_sink, dc); + + if ( err < 0 ) { + GST_DEBUG(err, "Failed to connect to srate"); + return -1; + } + + + massink->open_source = massink->srate_source; + } + + GST_DEBUG(0, "Connecting to mix."); + masc_make_dc(&dc, 6); + masc_append_dc_key_value (dc, "format", "linear"); + masc_append_dc_key_value (dc, "resolution", "16"); + masc_append_dc_key_value (dc, "sampling rate", "44100"); + masc_append_dc_key_value (dc, "channels", "2"); + masc_append_dc_key_value (dc, "endian", "host"); + + err = mas_asm_connect_source_sink (massink->open_source, massink->mix_sink, dc); + + if ( err < 0 ) { + GST_DEBUG(err, "Failed to connect to mixer"); + return -1; + } + + GST_FLAG_SET (massink, GST_MASSINK_OPEN); + + masc_make_mas_data (&massink->data, BUFFER_SIZE); + + massink->data->header.type = 10; + + massink->data->header.media_timestamp = 0; + massink->data->header.sequence = 0; + + return TRUE; +} + +/*static void +gst_massink_close_audio (GstMassink *massink) +{ + mas_free_device(massink->endian); + mas_free_device(massink->srate); + mas_free_device(massink->squant); + + mas_free_port(massink->mix_sink); + mas_free_port(massink->srate_source); + mas_free_port(massink->srate_sink); + mas_free_port(massink->audio_source); + mas_free_port(massink->audio_sink); + mas_free_port(massink->endian_source); + mas_free_port(massink->endian_sink); + mas_free_port(massink->squant_source); + mas_free_port(massink->squant_sink); + mas_free_port(massink->open_source); + + mas_free_channel (massink->audio_channel); + masc_destroy_mas_data (massink->data); + + g_free (ratestring); + g_free (bps); + + GST_FLAG_UNSET (massink, GST_MASSINK_OPEN); + + GST_DEBUG (0, "massink: closed sound channel"); +}*/ + +static GstElementStateReturn +gst_massink_change_state (GstElement *element) +{ + g_return_val_if_fail (GST_IS_MASSINK (element), FALSE); + + /* if going down into NULL state, close the fd if it's open */ + if (GST_STATE_PENDING (element) == GST_STATE_NULL) { + //if (GST_FLAG_IS_SET (element, GST_MASSINK_OPEN)) + //gst_massink_close_audio (GST_MASSINK (element)); + /* otherwise (READY or higher) we need to open the fd */ + } else { + if (!GST_FLAG_IS_SET (element, GST_MASSINK_OPEN)) { + if (!gst_massink_open_audio (GST_MASSINK (element))) + return GST_STATE_FAILURE; + } + } + + if (GST_ELEMENT_CLASS (parent_class)->change_state) + return GST_ELEMENT_CLASS (parent_class)->change_state (element); + return GST_STATE_SUCCESS; +} + diff --git a/ext/mas/massink.h b/ext/mas/massink.h new file mode 100644 index 00000000..7194ef38 --- /dev/null +++ b/ext/mas/massink.h @@ -0,0 +1,94 @@ +/* GStreamer + * Copyright (C) <1999> Erik Walthinsen <omega@cse.ogi.edu> + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Library General Public + * License as published by the Free Software Foundation; either + * version 2 of the License, or (at your option) any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Library General Public License for more details. + * + * You should have received a copy of the GNU Library General Public + * License along with this library; if not, write to the + * Free Software Foundation, Inc., 59 Temple Place - Suite 330, + * Boston, MA 02111-1307, USA. + */ + + +#ifndef __GST_MASSINK_H__ +#define __GST_MASSINK_H__ + +#include <gst/gst.h> +#include <stdio.h> +#include <stdlib.h> +#include <string.h> +#include <mas/mas.h> + +#ifdef __cplusplus +extern "C" { +#endif /* __cplusplus */ + + +#define GST_TYPE_MASSINK \ + (gst_massink_get_type()) +#define GST_MASSINK(obj) \ + (G_TYPE_CHECK_INSTANCE_CAST((obj),GST_TYPE_MASSINK,GstMassink)) +#define GST_MASSINK_CLASS(klass) \ + (G_TYPE_CHECK_CLASS_CAST((klass),GST_TYPE_MASSINK,GstMassink)) +#define GST_IS_MASSINK(obj) \ + (G_TYPE_CHECK_INSTANCE_TYPE((obj),GST_TYPE_MASSINK)) +#define GST_IS_MASSINK_CLASS(obj) \ + (G_TYPE_CHECK_CLASS_TYPE((klass),GST_TYPE_MASSINK)) + +typedef enum { + GST_MASSINK_OPEN = GST_ELEMENT_FLAG_LAST, + GST_MASSINK_FLAG_LAST = GST_ELEMENT_FLAG_LAST+2, +} GstMasSinkFlags; + +typedef struct _GstMassink GstMassink; +typedef struct _GstMassinkClass GstMassinkClass; + +struct _GstMassink { + GstElement element; + + GstPad *sinkpad; + + gboolean mute; + gint format; + gint depth; + gint channels; + gint frequency; + + gchar *host; + + mas_channel_t audio_channel; + mas_port_t mix_sink; + mas_port_t srate_source, srate_sink; + mas_port_t audio_source, audio_sink; + mas_port_t endian_sink, endian_source; + mas_port_t squant_sink, squant_source; + mas_port_t open_source; /* (!) */ + mas_device_t endian; + mas_device_t srate; + mas_device_t squant; + + struct mas_data *data; + GstClock *clock; +}; + +struct _GstMassinkClass { + GstElementClass parent_class; +}; + +GType gst_massink_get_type(void); + + +#ifdef __cplusplus +} +#endif /* __cplusplus */ + + +#endif /* __GST_MASSINK_H__ */ diff --git a/gst/videocrop/gstvideocrop.c b/gst/videocrop/gstvideocrop.c index 0a3fb1a5..20a524b5 100644 --- a/gst/videocrop/gstvideocrop.c +++ b/gst/videocrop/gstvideocrop.c @@ -21,6 +21,10 @@ #include <string.h> +#ifdef __MMX__ +#include <mmx.h> +#endif + #define GST_TYPE_VIDEO_CROP \ (gst_video_crop_get_type()) #define GST_VIDEO_CROP(obj) \ @@ -281,17 +285,22 @@ gst_video_crop_i420 (GstVideoCrop *video_crop, GstBuffer *src_buffer, GstBuffer guint8 *srcY, *srcU, *srcV; guint8 *destY, *destU, *destV; gint width = video_crop->crop_width; + gint crop_height = video_crop->crop_height; gint src_stride = video_crop->width; gint frame_size = video_crop->width * video_crop->height; - gint crop_height; gint j; srcY = GST_BUFFER_DATA (src_buffer) + (src_stride * video_crop->crop_y + video_crop->crop_x); destY = GST_BUFFER_DATA (dest_buffer); - crop_height = video_crop->crop_height; - /* copy Y plane first */ + + for (j = crop_height; j; j--) { + memcpy (destY, srcY, width); + srcY += src_stride; + destY += width; + } + for (j = crop_height; j; j--) { memcpy (destY, srcY, width); srcY += src_stride; |