X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=configure;h=f772ed13d525adc14c68710f35dd28aa448c6aab;hb=0187178e07218772553767da0cef12e0c0b149a6;hp=c00193c1ff02f88eca24fbe6b1638febb155116d;hpb=31abdc45e0a8cc076a3752ece68983bbecb89cd8;p=ffmpeg diff --git a/configure b/configure index c00193c1ff0..f772ed13d52 100755 --- a/configure +++ b/configure @@ -3,84 +3,263 @@ # ffmpeg configure script (c) 2000, 2001, 2002 Fabrice Bellard # -if test x"$1" = x"-h" -o x"$1" = x"--help" ; then -cat << EOF +show_help(){ + echo "Usage: configure [options]" + echo "Options: [defaults in brackets after descriptions]" + echo + echo "Standard options:" + echo " --help print this message" + echo " --log log tests and output to config.err" + echo " --prefix=PREFIX install in PREFIX [$prefix]" + echo " --libdir=DIR install libs in DIR [PREFIX/lib]" + echo " --incdir=DIR install includes in DIR [PREFIX/include/ffmpeg]" + echo " --mandir=DIR install man page in DIR [PREFIX/man]" + echo " --enable-mp3lame enable MP3 encoding via libmp3lame [default=no]" + echo " --enable-libogg enable Ogg support via libogg [default=no]" + echo " --enable-vorbis enable Vorbis support via libvorbis [default=no]" + echo " --enable-theora enable Theora support via libtheora [default=no]" + echo " --enable-faad enable FAAD support via libfaad [default=no]" + echo " --enable-faadbin build FAAD support with runtime linking [default=no]" + echo " --enable-faac enable FAAC support via libfaac [default=no]" + echo " --enable-libgsm enable GSM support via libgsm [default=no]" + echo " --enable-xvid enable XviD support via xvidcore [default=no]" + echo " --enable-x264 enable H.264 encoding via x264 [default=no]" + echo " --enable-mingw32 enable MinGW native/cross Windows compile" + echo " --enable-mingwce enable MinGW native/cross WinCE compile" + echo " --enable-a52 enable GPLed A52 support [default=no]" + echo " --enable-a52bin open liba52.so.0 at runtime [default=no]" + echo " --enable-dts enable GPLed DTS support [default=no]" + echo " --enable-pp enable GPLed postprocessing support [default=no]" + echo " --enable-static build static libraries [default=yes]" + echo " --disable-static do not build static libraries [default=no]" + echo " --enable-shared build shared libraries [default=no]" + echo " --disable-shared do not build shared libraries [default=yes]" + echo " --enable-amr_nb enable amr_nb float audio codec" + echo " --enable-amr_nb-fixed use fixed point for amr-nb codec" + echo " --enable-amr_wb enable amr_wb float audio codec" + echo " --enable-amr_if2 enable amr_wb IF2 audio codec" + echo " --enable-sunmlib use Sun medialib [default=no]" + echo " --enable-pthreads use pthreads [default=no]" + echo " --enable-dc1394 enable IIDC-1394 grabbing using libdc1394" + echo " and libraw1394 [default=no]" + echo " --enable-gpl allow use of GPL code, the resulting libav*" + echo " and ffmpeg will be under GPL [default=no]" + echo "" + echo "Advanced options (experts only):" + echo " --source-path=PATH path to source code [$source_path]" + echo " --cross-prefix=PREFIX use PREFIX for compilation tools [$cross_prefix]" + echo " --cc=CC use C compiler CC [$cc]" + echo " --make=MAKE use specified make [$make]" + echo " --extra-cflags=ECFLAGS add ECFLAGS to CFLAGS [$CFLAGS]" + echo " --extra-ldflags=ELDFLAGS add ELDFLAGS to LDFLAGS [$LDFLAGS]" + echo " --extra-libs=ELIBS add ELIBS [$ELIBS]" + echo " --build-suffix=SUFFIX suffix for application specific build []" + echo " --cpu=CPU force cpu to CPU [$cpu]" + echo " --tune=CPU tune code for a particular CPU" + echo " (may fail or perform badly on other CPUs)" + echo " --powerpc-perf-enable enable performance report on PPC" + echo " (requires enabling PMC)" + echo " --disable-mmx disable MMX usage" + echo " --disable-iwmmxt disable iwmmxt usage" + echo " --disable-altivec disable AltiVec usage" + echo " --disable-audio-oss disable OSS audio support [default=no]" + echo " --disable-audio-beos disable BeOS audio support [default=no]" + echo " --disable-v4l disable video4linux grabbing [default=no]" + echo " --disable-v4l2 disable video4linux2 grabbing [default=no]" + echo " --disable-bktr disable bktr video grabbing [default=no]" + echo " --disable-dv1394 disable DV1394 grabbing [default=no]" + echo " --disable-network disable network support [default=no]" + echo " --disable-zlib disable zlib [default=no]" + echo " --disable-lzo disable lzo [default=no]" + echo " --disable-simple_idct disable simple IDCT routines [default=no]" + echo " --disable-vhook disable video hooking support" + echo " --enable-gprof enable profiling with gprof [$gprof]" + echo " --disable-debug disable debugging symbols" + echo " --disable-opts disable compiler optimizations" + echo " --disable-mpegaudio-hp faster (but less accurate)" + echo " MPEG audio decoding [default=no]" + echo " --disable-protocols disable I/O protocols support [default=no]" + echo " --disable-ffserver disable ffserver build" + echo " --disable-ffplay disable ffplay build" + echo " --enable-small optimize for size instead of speed" + echo " --enable-memalign-hack emulate memalign, interferes with memory debuggers" + echo " --disable-strip disable stripping of executables and shared libraries" + echo " --disable-encoder=NAME disables encoder NAME" + echo " --enable-encoder=NAME enables encoder NAME" + echo " --disable-decoder=NAME disables decoder NAME" + echo " --enable-decoder=NAME enables decoder NAME" + echo " --disable-encoders disables all encoders" + echo " --disable-decoders disables all decoders" + echo " --disable-muxers disables all muxers" + echo " --disable-demuxers disables all demuxers" + echo "" + echo "NOTE: Object files are built at the place where configure is launched." + exit 1 +} + +log(){ + echo "$@" >>$logfile +} + +logfile(){ + log BEGIN $1 + cat -n $1 >>$logfile + log END $1 +} + +die(){ + log "$@" + echo "$@" + rm -f $TMPC $TMPO $TMPE $TMPS $TMPH + exit 1 +} + +enabled(){ + eval test "\$$1" = "yes" +} + +flags_saved(){ + (: ${SAVE_CFLAGS?}) 2>/dev/null +} + +save_flags(){ + flags_saved && return + SAVE_CFLAGS="$CFLAGS" + SAVE_LDFLAGS="$LDFLAGS" + SAVE_extralibs="$extralibs" +} + +restore_flags(){ + CFLAGS="$SAVE_CFLAGS" + LDFLAGS="$SAVE_LDFLAGS" + extralibs="$SAVE_extralibs" + unset SAVE_CFLAGS + unset SAVE_LDFLAGS + unset SAVE_extralibs +} + +temp_cflags(){ + save_flags + CFLAGS="$CFLAGS $*" +} -Usage: configure [options] -Options: [defaults in brackets after descriptions] +temp_ldflags(){ + save_flags + LDFLAGS="$LDFLAGS $*" +} + +temp_extralibs(){ + save_flags + extralibs="$extralibs $*" +} + +append(){ + var=$1 + shift + flags_saved && eval "SAVE_$var=\"\$SAVE_$var $*\"" + eval "$var=\"\$$var $*\"" +} + +add_cflags(){ + append CFLAGS "$@" +} + +add_ldflags(){ + append LDFLAGS "$@" +} + +add_extralibs(){ + append extralibs "$@" +} + +check_cc(){ + log check_cc "$@" + cat >$TMPC + logfile $TMPC + log $cc $CFLAGS "$@" -c -o $TMPO $TMPC + $cc $CFLAGS "$@" -c -o $TMPO $TMPC >>$logfile 2>&1 +} + +check_cpp(){ + log check_cpp "$@" + cat >$TMPC + logfile $TMPC + log $cc $CFLAGS "$@" -E -o $TMPO $TMPC + $cc $CFLAGS "$@" -E -o $TMPO $TMPC >>$logfile 2>&1 +} +check_ld(){ + log check_ld "$@" + cat >$TMPC + logfile $TMPC + log $cc $CFLAGS $LDFLAGS "$@" -o $TMPE $TMPC $extralibs + $cc $CFLAGS $LDFLAGS "$@" -o $TMPE $TMPC $extralibs >>$logfile 2>&1 +} + +check_cflags(){ + log check_cflags "$@" + check_cc "$@" < +int x; +EOF +} + +check_func(){ + log check_func "$@" + func=$1 + shift + check_ld "$@" <&1` case "$TARGET_OS" in - Linux|FreeBSD|NetBSD|BSD/OS|OpenBSD|SunOS|QNX|Darwin|GNU|BeOS) + Linux|FreeBSD|NetBSD|BSD/OS|OpenBSD|SunOS|QNX|Darwin|GNU|BeOS|MorphOS) ;; IRIX*) TARGET_OS=IRIX @@ -387,7 +613,7 @@ TARGET_OS=`( uname -s ) 2>&1` esac # find source path -source_path="`echo $0 | sed -e 's#/configure##'`" +source_path="`dirname $0`" source_path_used="yes" if test -z "$source_path" -o "$source_path" = "." ; then source_path=`pwd` @@ -405,10 +631,14 @@ CODEC_LIST=`grep 'register_avcodec(&[a-z]' $source_path/libavcodec/allcodecs.c for opt do case "$opt" in + --log) log=yes + ;; --prefix=*) prefix=`echo $opt | cut -d '=' -f 2`; force_prefix=yes ;; --libdir=*) libdir=`echo $opt | cut -d '=' -f 2`; force_libdir=yes ;; + --incdir=*) incdir=`echo $opt | cut -d '=' -f 2`; + ;; --mandir=*) mandir=`echo $opt | cut -d '=' -f 2` ;; --source-path=*) source_path=`echo $opt | cut -d '=' -f 2` @@ -421,7 +651,7 @@ for opt do ;; --extra-cflags=*) CFLAGS="$CFLAGS ${opt#--extra-cflags=}" ;; - --extra-ldflags=*) LDFLAGS="$LDFLAGS ${opt#--extra-ldflags=}" + --extra-ldflags=*) FFLDFLAGS="$FFLDFLAGS ${opt#--extra-ldflags=}" ;; --extra-libs=*) extralibs=${opt#--extra-libs=} ;; @@ -443,6 +673,8 @@ for opt do ;; --disable-v4l) v4l="no" ;; + --disable-v4l2) v4l2="no" + ;; --disable-bktr) bktr="no" ;; --disable-audio-oss) audio_oss="no" @@ -455,25 +687,28 @@ for opt do ;; --disable-zlib) zlib="no" ;; + --disable-lzo) lzo="no" + ;; --enable-a52) a52="yes" ;; --enable-a52bin) a52bin="yes" ;; - --enable-dts) dts="yes" ; extralibs="$extralibs -ldts" + --enable-dts) dts="yes" ;; --enable-pp) pp="yes" ;; - --enable-shared-pp) shared_pp="yes" - ;; --enable-libgsm) libgsm="yes" ;; --enable-mp3lame) mp3lame="yes" ;; --enable-libogg) libogg="yes" + pkg_requires="$pkg_requires ogg >= 1.1" ;; --enable-vorbis) vorbis="yes" + pkg_requires="$pkg_requires vorbis vorbisenc" ;; --enable-theora) theora="yes" + pkg_requires="$pkg_requires theora" ;; --enable-faad) faad="yes" ;; @@ -483,9 +718,10 @@ for opt do ;; --enable-xvid) xvid="yes" ;; - --enable-x264) x264="yes"; extralibs="$extralibs -lx264" + --enable-x264) x264="yes" ;; --enable-dc1394) dc1394="yes" + pkg_requires="$pkg_requires libraw1394" ;; --disable-vhook) vhook="no" ;; @@ -493,27 +729,37 @@ for opt do ;; --enable-mingw32) mingw32="yes" ;; + --enable-mingwce) mingwce="yes" + ;; + --enable-static) lstatic="yes" + ;; + --disable-static) lstatic="no" + ;; --enable-shared) lshared="yes" ;; + --disable-shared) lshared="no" + ;; --disable-debug) debug="no" ;; --disable-opts) optimize="no" ;; --disable-mpegaudio-hp) mpegaudio_hp="no" ;; + --disable-protocols) protocols="no"; network="no"; ffserver="no" + ;; --disable-ffserver) ffserver="no" ;; --disable-ffplay) ffplay="no" ;; --enable-small) optimize="small" ;; - --enable-amr_nb) amr_nb="yes" + --enable-amr_nb) amr="yes"; amr_nb="yes"; amr_nb_fixed="no" + ;; + --enable-amr_nb-fixed) amr="yes"; amr_nb_fixed="yes"; amr_nb="no" ;; - --enable-amr_nb-fixed) amr_nb_fixed="yes" + --enable-amr_wb) amr="yes"; amr_wb="yes" ;; - --enable-amr_wb) amr_wb="yes" - ;; - --enable-amr_if2) amr_if2="yes" + --enable-amr_if2) amr="yes"; amr_if2="yes" ;; --enable-sunmlib) sunmlib="yes" ;; @@ -525,20 +771,60 @@ for opt do ;; --disable-strip) dostrip="no" ;; - --enable-codec=*) CODEC_LIST="$CODEC_LIST ${opt#--enable-codec=}" + --enable-encoder=*) CODEC_LIST="$CODEC_LIST ${opt#--enable-encoder=}_encoder" + ;; + --enable-decoder=*) CODEC_LIST="$CODEC_LIST ${opt#--enable-decoder=}_decoder" ;; - --disable-codec=*) CODEC_LIST="`echo $CODEC_LIST | sed -e \"s#${opt#--disable-codec=}##\"`" + --disable-encoder=*) CODEC_LIST="`echo $CODEC_LIST | sed -e \"s#${opt#--disable-encoder=}_encoder##\"`" + ;; + --disable-decoder=*) CODEC_LIST="`echo $CODEC_LIST | sed -e \"s#${opt#--disable-decoder=}_decoder##\"`" ;; --disable-encoders) CODEC_LIST="`echo $CODEC_LIST | sed 's/[-_a-zA-Z0-9]*encoder//g'`" ;; --disable-decoders) CODEC_LIST="`echo $CODEC_LIST | sed 's/[-_a-zA-Z0-9]*decoder//g'`" ;; + --disable-muxers) muxers="no"; ffserver="no" + ;; + --disable-demuxers) demuxers="no" + ;; + --help) show_help + ;; + *) + echo "Unknown option \"$opt\"." + echo "See $0 --help for available options." + exit 1 + ;; esac done +if enabled log; then + logfile=config.err + echo "# $0 $@" >$logfile + set >>$logfile +fi + +# Combine FFLDFLAGS and the LDFLAGS environment variable +LDFLAGS="$FFLDFLAGS $LDFLAGS" + +cc="${cross_prefix}${cc}" +ar="${cross_prefix}${ar}" +ranlib="${cross_prefix}${ranlib}" +strip="${cross_prefix}${strip}" + +# we need to build at least one lib type +if test "$lstatic" = "no" && test "$lshared" = "no" ; then + cat < $TMPC << EOF - #include - int main( void ) { return 0; } -EOF - - if $cc $CFLAGS -o $TMPE $TMPC 2> /dev/null ; then - cat > $TMPC << EOF + if check_header faad.h; then + check_cc << EOF #include #ifndef FAAD2_VERSION ok faad1 #endif int main( void ) { return 0; } EOF - if $cc $CFLAGS -o $TMPE $TMPC 2> /dev/null ; then - echo "faad2 is under GPL and --enable-gpl is not specified" + if test $? = 0 ; then + echo "FAAD2 is under GPL and --enable-gpl is not specified." fail="yes" fi else faad="no" faadbin="no" - echo "faad test failed" + echo "FAAD test failed." fi fi - + if test "$fail" = "yes"; then exit 1 fi fi -# compute mmx state +# compute MMX state if test $mmx = "default"; then if test $cpu = "x86" -o $cpu = "x86_64"; then mmx="yes" @@ -620,42 +901,38 @@ fi # check iwmmxt support if test $iwmmxt = "default" -a $cpu = "armv4l"; then - cat > $TMPC << EOF - int main(void) { + iwmmxt=no + check_cc < /dev/null ; then - iwmmxt=yes - fi fi #Darwin CC versions needmdynamicnopic="no" if test $targetos = Darwin; then if test -n "`$cc -v 2>&1 | grep xlc`"; then - CFLAGS="$CFLAGS -qpdf2 -qlanglvl=extc99 -qmaxmem=-1 -qarch=auto -qtune=auto" + CFLAGS="$CFLAGS -qpdf2 -qlanglvl=extc99 -qmaxmem=-1 -qarch=auto -qtune=auto" else - gcc_version="`$cc -v 2>&1 | grep version | cut -d ' ' -f3-`" - case "$gcc_version" in - *2.95*) - CFLAGS="$CFLAGS -no-cpp-precomp -pipe -fomit-frame-pointer" - ;; - *[34].*) - CFLAGS="$CFLAGS -no-cpp-precomp -pipe -fomit-frame-pointer -force_cpusubtype_ALL -Wno-sign-compare" - if test "$lshared" = no; then - needmdynamicnopic="yes" - fi - ;; - *) - CFLAGS="$CFLAGS -no-cpp-precomp -pipe -fomit-frame-pointer" - if test "$lshared" = no; then - needmdynamicnopic="yes" - fi - ;; - esac + gcc_version="`$cc -v 2>&1 | grep version | cut -d ' ' -f3-`" + case "$gcc_version" in + *2.95*) + CFLAGS="$CFLAGS -no-cpp-precomp -pipe -fomit-frame-pointer" + ;; + *[34].*) + CFLAGS="$CFLAGS -no-cpp-precomp -pipe -fomit-frame-pointer -force_cpusubtype_ALL -Wno-sign-compare" + if test "$lshared" = no; then + needmdynamicnopic="yes" + fi + ;; + *) + CFLAGS="$CFLAGS -no-cpp-precomp -pipe -fomit-frame-pointer" + if test "$lshared" = no; then + needmdynamicnopic="yes" + fi + ;; + esac fi fi @@ -673,66 +950,68 @@ TUNECPU="generic" POWERPCMODE="32bits" if test $tune != "generic"; then case $tune in - 601|ppc601|PowerPC601) - CFLAGS="$CFLAGS -mcpu=601" - if test $altivec = "yes"; then - echo "WARNING: tuning for PPC601 but altivec enabled !"; - fi - TUNECPU=ppc601 - ;; - 603*|ppc603*|PowerPC603*) - CFLAGS="$CFLAGS -mcpu=603" - if test $altivec = "yes"; then - echo "WARNING: tuning for PPC603 but altivec enabled !"; - fi - TUNECPU=ppc603 - ;; - 604*|ppc604*|PowerPC604*) - CFLAGS="$CFLAGS -mcpu=604" - if test $altivec = "yes"; then - echo "WARNING: tuning for PPC604 but altivec enabled !"; - fi - TUNECPU=ppc604 - ;; - G3|g3|75*|ppc75*|PowerPC75*) - CFLAGS="$CFLAGS -mcpu=750 -mtune=750 -mpowerpc-gfxopt" - if test $altivec = "yes"; then - echo "WARNING: tuning for PPC75x but altivec enabled !"; - fi - TUNECPU=ppc750 - ;; - G4|g4|745*|ppc745*|PowerPC745*) - CFLAGS="$CFLAGS -mcpu=7450 -mtune=7450 -mpowerpc-gfxopt" - if test $altivec = "no"; then - echo "WARNING: tuning for PPC745x but altivec disabled !"; - fi - TUNECPU=ppc7450 - ;; - 74*|ppc74*|PowerPC74*) - CFLAGS="$CFLAGS -mcpu=7400 -mtune=7400 -mpowerpc-gfxopt" - if test $altivec = "no"; then - echo "WARNING: tuning for PPC74xx but altivec disabled !"; - fi - TUNECPU=ppc7400 - ;; - G5|g5|970|ppc970|PowerPC970|power4*|Power4*) - CFLAGS="$CFLAGS -mcpu=970 -mtune=970 -mpowerpc-gfxopt -mpowerpc64" - if test $altivec = "no"; then - echo "WARNING: tuning for PPC970 but altivec disabled !"; - fi - TUNECPU=ppc970 + 601|ppc601|PowerPC601) + CFLAGS="$CFLAGS -mcpu=601" + if test $altivec = "yes"; then + echo "WARNING: Tuning for PPC601 but AltiVec enabled!"; + fi + TUNECPU=ppc601 + ;; + 603*|ppc603*|PowerPC603*) + CFLAGS="$CFLAGS -mcpu=603" + if test $altivec = "yes"; then + echo "WARNING: Tuning for PPC603 but AltiVec enabled!"; + fi + TUNECPU=ppc603 + ;; + 604*|ppc604*|PowerPC604*) + CFLAGS="$CFLAGS -mcpu=604" + if test $altivec = "yes"; then + echo "WARNING: Tuning for PPC604 but AltiVec enabled!"; + fi + TUNECPU=ppc604 + ;; + G3|g3|75*|ppc75*|PowerPC75*) + CFLAGS="$CFLAGS -mcpu=750 -mtune=750 -mpowerpc-gfxopt" + if test $altivec = "yes"; then + echo "WARNING: Tuning for PPC75x but AltiVec enabled!"; + fi + TUNECPU=ppc750 + ;; + G4|g4|745*|ppc745*|PowerPC745*) + CFLAGS="$CFLAGS -mcpu=7450 -mtune=7450 -mpowerpc-gfxopt" + if test $altivec = "no"; then + echo "WARNING: Tuning for PPC745x but AltiVec disabled!"; + fi + TUNECPU=ppc7450 + ;; + 74*|ppc74*|PowerPC74*) + CFLAGS="$CFLAGS -mcpu=7400 -mtune=7400 -mpowerpc-gfxopt" + if test $altivec = "no"; then + echo "WARNING: Tuning for PPC74xx but AltiVec disabled!"; + fi + TUNECPU=ppc7400 + ;; + G5|g5|970|ppc970|PowerPC970|power4*|Power4*) + CFLAGS="$CFLAGS -mcpu=970 -mtune=970 -mpowerpc-gfxopt -mpowerpc64" + if test $altivec = "no"; then + echo "WARNING: Tuning for PPC970 but AltiVec disabled!"; + fi + TUNECPU=ppc970 POWERPCMODE="64bits" - ;; - i[3456]86|pentium|pentiumpro|pentium-mmx|pentium[234]|prescott|k6|k6-[23]|athlon|athlon-tbird|athlon-4|athlon-[mx]p|winchip-c6|winchip2|c3|nocona) - CFLAGS="$CFLAGS -march=$tune" - ;; - *) - echo "WARNING: unknown CPU \"$tune\", ignored" - ;; + ;; + i[3456]86|pentium|pentiumpro|pentium-mmx|pentium[234]|prescott|k6|k6-[23]|athlon|athlon-tbird|athlon-4|athlon-[mx]p|winchip-c6|winchip2|c3|nocona|athlon64|k8|opteron|athlon-fx) + CFLAGS="$CFLAGS -march=$tune" + ;; + *) + echo "WARNING: Unknown CPU \"$tune\", ignored." + ;; esac fi -# AltiVec flags: The FSF version of GCC differs from the Apple version +# check for SIMD availability + +# AltiVec flags: The FSF version of GCC differs from the Apple version if test $cpu = "powerpc"; then if test $altivec = "yes"; then if test -n "`$cc -v 2>&1 | grep version | grep Apple`"; then @@ -743,30 +1022,17 @@ if test $cpu = "powerpc"; then fi fi -# See if we have -cat > $TMPC << EOF -#include -int main( void ) { return 0; } -EOF +check_header altivec.h && _altivec_h=yes || _altivec_h=no -_altivec_h="no" -if $cc $CFLAGS -o $TMPE $TMPC 2> /dev/null ; then -_altivec_h="yes" -fi - -# See does our compiler support Motorola AltiVec C API +# check if our compiler supports Motorola AltiVec C API if test $altivec = "yes"; then -if test $_altivec_h = "yes"; then -cat > $TMPC << EOF -#include -int main(void) { - vector signed int v1, v2, v3; - v1 = vec_add(v2,v3); - return 0; -} -EOF -else -cat > $TMPC << EOF + if test $_altivec_h = "yes"; then + inc_altivec_h="#include " + else + inc_altivec_h= + fi + check_cc < /dev/null || altivec="no" -fi -# Can only do mmi on mips +# mmi only available on mips if test $mmi = "default"; then if test $cpu = "mips"; then mmi="yes" @@ -786,25 +1050,60 @@ if test $mmi = "default"; then fi fi -# See does our compiler support mmi -if test $mmi = "yes"; then -cat > $TMPC << EOF +# check if our compiler supports mmi +enabled mmi && check_cc < /dev/null || mmi="no" -fi -if test "$mingw32" = "yes" ; then +# test gcc version to see if vector builtins can be used +# currently only used on i386 for MMX builtins +check_cc -msse < +int main(void) { +#if __GNUC__ > 3 || (__GNUC__ == 3 && __GNUC_MINOR__ >= 2) +return 0; +#else +#error no vector builtins +#endif +} +EOF + +# test for mm3dnow.h +test "$cpu" = "x86_64" && march=k8 || march=athlon +check_cc -march=$march < +int main(void) { +__m64 b1; +b1 = _m_pswapd(b1); +_m_femms(); +return 0; +} +EOF + +if test "$mingw32" = "yes" -o "$mingwce" = "yes"; then + if test "$lshared" = "yes" && test "$lstatic" = "yes" ; then + cat < $TMPC << EOF +# big/little-endian test +if test -z "$cross_prefix" ; then + check_ld < int main(int argc, char ** argv){ - volatile uint32_t i=0x01234567; - return (*((uint8_t*)(&i))) == 0x67; + volatile uint32_t i=0x01234567; + return (*((uint8_t*)(&i))) == 0x67; } EOF - -if $cc -o $TMPE $TMPC 2>/dev/null ; then -$TMPE && bigendian="yes" -else -echo big/little test failed -fi - else - -# if cross compiling, cannot launch a program, so make a static guess -if test "$cpu" = "powerpc" -o "$cpu" = "mips" ; then - bigendian="yes" -fi - + # programs cannot be launched if cross compiling, so make a static guess + if test "$cpu" = "powerpc" -o "$cpu" = "mips" ; then + bigendian="yes" + fi fi # --- # *inttypes.h* test -cat > $TMPC << EOF -#include -int main(int argc, char ** argv){ - return 0; -} -EOF - -$cc -o $TMPE $TMPC 2>/dev/null || inttypes="no" +check_header inttypes.h || inttypes=no # --- # *int_fast* test -cat > $TMPC << EOF +check_cc < int main(int argc, char ** argv){ - volatile uint_fast64_t i=0x01234567; - return 0; + volatile uint_fast64_t i=0x01234567; + return 0; } EOF -$cc -o $TMPE $TMPC 2>/dev/null || emu_fast_int="yes" - # --- # check availability of some header files -cat > $TMPC << EOF -#include -int main( void ) { return 0; } -EOF - _memalign=no _malloc_h=no -if $cc -o $TMPE $TMPC 2> /dev/null ; then -_malloc_h=yes -_memalign=yes -# check for memalign - atmos -cat > $TMPC << EOF -#include -#include -int main ( void ) { -char *string = NULL; -string = memalign(64, sizeof(char)); -return 0; -} -EOF -$cc -o $TMPE $TMPC 2> /dev/null || _memalign=no +if check_header malloc.h; then + _malloc_h=yes + _memalign=yes + check_func memalign || _memalign="no" fi if test "$_memalign" = "no" -a "$mmx" = "yes" -a "$memalignhack" != "yes"; then - echo "error, no memalign() but sse enabled, either disable it or use --enable-memalign-hack" - exit 1 -fi - -cat > $TMPC << EOF -#include -int main( void ) { localtime_r(NULL, NULL); } -EOF - -localtime_r=no -if $cc -o $TMPE $TMPC 2> /dev/null ; then - localtime_r=yes -fi - -if test "$zlib" = "yes"; then -# check for zlib - mmu_man -cat > $TMPC << EOF -#include -int main ( void ) { -if (zlibVersion() != ZLIB_VERSION) - puts("zlib version differs !!!"); - return 1; -return 0; + die "Error, no memalign() but SSE enabled, disable it or use --enable-memalign-hack." +fi + +check_func localtime_r && localtime_r=yes || localtime_r=no +enabled zlib && check_lib zlib.h zlibVersion -lz || zlib="no" +enabled lzo && enabled gpl && check_lib lzo1x.h lzo_version -llzo || lzo="no" + +# check for some common methods of building with pthread support +# do this before the optional library checks as some of them require pthreads +if enabled pthreads; then + { check_cflags -pthread && check_ldflags -pthread; } || + { check_cflags -pthreads && check_ldflags -pthreads; } || + check_lib pthread.h pthread_create -lpthread || + check_func pthread_create || + die "ERROR: can't find pthreads library" +fi + +# these are off by default, so fail if requested and not available +enabled dts && require libdts dts.h dts_init -ldts +enabled libgsm && require libgsm gsm.h gsm_create -lgsm +enabled mp3lame && require LAME lame/lame.h lame_init -lmp3lame +enabled libogg && require libogg ogg/ogg.h ogg_sync_init -logg +enabled vorbis && require libvorbis vorbis/vorbisenc.h vorbis_info_init -lvorbis -lvorbisenc +enabled theora && require libtheora theora/theora.h theora_info_init -ltheora +enabled faad && require libfaad faad.h faacDecOpen -lfaad +enabled xvid && require XviD xvid.h xvid_global -lxvidcore +enabled x264 && require x264 x264.h x264_encoder_open -lx264 +enabled dc1394 && require libdc1394 libdc1394/dc1394_control.h dc1394_create_handle -ldc1394_control -lraw1394 +enabled sunmlib && require mediaLib mlib_types.h mlib_VectorSub_S16_U8_Mod -lmlib + +# Ugh, faac uses stdcall calling convention on win32 so we can't use +# the generic test functions +if enabled faac; then + save_flags + temp_extralibs -lfaac + check_ld < +#include +int main(){ + char *id, *cpr; + faacEncGetVersion(&id, &cpr); + return 0; } EOF -$cc $CFLAGS $LDFLAGS -o $TMPE $TMPC -lz 2> /dev/null || zlib="no" -# $TMPE 2> /dev/null > /dev/null || zlib="no" -# XXX: more tests needed - runtime test -fi -if test "$zlib" = "yes"; then -extralibs="$extralibs -lz" + restore_flags fi # test for lrintf in math.h -cat > $TMPC << EOF +check_exec < int main( void ) { return (lrintf(3.999f) > 0)?0:1; } EOF -have_lrintf="no" -if $cc $extralibs -o $TMPE $TMPC 2> /dev/null ; then - have_lrintf="yes" - # allanc@chickenandporn.com: cannot execute cross-compiled - # code on the host. Only execute if not cross-compiling. - if test -z "$cross_prefix" ; then - $TMPE 2> /dev/null > /dev/null || have_lrintf="no" - fi -fi - _restrict= for restrict_keyword in restrict __restrict__ __restrict; do - echo "void foo(char * $restrict_keyword p);" > $TMPC - if $cc -c -o $TMPO $TMPC 2> /dev/null; then - _restrict=$restrict_keyword - break; - fi -done - -# test gcc version to see if vector builtins can be used -# currently only used on i386 for MMX builtins -cat > $TMPC << EOF -#include -int main(void) { -#if __GNUC__ > 3 || (__GNUC__ == 3 && __GNUC_MINOR__ >= 2) -return 0; -#else -#error no vector builtins -#endif -} + check_cc < /dev/null ; then - builtin_vector=yes -fi +done # dlopen/dlfcn.h probing -cat > $TMPC << EOF -#include -int main( void ) { return (int) dlopen("foo", 0); } -EOF - -ldl=-ldl - -if $cc -o $TMPE $TMPC -ldl > /dev/null 2>&1 ; then -dlfcn=yes -dlopen=yes -fi +check_header dlfcn.h && dlfcn=yes -if $cc -o $TMPE $TMPC > /dev/null 2>&1 ; then -dlfcn=yes -dlopen=yes -ldl="" +temp_extralibs -ldl +if check_func dlopen; then + dlopen=yes + ldl=-ldl fi +restore_flags -cat > $TMPC << EOF -int main( void ) { return (int) dlopen("foo", 0); } -EOF - -if $cc -o $TMPE $TMPC -ldl > /dev/null 2>&1 ; then -dlopen=yes +if check_func dlopen; then + dlopen=yes + ldl= fi -if $cc -o $TMPE $TMPC > /dev/null 2>&1 ; then -dlopen=yes -ldl="" -fi - -if test "$vhook" = "default" ; then - vhook="$dlopen" +if test "$vhook" = "default"; then + vhook="$dlopen" fi if test "$vhook" = "yes" -o "$a52bin" = "yes" -o "$faadbin" = "yes"; then - extralibs="$extralibs $ldl" + add_extralibs $ldl fi ########################################## -# imlib probe +# imlib check -cat > $TMPC << EOF +temp_extralibs -lImlib2 +check_ld < #include int main( void ) { return (int) imlib_load_font("foo"); } EOF - -imlib2=no -if $cc $CFLAGS $LDFLAGS -o $TMPE $TMPC -lImlib2 -lm > /dev/null 2>&1 ; then -imlib2=yes -fi +restore_flags ########################################## -# freetype probe +# FreeType check -cat > $TMPC << EOF +freetype2=no +if test "x$targetos" != "xBeOS"; then + if (freetype-config --version) >/dev/null 2>&1 ; then + temp_cflags `freetype-config --cflags` + temp_extralibs `freetype-config --libs` + check_ld < int main( void ) { return (int) FT_Init_FreeType(0); } EOF - -freetype2=no -if test "x$targetos" != "xBeOS" && test "$os2" != "yes"; then - if (freetype-config --version) >/dev/null 2>&1 ; then - if $cc -o $TMPE $TMPC `freetype-config --cflags` `freetype-config --libs` > /dev/null 2>&1 ; then - freetype2=yes - fi + restore_flags fi fi ########################################## -# SDL probe +# SDL check -cat > $TMPC << EOF +sdl_too_old=no +sdl=no +SDL_CONFIG="${cross_prefix}sdl-config" +if ("${SDL_CONFIG}" --version) >/dev/null 2>&1 ; then + temp_cflags `"${SDL_CONFIG}" --cflags` + temp_extralibs `"${SDL_CONFIG}" --libs` + check_ld < #undef main /* We don't want SDL to override our main() */ int main( void ) { return SDL_Init (SDL_INIT_VIDEO); } EOF - -sdl_too_old=no -sdl=no -if (sdl-config --version) >/dev/null 2>&1 ; then -if $cc -o $TMPE `sdl-config --cflags` $TMPC `sdl-config --libs` > /dev/null 2>&1 ; then -_sdlversion=`sdl-config --version | sed 's/[^0-9]//g'` -if test "$_sdlversion" -lt 121 ; then -sdl_too_old=yes -else -sdl=yes -fi -fi + if test $? = 0; then + _sdlversion=`"${SDL_CONFIG}" --version | sed 's/[^0-9]//g'` + if test "$_sdlversion" -lt 121 ; then + sdl_too_old=yes + else + sdl=yes + check_cc < +int main(void){ + const SDL_VideoInfo *vi = SDL_GetVideoInfo(); + int w = vi->current_w; + return 0; +} +EOF + fi + fi + restore_flags fi +enabled sdl || ffplay=no + ########################################## -# texi2html probe +# texi2html check texi2html=no if (texi2html -version) >/dev/null 2>&1; then texi2html=yes fi -if test "$network" = "yes" ; then ########################################## -# IPv6 probe +# IPv6 check -cat > $TMPC << EOF +enabled network && check_ld < #include #include @@ -1088,121 +1323,123 @@ int main( void ) { struct ipv6_mreq mreq6; getaddrinfo(0,0,0,0); getnameinfo(0,0,0,0,0,0,0); - IN6_IS_ADDR_MULTICAST(0); + IN6_IS_ADDR_MULTICAST((const struct in6_addr *)0); } EOF -ipv6=no -if $cc -o $TMPE $TMPC > /dev/null 2>&1 ; then -ipv6=yes -fi -fi +# check for video4linux2 --- V4L2_PIX_FMT_YUV420 +enabled v4l2 && check_cc < +#include +#include +int dummy = V4L2_PIX_FMT_YUV420; +struct v4l2_buffer dummy1; +EOF -case "`$cc -v 2>&1 | grep version`" in - *gcc*) - CFLAGS="-Wall -Wno-switch $CFLAGS" - ;; - *) - ;; -esac +enabled debug && add_cflags -g -if test "$sdl" = "no" ; then - ffplay=no -fi +# add some useful compiler flags if supported +check_cflags -Wdeclaration-after-statement +check_cflags -Wall +check_cflags -Wno-switch -if test "$debug" = "yes"; then - CFLAGS="-g $CFLAGS" -fi +# add some linker flags +check_ldflags '-Wl,--as-needed' '-Wl,-rpath-link,\$(BUILD_ROOT)/libavcodec' '-Wl,-rpath-link,\$(BUILD_ROOT)/libavformat' '-Wl,-rpath-link,\$(BUILD_ROOT)/libavutil' -if test "$optimize" = "small"; then -# CFLAGS=${CFLAGS//-O3/-Os} - CFLAGS="$CFLAGS -Os" -fi +# not all compilers support -Os +test "$optimize" = "small" && check_cflags -Os -if test "$optimize" = "yes"; then +if enabled optimize; then if test -n "`$cc -v 2>&1 | grep xlc`"; then - CFLAGS="$CFLAGS -O5" - LDFLAGS="$LDFLAGS -O5" + CFLAGS="$CFLAGS -O5" + LDFLAGS="$LDFLAGS -O5" else - CFLAGS="-O3 $CFLAGS" + CFLAGS="-O3 $CFLAGS" fi fi # PIC flags for shared library objects where they are needed if test "$lshared" = "yes" ; then - # LIBOBJFLAGS may have already been set in the OS configuration - if test -z "$LIBOBJFLAGS" ; then - if test "$cpu" = "x86_64" -o "$cpu" = "ia64" ; then - LIBOBJFLAGS="\$(PIC)" + # LIBOBJFLAGS may have already been set in the OS configuration + if test -z "$LIBOBJFLAGS" ; then + if test "$cpu" = "x86_64" -o "$cpu" = "ia64" -o "$cpu" = "alpha" ; then + LIBOBJFLAGS="\$(PIC)" + fi fi - fi fi if test x"$bindir" = x""; then -bindir="${prefix}/bin" + bindir="${prefix}/bin" fi if test x"$libdir" = x""; then -libdir="${prefix}/lib" + libdir="${prefix}/lib" +fi + +if test x"$incdir" = x""; then + incdir="${prefix}/include/ffmpeg" fi if test x"$mandir" = x""; then -mandir="${prefix}/man" + mandir="${prefix}/man" fi -echo "Install prefix $prefix" -echo "Source path $source_path" +echo "install prefix $prefix" +echo "source path $source_path" echo "C compiler $cc" echo "make $make" echo "CPU $cpu ($tune)" if test "$BUILDSUF" != ""; then -echo "Build suffix $BUILDSUF" + echo "build suffix $BUILDSUF" fi -echo "Big Endian $bigendian" +echo "big-endian $bigendian" echo "inttypes.h $inttypes" echo "broken inttypes.h $emu_fast_int" if test $cpu = "x86" -o $cpu = "x86_64"; then -echo "MMX enabled $mmx" -echo "Vector Builtins $builtin_vector" + echo "MMX enabled $mmx" + echo "Vector Builtins $builtin_vector" + echo "3DNow! Builtins $mm3dnow" fi if test $cpu = "armv4l"; then -echo "IWMMXT enabled $iwmmxt" + echo "IWMMXT enabled $iwmmxt" fi if test $cpu = "mips"; then -echo "MMI enabled $mmi" + echo "MMI enabled $mmi" fi if test $cpu = "powerpc"; then -echo "AltiVec enabled $altivec" + echo "AltiVec enabled $altivec" fi echo "gprof enabled $gprof" echo "zlib enabled $zlib" +echo "lzo enabled $lzo" echo "libgsm enabled $libgsm" echo "mp3lame enabled $mp3lame" echo "libogg enabled $libogg" -echo "vorbis enabled $vorbis" -echo "theora enabled $theora" -echo "faad enabled $faad" +echo "Vorbis enabled $vorbis" +echo "Theora enabled $theora" +echo "FAAD enabled $faad" echo "faadbin enabled $faadbin" -echo "faac enabled $faac" -echo "xvid enabled $xvid" +echo "FAAC enabled $faac" +echo "XviD enabled $xvid" echo "x264 enabled $x264" echo "a52 support $a52" echo "a52 dlopened $a52bin" -echo "dts support $dts" +echo "DTS support $dts" echo "pp support $pp" echo "debug symbols $debug" echo "strip symbols $dostrip" echo "optimize $optimize" -echo "shared pp $shared_pp" -echo "Video hooking $vhook" +echo "static $lstatic" +echo "shared $lshared" +echo "video hooking $vhook" echo "SDL support $sdl" if test $sdl_too_old = "yes"; then -echo "-> Your SDL version is too old - please upgrade to have FFplay/SDL support" + echo "-> Your SDL version is too old - please upgrade to have FFplay/SDL support." fi -if test "$vhook" = "yes" ; then -echo "Imlib2 support $imlib2" -echo "freetype support $freetype2" +if test "$vhook" = "yes"; then + echo "Imlib2 support $imlib2" + echo "FreeType support $freetype2" fi echo "Sun medialib support" $sunmlib echo "pthreads support" $pthreads @@ -1212,44 +1449,43 @@ echo "AMR-WB float support" $amr_wb echo "AMR-WB IF2 support" $amr_if2 echo "network support $network" if test "$network" = "yes" ; then -echo "IPv6 support $ipv6" + echo "IPv6 support $ipv6" fi if test "$gpl" = "no" ; then -echo "License: LGPL" + echo "License: LGPL" else -echo "License: GPL" + echo "License: GPL" fi -echo "Creating config.mak and config.h" +echo "Creating config.mak and config.h..." date >> config.log echo " $0 $FFMPEG_CONFIGURATION" >> config.log -echo "# Automatically generated by configure - do not modify" > config.mak -echo "/* Automatically generated by configure - do not modify */" > $TMPH +echo "# Automatically generated by configure - do not modify!" > config.mak +echo "/* Automatically generated by configure - do not modify! */" > $TMPH echo "#define FFMPEG_CONFIGURATION "'"'"$FFMPEG_CONFIGURATION"'"' >> $TMPH -echo "prefix=$prefix" >> config.mak -echo "libdir=$libdir" >> config.mak -echo "bindir=$bindir" >> config.mak -echo "mandir=$mandir" >> config.mak +echo "prefix=\$(DESTDIR)$prefix" >> config.mak +echo "libdir=\$(DESTDIR)$libdir" >> config.mak +echo "incdir=\$(DESTDIR)$incdir" >> config.mak +echo "bindir=\$(DESTDIR)$bindir" >> config.mak +echo "mandir=\$(DESTDIR)$mandir" >> config.mak echo "MAKE=$make" >> config.mak echo "CC=$cc" >> config.mak echo "AR=$ar" >> config.mak echo "RANLIB=$ranlib" >> config.mak if test "$dostrip" = "yes" ; then -echo "STRIP=$strip" >> config.mak -echo "INSTALLSTRIP=-s" >> config.mak + echo "STRIP=$strip" >> config.mak + echo "INSTALLSTRIP=$installstrip" >> config.mak else -echo "STRIP=echo ignoring strip" >> config.mak -echo "INSTALLSTRIP=" >> config.mak + echo "STRIP=echo ignoring strip" >> config.mak + echo "INSTALLSTRIP=" >> config.mak fi -# SHCFLAGS is a copy of CFLAGS without -mdynamic-no-pic. Used when building +# SHCFLAGS is a copy of CFLAGS without -mdynamic-no-pic, used when building # shared modules on OS/X (vhook/Makefile). -SHCFLAGS=$CFLAGS -if test "$needmdynamicnopic" = yes; then - CFLAGS="$CFLAGS -mdynamic-no-pic" -fi +SHCFLAGS="$CFLAGS" +test "$needmdynamicnopic" = yes && add_cflags -mdynamic-no-pic echo "OPTFLAGS=$CFLAGS" >> config.mak echo "SHCFLAGS=$SHCFLAGS">>config.mak @@ -1258,9 +1494,15 @@ echo "LDCONFIG=$LDCONFIG" >> config.mak echo "FFSLDFLAGS=$FFSLDFLAGS" >> config.mak echo "SHFLAGS=$SHFLAGS" >> config.mak echo "LIBOBJFLAGS=$LIBOBJFLAGS" >> config.mak +echo "BUILD_STATIC=$lstatic" >> config.mak echo "BUILDSUF=$BUILDSUF" >> config.mak echo "LIBPREF=$LIBPREF" >> config.mak echo "LIBSUF=\${BUILDSUF}$LIBSUF" >> config.mak +if test "$lstatic" = "yes" ; then + echo "LIB=$LIB" >> config.mak +else # Some Make complain if this variable does not exist. + echo "LIB=" >> config.mak +fi echo "SLIBPREF=$SLIBPREF" >> config.mak echo "SLIBSUF=\${BUILDSUF}$SLIBSUF" >> config.mak echo "EXESUF=\${BUILDSUF}$EXESUF" >> config.mak @@ -1302,6 +1544,18 @@ elif test "$cpu" = "mips" ; then elif test "$cpu" = "sh4" ; then echo "TARGET_ARCH_SH4=yes" >> config.mak echo "#define ARCH_SH4 1" >> $TMPH +elif test "$cpu" = "parisc" ; then + echo "TARGET_ARCH_PARISC=yes" >> config.mak + echo "#define ARCH_PARISC 1" >> $TMPH +elif test "$cpu" = "s390" ; then + echo "TARGET_ARCH_S390=yes" >> config.mak + echo "#define ARCH_S390 1" >> $TMPH +elif test "$cpu" = "m68k" ; then + echo "TARGET_ARCH_M68K=yes" >> config.mak + echo "#define ARCH_M68K 1" >> $TMPH +elif test "$cpu" = "ia64" ; then + echo "TARGET_ARCH_IA64=yes" >> config.mak + echo "#define ARCH_IA64 1" >> $TMPH fi echo "#define TUNECPU $TUNECPU" >> $TMPH if test "$bigendian" = "yes" ; then @@ -1323,6 +1577,10 @@ if test "$builtin_vector" = "yes" ; then echo "TARGET_BUILTIN_VECTOR=yes" >> config.mak echo "#define HAVE_BUILTIN_VECTOR 1" >> $TMPH fi +if test "$mm3dnow" = "yes" ; then + echo "TARGET_BUILTIN_3DNOW=yes" >> config.mak + echo "#define HAVE_MM3DNOW 1" >> $TMPH +fi if test "$iwmmxt" = "yes" ; then echo "TARGET_IWMMXT=yes" >> config.mak echo "#define HAVE_IWMMXT 1" >> $TMPH @@ -1358,20 +1616,19 @@ fi if test "$sunmlib" = "yes" ; then echo "HAVE_MLIB=yes" >> config.mak echo "#define HAVE_MLIB 1" >> $TMPH - extralibs="$extralibs -lmlib" fi if test "$pthreads" = "yes" ; then echo "HAVE_PTHREADS=yes" >> config.mak echo "#define HAVE_PTHREADS 1" >> $TMPH echo "#define HAVE_THREADS 1" >> $TMPH - if test $targetos != FreeBSD -a $targetos != OpenBSD ; then - extralibs="$extralibs -lpthread" - fi fi if test "$sdl" = "yes" ; then echo "CONFIG_SDL=yes" >> config.mak - echo "SDL_LIBS=`sdl-config --libs`" >> config.mak - echo "SDL_CFLAGS=`sdl-config --cflags`" >> config.mak + echo "SDL_LIBS=`"${SDL_CONFIG}" --libs`" >> config.mak + echo "SDL_CFLAGS=`"${SDL_CONFIG}" --cflags`" >> config.mak + if test "$sdl_video_size" = "yes"; then + echo "#define HAVE_SDL_VIDEO_SIZE 1" >> $TMPH + fi fi if test "$texi2html" = "yes"; then echo "BUILD_DOC=yes" >> config.mak @@ -1383,22 +1640,52 @@ if test "$vhook" = "yes" ; then echo "BUILD_VHOOK=yes" >> config.mak echo "#define HAVE_VHOOK 1" >> $TMPH fi + +pp_version=`grep '#define LIBPOSTPROC_VERSION ' "$source_path/libpostproc/postprocess.h" | sed 's/[^0-9\.]//g'` +lavc_version=`grep '#define LIBAVCODEC_VERSION ' "$source_path/libavcodec/avcodec.h" | sed 's/[^0-9\.]//g'` +lavf_version=`grep '#define LIBAVFORMAT_VERSION ' "$source_path/libavformat/avformat.h" | sed 's/[^0-9\.]//g'` +lavu_version=`grep '#define LIBAVUTIL_VERSION ' "$source_path/libavutil/avutil.h" | sed 's/[^0-9\.]//g'` + + + if test "$lshared" = "yes" ; then + echo "#define BUILD_SHARED_AV 1" >> $TMPH echo "BUILD_SHARED=yes" >> config.mak echo "PIC=-fPIC -DPIC" >> config.mak + echo "SPPMAJOR=${lavc_version%%.*}" >> config.mak + echo "SPPVERSION=$lavc_version" >> config.mak + echo "LAVCMAJOR=${lavc_version%%.*}" >> config.mak + echo "LAVCVERSION=$lavc_version" >> config.mak + echo "LAVFMAJOR=${lavf_version%%.*}" >> config.mak + echo "LAVFVERSION=$lavf_version" >> config.mak + echo "LAVUMAJOR=${lavu_version%%.*}" >> config.mak + echo "LAVUVERSION=$lavu_version" >> config.mak + echo "SLIBNAME=${SLIBNAME}" >> config.mak + echo "SLIBNAME_WITH_VERSION=${SLIBNAME_WITH_VERSION}" >> config.mak + echo "SLIBNAME_WITH_MAJOR=${SLIBNAME_WITH_MAJOR}" >> config.mak fi echo "EXTRALIBS=$extralibs" >> config.mak -version=`grep '#define FFMPEG_VERSION ' "$source_path/libavcodec/avcodec.h" | - cut -d '"' -f 2` -echo "VERSION=$version" >>config.mak -# if you do not want to use encoders, disable that. + +# If you do not want to use encoders, disable them. echo "#define CONFIG_ENCODERS 1" >> $TMPH echo "CONFIG_ENCODERS=yes" >> config.mak -# if you do not want to use decoders, disable that. +# If you do not want to use decoders, disable them. echo "#define CONFIG_DECODERS 1" >> $TMPH echo "CONFIG_DECODERS=yes" >> config.mak +# muxers +if test "$muxers" = "yes" ; then + echo "#define CONFIG_MUXERS 1" >> $TMPH + echo "CONFIG_MUXERS=yes" >> config.mak +fi + +# demuxers +if test "$demuxers" = "yes" ; then + echo "#define CONFIG_DEMUXERS 1" >> $TMPH + echo "CONFIG_DEMUXERS=yes" >> config.mak +fi + # AC3 if test "$a52" = "yes" ; then echo "#define CONFIG_AC3 1" >> $TMPH @@ -1420,14 +1707,9 @@ fi if test "$pp" = "yes" ; then echo "#define CONFIG_PP 1" >> $TMPH echo "CONFIG_PP=yes" >> config.mak - - if test "$shared_pp" = "yes" ; then - echo "#define SHARED_PP 1" >> $TMPH - echo "SHARED_PP=yes" >> config.mak - fi fi -# mpeg audio high precision mode +# MPEG audio high precision mode if test "$mpegaudio_hp" = "yes" ; then echo "#define CONFIG_MPEGAUDIO_HP 1" >> $TMPH fi @@ -1437,6 +1719,11 @@ if test "$v4l" = "yes" ; then echo "CONFIG_VIDEO4LINUX=yes" >> config.mak fi +if test "$v4l2" = "yes" ; then + echo "#define CONFIG_VIDEO4LINUX2 1" >> $TMPH + echo "CONFIG_VIDEO4LINUX2=yes" >> config.mak +fi + if test "$bktr" = "yes" ; then echo "#define CONFIG_BKTR 1" >> $TMPH echo "CONFIG_BKTR=yes" >> config.mak @@ -1484,6 +1771,11 @@ if test "$zlib" = "yes" ; then echo "CONFIG_ZLIB=yes" >> config.mak fi +if test "$lzo" = "yes" ; then + echo "#define CONFIG_LZO 1" >> $TMPH + echo "CONFIG_LZO=yes" >> config.mak +fi + if test "$libgsm" = "yes" ; then echo "#define CONFIG_LIBGSM 1" >> $TMPH echo "CONFIG_LIBGSM=yes" >> config.mak @@ -1545,9 +1837,22 @@ if test "$mingw32" = "yes" ; then echo "#endif" >> $TMPH fi +if test "$mingwce" = "yes" ; then + echo "#define CONFIG_WIN32 1" >> $TMPH + echo "CONFIG_WIN32=yes" >> config.mak + echo "#define CONFIG_WINCE 1" >> $TMPH + echo "CONFIG_WINCE=yes" >> config.mak + echo "#ifndef __MINGW32__" >> $TMPH + echo "#define __MINGW32__ 1" >> $TMPH + echo "#endif" >> $TMPH +fi + if test "$os2" = "yes" ; then echo "#define CONFIG_OS2 1" >> $TMPH echo "CONFIG_OS2=yes" >> config.mak + echo "HAVE_OS2THREADS=yes" >> config.mak + echo "#define HAVE_OS2THREADS 1" >> $TMPH + echo "#define HAVE_THREADS 1" >> $TMPH fi if test "$TARGET_OS" = "SunOS" ; then @@ -1595,6 +1900,11 @@ if test "$simpleidct" = "yes" ; then echo "#define SIMPLE_IDCT 1" >> $TMPH fi +if test "$protocols" = "yes" ; then + echo "#define CONFIG_PROTOCOLS 1" >> $TMPH + echo "CONFIG_PROTOCOLS=yes" >> config.mak +fi + if test "$ffserver" = "yes" ; then echo "#define CONFIG_FFSERVER 1" >> $TMPH echo "CONFIG_FFSERVER=yes" >> config.mak @@ -1617,21 +1927,46 @@ fi # build tree in object directory if source path is different from current one if test "$source_path_used" = "yes" ; then - DIRS="doc libavformat libavcodec libavcodec/alpha libavcodec/armv4l \ - libavcodec/i386 libavcodec/sparc libavcodec/mlib \ - libavcodec/ppc libavcodec/liba52 libavcodec/libpostproc tests vhook" - FILES="Makefile libavformat/Makefile libavcodec/Makefile \ - libavcodec/libpostproc/Makefile tests/Makefile vhook/Makefile \ - doc/Makefile doc/texi2pod.pl" + DIRS="\ + doc \ + libavformat \ + libavcodec \ + libavcodec/alpha \ + libavcodec/armv4l \ + libavcodec/i386 \ + libavcodec/sparc \ + libavcodec/mlib \ + libavcodec/ppc \ + libavcodec/liba52 \ + libpostproc \ + libavutil \ + tests \ + vhook \ + " + FILES="\ + Makefile \ + libavformat/Makefile \ + libavcodec/Makefile \ + libpostproc/Makefile \ + libavutil/Makefile \ + tests/Makefile \ + vhook/Makefile \ + doc/Makefile \ + doc/texi2pod.pl \ + " for dir in $DIRS ; do mkdir -p $dir done for f in $FILES ; do ln -sf "$source_path/$f" $f done - echo "SRC_PATH=$source_path" >> config.mak -else - echo "SRC_PATH='$source_path'" >> config.mak +fi +echo "SRC_PATH=$source_path" >> config.mak +echo "BUILD_ROOT=$PWD" >> config.mak + +if test "$amr" = "yes" ; then + echo "#define AMR 1" >> $TMPH + echo "AMR=yes" >> config.mak fi if test "$amr_wb" = "yes" ; then @@ -1642,64 +1977,53 @@ if test "$amr_wb" = "yes" ; then echo "V5.1.0 from " echo "http://www.3gpp.org/ftp/Specs/archive/26_series/26.204/26204-510.zip" echo "and extracted the source to libavcodec/amrwb_float" - echo fi if test "$amr_nb" = "yes" ; then echo "#define AMR_NB 1" >> $TMPH echo "AMR_NB=yes" >> config.mak echo + echo "AMR NB FLOAT NOTICE ! Make sure you have downloaded TS26.104" + echo "REL-5 V5.1.0 from " + echo "http://www.3gpp.org/ftp/Specs/archive/26_series/26.104/26104-510.zip" + echo "and extracted the source to libavcodec/amr_float" + echo "If you try this on alpha, you may need to change Word32 to int in amr/typedef.h" +fi + if test "$amr_nb_fixed" = "yes" ; then - echo "AMR_NB_FIXED=yes" >> config.mak echo "#define AMR_NB_FIXED 1" >> $TMPH + echo "AMR_NB_FIXED=yes" >> config.mak + echo echo "AMR NB FIXED POINT NOTICE! Make sure you have downloaded TS26.073 " echo "REL-5 version 5.1.0 from " - echo "http://www.3gpp.org/ftp/Specs/latest/Rel-5/26_series/26073-5??.zip" + echo "http://www.3gpp.org/ftp/Specs/archive/26_series/26.073/26073-510.zip" echo "and extracted src to libavcodec/amr" echo "You must also add -DMMS_IO and remove -pedantic-errors to/from CFLAGS in libavcodec/amr/makefile." echo "i.e. CFLAGS = -Wall -I. \$(CFLAGS_\$(MODE)) -D\$(VAD) -DMMS_IO" - echo -else - echo "AMR NB FLOAT NOTICE ! Make sure you have downloaded TS26.104" - echo "REL-5 V5.1.0 from " - echo "http://www.3gpp.org/ftp/Specs/latest/Rel-5/26_series/26104-5??.zip" - echo "and extracted the source to libavcodec/amr_float" - echo "and if u try this on an alpha, u may need to change Word32 to int in amr/typedef.h" - echo fi if test "$amr_if2" = "yes" ; then echo "AMR_CFLAGS=-DIF2=1" >> config.mak fi -fi for codec in $CODEC_LIST ; do echo "#define CONFIG_`echo $codec | tr a-z A-Z` 1" >> $TMPH echo "CONFIG_`echo $codec | tr a-z A-Z`=yes" >> config.mak done +# Do not overwrite config.h if unchanged to avoid superfluous rebuilds. diff $TMPH config.h >/dev/null 2>&1 -if test $? -ne 0 ; then - mv -f $TMPH config.h +if test "$?" != "0" ; then + mv -f $TMPH config.h else - echo "config.h is unchanged" + echo "config.h is unchanged" fi rm -f $TMPO $TMPC $TMPE $TMPS $TMPH -# build pkg-config files libavcodec.pc, libavformat.pc and libpostproc.pc -lavc_version=`grep '#define LIBAVCODEC_VERSION ' "$source_path/libavcodec/avcodec.h" | sed 's/[^0-9\.]//g'` -lavf_version=`grep '#define LIBAVFORMAT_VERSION ' "$source_path/libavformat/avformat.h" | sed 's/[^0-9\.]//g'` -lavu_version=`grep '#define LIBAVUTIL_VERSION ' "$source_path/libavutil/avutil.h" | sed 's/[^0-9\.]//g'` - -requires= -test "$libogg" = "yes" && requires="$requires ogg >= 1.1" -test "$vorbis" = "yes" && requires="$requires vorbis" -test "$theora" = "yes" && requires="$requires theora" -test "$faad" = "yes" && test "$faadbin" = "no" && extralibs="$extralibs -lfaad" - +# build pkg-config files libav*.pc and libpostproc.pc # libavutil.pc cat <libavutil.pc prefix=$prefix @@ -1710,7 +2034,7 @@ includedir=\${prefix}/include Name: libavutil Description: FFmpeg utility library Version: $lavu_version -Requires: +Requires: Conflicts: Libs: -L\${libdir} -lavutil Cflags: -I\${includedir} -I\${includedir}/ffmpeg @@ -1725,7 +2049,7 @@ includedir=\${pcfiledir}/libavutil Name: libavutil Description: FFmpeg utility library Version: $lavu_version -Requires: +Requires: Conflicts: Libs: \${libdir}/${LIBPREF}avutil${LIBSUF} Cflags: -I\${includedir} @@ -1741,7 +2065,7 @@ includedir=\${prefix}/include Name: libavcodec Description: FFmpeg codec library Version: $lavc_version -Requires: $requires libavutil = $lavu_version +Requires: $pkg_requires libavutil = $lavu_version Conflicts: Libs: -L\${libdir} -lavcodec $extralibs Cflags: -I\${includedir} -I\${includedir}/ffmpeg @@ -1756,7 +2080,7 @@ includedir=\${pcfiledir}/libavcodec Name: libavcodec Description: FFmpeg codec library Version: $lavc_version -Requires: $requires libavutil = $lavu_version +Requires: $pkg_requires libavutil = $lavu_version Conflicts: Libs: \${libdir}/${LIBPREF}avcodec${LIBSUF} $extralibs Cflags: -I\${includedir} @@ -1772,7 +2096,7 @@ includedir=\${prefix}/include Name: libavformat Description: FFmpeg container format library Version: $lavf_version -Requires: $requires libavcodec = $lavc_version +Requires: $pkg_requires libavcodec = $lavc_version Conflicts: Libs: -L\${libdir} -lavformat $extralibs Cflags: -I\${includedir} -I\${includedir}/ffmpeg @@ -1787,7 +2111,7 @@ includedir=\${pcfiledir}/libavformat Name: libavformat Description: FFmpeg container format library Version: $lavf_version -Requires: $requires libavcodec = $lavc_version +Requires: $pkg_requires libavcodec = $lavc_version Conflicts: Libs: \${libdir}/${LIBPREF}avformat${LIBSUF} $extralibs Cflags: -I\${includedir} @@ -1804,7 +2128,7 @@ includedir=\${prefix}/include Name: libpostproc Description: FFmpeg post processing library Version: $lavc_version -Requires: +Requires: Conflicts: Libs: -L\${libdir} -lpostproc Cflags: -I\${includedir} -I\${includedir}/postproc @@ -1813,13 +2137,13 @@ EOF cat <libpostproc-uninstalled.pc prefix= exec_prefix= -libdir=\${pcfiledir}/libavcodec/libpostproc -includedir=\${pcfiledir}/libavcodec/libpostproc +libdir=\${pcfiledir}/libpostproc +includedir=\${pcfiledir}/libpostproc Name: libpostproc Description: FFmpeg post processing library Version: $lavc_version -Requires: +Requires: Conflicts: Libs: \${libdir}/${LIBPREF}postproc${LIBSUF} Cflags: -I\${includedir}