X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=configure;h=430edbdc0c215bc50c7eb0a797a3d86e05175305;hb=7e14f14584939ec0dc822ae6fa91355f9c307913;hp=f2d30666192f88ee67c9854a5469d75e6da4fea7;hpb=6b19786b1187e0c194be3b9e76091e6f86a6e821;p=ffmpeg diff --git a/configure b/configure index f2d30666192..430edbdc0c2 100755 --- a/configure +++ b/configure @@ -12,14 +12,14 @@ try_exec(){ echo "Trying shell $1" - type "$1" >/dev/null 2>&1 && exec "$@" + type "$1" > /dev/null 2>&1 && exec "$@" } unset foo -(: ${foo%%bar}) 2>/dev/null +(: ${foo%%bar}) 2> /dev/null E1="$?" -(: ${foo?}) 2>/dev/null +(: ${foo?}) 2> /dev/null E2="$?" if test "$E1" != 0 || test "$E2" = 0; then @@ -56,11 +56,13 @@ show_help(){ echo echo "Standard options:" echo " --help print this message" - echo " --log[=FILE|yes|no] log tests and output to FILE [config.err]" - echo " --prefix=PREFIX install in PREFIX [$PREFIX]" + echo " --logfile=FILE log tests and output to FILE [config.err]" + echo " --disable-logging do not log configure debug information" + echo " --prefix=PREFIX install in PREFIX [$prefix]" + echo " --bindir=DIR install binaries in DIR [PREFIX/bin]" echo " --libdir=DIR install libs in DIR [PREFIX/lib]" echo " --shlibdir=DIR install shared libs in DIR [PREFIX/lib]" - echo " --incdir=DIR install includes in DIR [PREFIX/include/ffmpeg]" + echo " --incdir=DIR install includes in DIR [PREFIX/include]" echo " --mandir=DIR install man page in DIR [PREFIX/share/man]" echo " --enable-static build static libraries [default=yes]" echo " --disable-static do not build static libraries [default=no]" @@ -68,15 +70,20 @@ show_help(){ echo " --disable-shared do not build shared libraries [default=yes]" echo " --enable-gpl allow use of GPL code, the resulting libav*" echo " and ffmpeg will be under GPL [default=no]" - echo " --enable-pp enable GPLed postprocessing support [default=no]" - echo " --enable-swscaler software scaler support [default=no]" + echo " --enable-nonfree allow use of nonfree code, the resulting libav*" + echo " and ffmpeg will be unredistributable [default=no]" + echo " --enable-postproc enable GPLed postprocessing support [default=no]" + echo " --enable-swscale software scaler support [default=no]" + echo " --enable-avfilter video filter support (replaces vhook) [default=no]" + echo " --enable-avfilter-lavf video filters dependant on avformat [default=no]" echo " --enable-beosthreads use BeOS threads [default=no]" + echo " --enable-os2threads use OS/2 threads [default=no]" echo " --enable-pthreads use pthreads [default=no]" echo " --enable-w32threads use Win32 threads [default=no]" echo " --enable-x11grab enable X11 grabbing [default=no]" echo echo "External library support:" - echo " --enable-sunmlib use Sun medialib [default=no]" + echo " --enable-mlib use Sun medialib [default=no]" echo " --enable-liba52 enable GPLed liba52 support [default=no]" echo " --enable-liba52bin open liba52.so.0 at runtime [default=no]" echo " --enable-avisynth allow reading AVISynth script files [default=no]" @@ -84,6 +91,7 @@ show_help(){ echo " --enable-libamr-wb enable libamr-wb floating point audio codec" echo " --enable-libdc1394 enable IIDC-1394 grabbing using libdc1394" echo " and libraw1394 [default=no]" + echo " --enable-libdirac enable Dirac support via libdirac [default=no]" echo " --enable-libfaac enable FAAC support via libfaac [default=no]" echo " --enable-libfaad enable FAAD support via libfaad [default=no]" echo " --enable-libfaadbin open libfaad.so.0 at runtime [default=no]" @@ -91,10 +99,10 @@ show_help(){ echo " --enable-libmp3lame enable MP3 encoding via libmp3lame [default=no]" echo " --enable-libnut enable NUT (de)muxing via libnut," echo " native demuxer exists [default=no]" - echo " --enable-libogg enable Ogg muxing via libogg [default=no]" + echo " --enable-libschroedinger enable Dirac support via libschroedinger [default=no]" echo " --enable-libtheora enable Theora encoding via libtheora [default=no]" - echo " --enable-libvorbis enable Vorbis en/decoding via libvorbis," - echo " native implementations exist [default=no]" + echo " --enable-libvorbis enable Vorbis encoding via libvorbis," + echo " native implementation exists [default=no]" echo " --enable-libx264 enable H.264 encoding via x264 [default=no]" echo " --enable-libxvid enable Xvid encoding via xvidcore," echo " native MPEG-4/Xvid encoder exists [default=no]" @@ -102,10 +110,9 @@ show_help(){ 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 " --cross-compile assume a cross-compiler is used" - echo " --target-os=OS compiler targets OS [$targetos]" + echo " --enable-cross-compile assume a cross-compiler is used" + echo " --target-os=OS compiler targets OS [$target_os]" 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]" @@ -116,13 +123,17 @@ show_help(){ echo " --enable-powerpc-perf enable performance report on PPC" echo " (requires enabling PMC)" echo " --disable-mmx disable MMX usage" + echo " --disable-mmx2 disable MMX2 usage" + echo " --disable-ssse3 disable SSSE3 usage" echo " --disable-armv5te disable armv5te usage" echo " --disable-armv6 disable armv6 usage" + echo " --disable-armvfp disable ARM VFP usage" echo " --disable-iwmmxt disable iwmmxt usage" echo " --disable-altivec disable AltiVec usage" echo " --disable-network disable network support [default=no]" echo " --disable-ipv6 disable ipv6 support [default=no]" echo " --disable-zlib disable zlib [default=no]" + echo " --disable-bzlib disable bzlib [default=no]" echo " --disable-vhook disable video hooking support" echo " --disable-debug disable debugging symbols" echo " --disable-mpegaudio-hp faster (but less accurate)" @@ -132,6 +143,7 @@ show_help(){ echo " --disable-ffserver disable ffserver build" echo " --disable-ffplay disable ffplay build" echo " --enable-small optimize for size instead of speed" + echo " --enable-hardcoded-tables use hardcoded tables instead of runtime generation" echo " --enable-memalign-hack emulate memalign, interferes with memory debuggers" echo " --disable-encoder=NAME disables encoder NAME" echo " --enable-encoder=NAME enables encoder NAME" @@ -154,6 +166,7 @@ show_help(){ echo " --enable-protocol=NAME enables protocol NAME" echo " --disable-protocol=NAME disables protocol NAME" echo " --disable-protocols disables all protocols" + echo " --disable-devices disables all devices" echo " --list-decoders show all available decoders" echo " --list-encoders show all available encoders" echo " --list-muxers show all available muxers" @@ -161,24 +174,26 @@ show_help(){ echo " --list-parsers show all available parsers" echo " --list-protocols show all available protocols" echo " --list-bsfs show all available bitstream filters" + echo " --list-indevs show all available input devices" + echo " --list-outdevs show all available output devices" echo echo "Developer options (useful when working on FFmpeg itself):" echo " --enable-gprof enable profiling with gprof [$gprof]" - echo " --disable-opts disable compiler optimizations" + echo " --disable-optimizations disable compiler optimizations" echo " --enable-extra-warnings enable more compiler warnings" - echo " --disable-strip disable stripping of executables and shared libraries" + echo " --disable-stripping disable stripping of executables and shared libraries" echo "" echo "NOTE: Object files are built at the place where configure is launched." exit 1 } log(){ - echo "$@" >>$logfile + echo "$@" >> $logfile } log_file(){ log BEGIN $1 - cat -n $1 >>$logfile + pr -n -t $1 >> $logfile log END $1 } @@ -192,30 +207,30 @@ die(){ cat </dev/null + (: ${SAVE_CFLAGS?}) 2> /dev/null } save_flags(){ @@ -393,19 +408,19 @@ add_extralibs(){ check_cmd(){ log "$@" - "$@" >>$logfile 2>&1 + "$@" >> $logfile 2>&1 } check_cc(){ log check_cc "$@" - cat >$TMPC + cat > $TMPC log_file $TMPC check_cmd $cc $CFLAGS "$@" -c -o $TMPO $TMPC } check_cpp(){ log check_cpp "$@" - cat >$TMPC + cat > $TMPC log_file $TMPC check_cmd $cc $CFLAGS "$@" -E -o $TMPO $TMPC } @@ -416,9 +431,7 @@ check_asm(){ asm="$2" shift 2 check_cc "$@" <>$logfile 2>&1; } + check_ld "$@" && { enabled cross_compile || $TMPE >> $logfile 2>&1; } } check_exec_crash(){ @@ -531,12 +540,12 @@ check_exec_crash(){ # can redirect the "Terminated" message from the shell. SIGBUS # is not defined by standard C so it is used conditionally. - (check_exec "$@") >>$logfile 2>&1 <> $logfile 2>&1 < static void sighandler(int sig){ raise(SIGTERM); } -int main(){ +int main(void){ signal(SIGILL, sighandler); signal(SIGFPE, sighandler); signal(SIGSEGV, sighandler); @@ -548,6 +557,23 @@ int main(){ EOF } +check_type(){ + log check_type "$@" + headers=$1 + type=$2 + shift 2 + disable $type + incs="" + for hdr in $headers; do + incs="$incs +#include <$hdr>" + done + check_cc "$@" < $logfile +set >> $logfile -# OS specific -case $targetos in - beos|haiku|zeta) - PREFIX="$HOME/config" - # helps building libavcodec - add_cflags "-DPIC -fomit-frame-pointer" - # 3 gcc releases known for BeOS, each with ugly bugs - gcc_version="`$cc -v 2>&1 | grep version | cut -d ' ' -f3-`" - case "$gcc_version" in - 2.9-beos-991026*|2.9-beos-000224*) echo "R5/GG gcc" - disable mmx - ;; - *20010315*) echo "BeBits gcc" - add_cflags "-fno-expensive-optimizations" - ;; - esac - LDCONFIG="echo ignoring ldconfig" - SHFLAGS=-nostart - # enable BeOS things - enable audio_beos - # no need for libm, but the inet stuff - # Check for BONE - # XXX: actually should check for NOT net_server - if (echo $BEINCLUDES|grep 'headers/be/bone' >/dev/null); then - network_extralibs="-lbind -lsocket" - else - enable beos_netserver - network_extralibs="-lnet" - fi ;; - sunos) - FFSERVERLDFLAGS="" - SHFLAGS="-shared -Wl,-h,\$@" - network_extralibs="-lsocket -lnsl" +cc="${cross_prefix}${cc}" +ar="${cross_prefix}${ar}" +nm="${cross_prefix}${nm}" +ranlib="${cross_prefix}${ranlib}" +strip="${cross_prefix}${strip}" + +# set temporary file name +if test ! -z "$TMPDIR" ; then + TMPDIR1="${TMPDIR}" +elif test ! -z "$TEMPDIR" ; then + TMPDIR1="${TEMPDIR}" +else + TMPDIR1="/tmp" +fi + +TMPC="${TMPDIR1}/ffmpeg-conf-${RANDOM}-$$-${RANDOM}.c" +TMPE="${TMPDIR1}/ffmpeg-conf-${RANDOM}-$$-${RANDOM}${EXESUF}" +TMPH="${TMPDIR1}/ffmpeg-conf-${RANDOM}-$$-${RANDOM}.h" +TMPO="${TMPDIR1}/ffmpeg-conf-${RANDOM}-$$-${RANDOM}.o" +TMPS="${TMPDIR1}/ffmpeg-conf-${RANDOM}-$$-${RANDOM}.S" +TMPSH="${TMPDIR1}/ffmpeg-conf-${RANDOM}-$$-${RANDOM}.sh" + +case "$arch" in + i386|i486|i586|i686|i86pc|BePC) + arch="x86_32" + enable fast_unaligned ;; - netbsd) - oss_demuxer_extralibs="-lossaudio" - oss_muxer_extralibs="-lossaudio" + x86_64|amd64) + arch="x86_32" + enable fast_unaligned + check_cc <$logfile - set >>$logfile -else - logfile=/dev/null -fi + *) + target_os="${target_os}-UNKNOWN" + ;; +esac + +add_extralibs $osextralibs # Combine FFLDFLAGS and the LDFLAGS environment variable. LDFLAGS="$FFLDFLAGS $LDFLAGS" test -n "$cross_prefix" && enable cross_compile -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 ! enabled_any static shared; then @@ -1247,14 +1330,7 @@ EOF exit 1; fi -if disabled static; then - LIB="" -fi - -if ! enabled libogg; then - enabled libtheora && die "libogg must be enabled to enable libtheora." - enabled libvorbis && die "libogg must be enabled to enable libvorbis." -fi +disabled static && LIBNAME="" if enabled_any libfaad libfaadbin ; then if check_header faad.h; then @@ -1263,7 +1339,7 @@ if enabled_any libfaad libfaadbin ; then #ifndef FAAD2_VERSION ok faad1 #endif -int main( void ) { return 0; } +int main(void) { return 0; } EOF test $? = 0 && enable libfaad2 else @@ -1278,13 +1354,17 @@ if ! enabled gpl; then shift enabled_any $@ && die "$name is under GPL and --enable-gpl is not specified." } - die_gpl_disabled "The Postprocessing code" pp + die_gpl_disabled "The Postprocessing code" postproc die_gpl_disabled "liba52" liba52 die_gpl_disabled "libx264" libx264 die_gpl_disabled "libxvidcore" libxvid die_gpl_disabled "FAAD2" libfaad2 die_gpl_disabled "The X11 grabber" x11grab - die_gpl_disabled "The software scaler" swscaler + die_gpl_disabled "The software scaler" swscale +fi + +if ! enabled nonfree && enabled_any libamr_nb libamr_wb; then + die "libamr is nonfree and --enable-nonfree is not specified." fi check_deps $ARCH_EXT_LIST @@ -1292,18 +1372,18 @@ check_deps $ARCH_EXT_LIST test -z "$need_memalign" && need_memalign="$mmx" #Darwin CC versions -if test $targetos = darwin; then - if test -n "`$cc -v 2>&1 | grep xlc`"; then +if test $target_os = darwin; then + if $cc -v 2>&1 | grep -q xlc; then add_cflags "-qpdf2 -qlanglvl=extc99 -qmaxmem=-1 -qarch=auto -qtune=auto" else - add_cflags "-no-cpp-precomp -pipe" + add_cflags "-pipe" check_cflags "-force_cpusubtype_ALL" check_cflags "-Wno-sign-compare" - disabled shared && add_cflags -mdynamic-no-pic + enabled shared || check_cflags -mdynamic-no-pic fi fi -disabled optimize || add_cflags -fomit-frame-pointer +disabled optimizations || add_cflags -fomit-frame-pointer # Add processor-specific flags if test $cpu != "generic"; then @@ -1357,7 +1437,7 @@ if test $cpu != "generic"; then enable fast_cmov ;; # targets that do support conditional mov but on which it's slow - pentium4|prescott|nocona) + pentium4|pentium4m|prescott|nocona) add_cflags "-march=$cpu" enable cmov disable fast_cmov @@ -1365,33 +1445,21 @@ if test $cpu != "generic"; then sparc64) add_cflags "-mcpu=v9" ;; - bf*) #bf531 bf532 bf533 bf561 bf5xx all get this config - add_cflags "-mfdpic" - add_ldflags "-mfdpic" - ;; arm*) add_cflags "-mcpu=$cpu" ;; *) - echo "WARNING: Unknown CPU \"$cpu\", ignored." + echo "WARNING: Unknown CPU \"$cpu\", ignored." ;; esac fi -gnu_make(){ - $1 --version 2>&1 | grep -q GNU -} - -if ! gnu_make $make; then - gnu_make gmake && make=gmake || die "GNU make not found." -fi - # make sure we can execute files in $TMPDIR -cat >$TMPE 2>>$logfile < $TMPSH 2>> $logfile <>$logfile 2>&1 -if ! $TMPE >>$logfile 2>&1; then +chmod +x $TMPSH >> $logfile 2>&1 +if ! $TMPSH >> $logfile 2>&1; then cat <&1 | grep version | grep Apple`" && - add_cflags "-faltivec" || - add_cflags "-maltivec -mabi=altivec" - - check_header altivec.h + check_cflags -maltivec -mabi=altivec && + check_header altivec.h || + check_cflags -faltivec # check if our compiler supports Motorola AltiVec C API enabled altivec_h && @@ -1473,8 +1548,11 @@ int main(void) { EOF fi +# We have to check if pld is a nop and disable it. +enabled armv4l && check_asm pld '"pld [r0]"' enabled armv5te && check_asm armv5te '"qadd r0, r0, r0"' enabled armv6 && check_asm armv6 '"sadd16 r0, r0, r0"' +enabled armvfp && check_asm armvfp '"fadds s0, s0, s0"' enabled iwmmxt && check_asm iwmmxt '"wunpckelub wr6, wr4"' enabled mmi && check_asm mmi '"lq $2, 0($2)"' enabled vis && check_asm vis '"pdist %f0, %f0, %f0"' -mcpu=ultrasparc @@ -1486,7 +1564,7 @@ enabled vis && add_cflags "-mcpu=ultrasparc -mtune=ultrasparc" check_cc < -int main( void ) { return (lrintf(3.999f) > 0)?0:1; } +int main(void) { return ($func(3.999f) > 0)?0:1; } EOF - -enabled_any libamr_nb libamr_wb && enable libamr +done # these are off by default, so fail if requested and not available enabled avisynth && require2 vfw32 "windows.h vfw.h" AVIFileInit -lvfw32 -enabled liba52 && require liba52 a52dec/a52.h a52_init -la52 -enabled libamr_nb && require libamrnb amrnb/interf_dec.h Speech_Decode_Frame_init -lamrnb -lm -enabled libamr_wb && require libamrwb amrwb/dec_if.h D_IF_init -lamrwb -lm -enabled libdc1394 && require libdc1394 libdc1394/dc1394_control.h dc1394_create_handle -ldc1394_control -lraw1394 +enabled liba52 && require liba52 a52dec/a52.h a52_init -la52 +enabled libamr_nb && require libamrnb amrnb/interf_dec.h Speech_Decode_Frame_init -lamrnb -lm +enabled libamr_wb && require libamrwb amrwb/dec_if.h D_IF_init -lamrwb -lm +enabled libdirac && add_cflags "$(pkg-config --cflags dirac)" \ + && require libdirac libdirac_decoder/dirac_parser.h dirac_decoder_init -ldirac_decoder \ + && require libdirac libdirac_encoder/dirac_encoder.h dirac_encoder_init -ldirac_encoder enabled libfaac && require2 libfaac "stdint.h faac.h" faacEncGetVersion -lfaac enabled libfaad && require2 libfaad faad.h faacDecOpen -lfaad -enabled libgsm && require libgsm gsm.h gsm_create -lgsm -enabled libmp3lame && require LAME lame/lame.h lame_init -lmp3lame -lm -enabled libnut && require libnut libnut.h nut_demuxer_init -lnut -enabled libogg && require libogg ogg/ogg.h ogg_sync_init -logg -enabled libtheora && require libtheora theora/theora.h theora_info_init -ltheora -logg -enabled libvorbis && require libvorbis vorbis/vorbisenc.h vorbis_info_init -lvorbis -lvorbisenc -logg -enabled libx264 && require x264 x264.h x264_encoder_open -lx264 -enabled libxvid && require Xvid xvid.h xvid_global -lxvidcore -enabled mlib && require mediaLib mlib_types.h mlib_VectorSub_S16_U8_Mod -lmlib +enabled libgsm && require libgsm gsm.h gsm_create -lgsm +enabled libmp3lame && require LAME lame/lame.h lame_init -lmp3lame -lm +enabled libnut && require libnut libnut.h nut_demuxer_init -lnut +enabled libschroedinger && add_cflags $(pkg-config --cflags schroedinger-1.0) \ + && require libschroedinger schroedinger/schro.h schro_init $(pkg-config --libs schroedinger-1.0) +enabled libtheora && require libtheora theora/theora.h theora_info_init -ltheora -logg +enabled libvorbis && require libvorbis vorbis/vorbisenc.h vorbis_info_init -lvorbisenc -lvorbis -logg +enabled libx264 && require x264 x264.h x264_encoder_open -lx264 -lm +enabled libxvid && require Xvid xvid.h xvid_global -lxvidcore +enabled mlib && require mediaLib mlib_types.h mlib_VectorSub_S16_U8_Mod -lmlib # disable the native AC-3 decoder if liba52 is enabled enabled liba52 && disable ac3_decoder +# disable the slower libdirac decoder if libschroedinger is enabled +enabled libschroedinger && enabled libdirac && disable libdirac_decoder + +# libdc1394 check +if enabled libdc1394; then + { check_lib dc1394/dc1394.h dc1394_new -ldc1394 -lraw1394 && + enable libdc1394_2; } || + { check_lib libdc1394/dc1394_control.h dc1394_create_handle -ldc1394_control -lraw1394 && + enable libdc1394_1; } || + die "ERROR: No version of libdc1394 found " +fi + + _restrict= for restrict_keyword in restrict __restrict__ __restrict; do check_cc </dev/null 2>&1; then +if "${SDL_CONFIG}" --version > /dev/null 2>&1; then sdl_cflags=`"${SDL_CONFIG}" --cflags` temp_cflags $sdl_cflags temp_extralibs `"${SDL_CONFIG}" --libs` - if check_lib SDL.h SDL_Init; then + if check_lib2 SDL.h SDL_Init; then _sdlversion=`"${SDL_CONFIG}" --version | sed 's/[^0-9]//g'` if test "$_sdlversion" -lt 121 ; then enable sdl_too_old @@ -1620,7 +1722,7 @@ if "${SDL_CONFIG}" --version >/dev/null 2>&1; then enable sdl check_cc $sdl_cflags < -int main(void){ +int main(int argc, char **argv){ const SDL_VideoInfo *vi = SDL_GetVideoInfo(); int w = vi->current_w; return 0; @@ -1631,7 +1733,9 @@ EOF restore_flags fi -texi2html -version >/dev/null 2>&1 && enable texi2html || disable texi2html +texi2html -version > /dev/null 2>&1 && enable texi2html || disable texi2html + +check_type sys/socket.h socklen_t ########################################## # Network check @@ -1642,6 +1746,7 @@ if enabled network; then check_func closesocket elif check_header winsock2.h ; then network_extralibs="-lws2_32" + check_type ws2tcpip.h socklen_t check_func2 winsock2.h closesocket fi fi @@ -1654,18 +1759,20 @@ enabled network && enabled ipv6 && check_ld < #include #include -int main( void ) { - struct sockaddr_storage saddr; - struct ipv6_mreq mreq6; - getaddrinfo(0,0,0,0); - getnameinfo(0,0,0,0,0,0,0); - IN6_IS_ADDR_MULTICAST((const struct in6_addr *)0); +int main(void) { + struct sockaddr_storage saddr; + struct ipv6_mreq mreq6; + getaddrinfo(0,0,0,0); + getnameinfo(0,0,0,0,0,0,0); + IN6_IS_ADDR_MULTICAST((const struct in6_addr *)0); } EOF check_header linux/videodev.h check_header linux/videodev2.h +check_func2 "windows.h vfw.h" capCreateCaptureWindow -lvfw32 + # check for ioctl_meteor.h, ioctl_bt848.h and alternatives { check_header dev/bktr/ioctl_meteor.h && check_header dev/bktr/ioctl_bt848.h; } || @@ -1678,14 +1785,14 @@ check_header dev/ic/bt8xx.h check_header sys/soundcard.h check_header soundcard.h -# Deal with the x11 frame grabber +# deal with the X11 frame grabber enabled x11grab && check_header X11/Xlib.h && check_header X11/extensions/XShm.h && check_func XOpenDisplay -lX11 && check_func XShmCreateImage -lX11 -lXext -enabled debug && add_cflags -g +enabled debug && add_cflags -g"$debuglevel" # add some useful compiler flags if supported check_cflags -Wdeclaration-after-statement @@ -1695,30 +1802,52 @@ check_cflags -Wdisabled-optimization check_cflags -Wpointer-arith check_cflags -Wredundant-decls check_cflags -Wno-pointer-sign +check_cflags -Wcast-qual +check_cflags -Wwrite-strings +check_cflags -Wtype-limits enabled extra_warnings && check_cflags -Winline # add some linker flags check_ldflags -Wl,--warn-common check_ldflags $LDLATEFLAGS +check_ldflags -Wl,-Bsymbolic if enabled small; then check_cflags -Os # not all compilers support -Os - optimize="small" -elif enabled optimize; then - if test -n "`$cc -v 2>&1 | grep xlc`"; then + optimizations="small" +elif enabled optimizations; then + if $cc -v 2>&1 | grep -q xlc; then add_cflags "-O5" add_ldflags "-O5" else add_cflags "-O3" fi fi +check_cflags -fno-math-errno +check_cflags -fno-signed-zeros + +# add some flags for Intel C Compiler +if $cc --version | grep -q Intel; then + # Just warnings, no remarks + check_cflags -w1 + # -wd: Disable following warnings + # 144, 167, 556: -Wno-pointer-sign + # 10006: ignoring unknown option -fno-signed-zeros + # 10156: ignoring option '-W'; no argument required + check_cflags -wd144,167,556,10006,10156 + # 11030: Warning unknown option --as-needed + # 10156: ignoring option '-export'; no argument required + check_ldflags -wd10156,11030 + # Allow to compile with optimizations + check_ldflags -march=$cpu +fi # PIC flags for shared library objects where they are needed if enabled shared; then # LIBOBJFLAGS may have already been set in the OS configuration if test -z "$LIBOBJFLAGS" ; then case "$arch" in - x86_64|ia64|alpha|sparc*|power*) LIBOBJFLAGS="\$(PIC)" ;; + x86_64|ia64|alpha|sparc*|power*) LIBOBJFLAGS='$(PIC)' ;; esac fi fi @@ -1730,37 +1859,49 @@ fi VHOOKCFLAGS="-fPIC" -# find if .align arg is power-of-two or not +# Find out if the .align argument is a power of two or not. if test $asmalign_pot = "unknown"; then disable asmalign_pot echo 'asm (".align 3");' | check_cc && enable asmalign_pot fi -enabled_any $ENCODER_LIST && enable encoders -enabled_any $DECODER_LIST && enable decoders -enabled_any $MUXER_LIST && enable muxers -enabled_any $DEMUXER_LIST && enable demuxers -enabled_any $PROTOCOL_LIST && enable protocols -enabled_any $BSF_LIST && enable bsfs - -enabled_any $THREADS_LIST && enable threads - -check_deps $CONFIG_LIST $HAVE_LIST $DECODER_LIST $ENCODER_LIST $PARSER_LIST \ - $BSF_LIST $DEMUXER_LIST $MUXER_LIST $PROTOCOL_LIST +enabled_any $DECODER_LIST && enable decoders +enabled_any $ENCODER_LIST && enable encoders +enabled_any $BSF_LIST && enable bsfs +enabled_any $DEMUXER_LIST && enable demuxers +enabled_any $MUXER_LIST && enable muxers +enabled_any $FILTER_LIST && enable filters +enabled_any $INDEV_LIST && enable demuxers +enabled_any $OUTDEV_LIST && enable muxers +enabled_any $PROTOCOL_LIST && enable protocols + +enabled_any $THREADS_LIST && enable threads + +check_deps $CONFIG_LIST \ + $HAVE_LIST \ + $DECODER_LIST \ + $ENCODER_LIST \ + $PARSER_LIST \ + $BSF_LIST \ + $DEMUXER_LIST \ + $MUXER_LIST \ + $FILTER_LIST \ + $INDEV_LIST \ + $OUTDEV_LIST \ + $PROTOCOL_LIST \ enabled libdc1394 && append pkg_requires "libraw1394" -enabled libogg && append pkg_requires "ogg >= 1.1" +enabled libdirac && append pkg_requires "dirac" enabled libtheora && append pkg_requires "theora" -enabled libvorbis && append pkg_requires "vorbis vorbisenc" +enabled libvorbis && append pkg_requires "vorbisenc" -echo "install prefix $PREFIX" +echo "install prefix $prefix" echo "source path $source_path" echo "C compiler $cc" -echo "make $make" echo ".align is power-of-two $asmalign_pot" echo "ARCH $arch ($cpu)" -if test "$BUILDSUF" != ""; then - echo "build suffix $BUILDSUF" +if test "$build_suffix" != ""; then + echo "build suffix $build_suffix" fi echo "big-endian ${bigendian-no}" if test $arch = "x86_32" -o $arch = "x86_64"; then @@ -1773,6 +1914,7 @@ fi if test $arch = "armv4l"; then echo "ARMv5TE enabled ${armv5te-no}" echo "ARMv6 enabled ${armv6-no}" + echo "ARM VFP enabled ${armvfp-no}" echo "IWMMXT enabled ${iwmmxt-no}" fi if test $arch = "mips"; then @@ -1784,12 +1926,14 @@ if test $arch = "powerpc"; then fi echo "gprof enabled ${gprof-no}" echo "debug symbols ${debug-no}" -echo "strip symbols ${dostrip-no}" -echo "optimize ${optimize-no}" +echo "strip symbols ${stripping-no}" +echo "optimizations ${optimizations-no}" echo "static ${static-no}" echo "shared ${shared-no}" -echo "postprocessing support ${pp-no}" -echo "software scaler enabled ${swscaler-no}" +echo "postprocessing support ${postproc-no}" +echo "software scaler enabled ${swscale-no}" +echo "new filter support ${avfilter-no}" +echo "filters using lavformat ${avfilter_lavf-no}" echo "video hooking ${vhook-no}" if enabled vhook; then echo "Imlib2 support ${imlib2-no}" @@ -1811,47 +1955,64 @@ echo "liba52 dlopened ${liba52bin-no}" echo "libamr-nb support ${libamr_nb-no}" echo "libamr-wb support ${libamr_wb-no}" echo "libdc1394 support ${libdc1394-no}" +echo "libdirac enabled ${libdirac-no}" echo "libfaac enabled ${libfaac-no}" echo "libfaad enabled ${libfaad-no}" echo "libfaad dlopened ${libfaadbin-no}" echo "libgsm enabled ${libgsm-no}" echo "libmp3lame enabled ${libmp3lame-no}" echo "libnut enabled ${libnut-no}" -echo "libogg enabled ${libogg-no}" +echo "libschroedinger enabled ${libschroedinger-no}" echo "libtheora enabled ${libtheora-no}" echo "libvorbis enabled ${libvorbis-no}" -echo "x264 enabled ${libx264-no}" -echo "XviD enabled ${libxvid-no}" +echo "libx264 enabled ${libx264-no}" +echo "libxvid enabled ${libxvid-no}" echo "zlib enabled ${zlib-no}" -enabled gpl && - echo "License: GPL" || - echo "License: LGPL" +echo "bzlib enabled ${bzlib-no}" +echo + +for type in decoder encoder parser demuxer muxer protocol filter bsf indev outdev; do + echo "Enabled ${type}s:" + eval list=\$$(toupper $type)_LIST + for part in $list; do + enabled $part && echo ${part%_*} + done | sort | pr -3 -t + echo +done + +license="LGPL" +if enabled nonfree; then + license="unredistributable" +elif enabled gpl; then + license="GPL" +fi + +echo "License: $license" echo "Creating config.mak and config.h..." echo "# Automatically generated by configure - do not modify!" > config.mak echo "/* Automatically generated by configure - do not modify! */" > $TMPH +echo "#ifndef FFMPEG_CONFIG_H" >> $TMPH +echo "#define FFMPEG_CONFIG_H" >> $TMPH echo "#define FFMPEG_CONFIGURATION \"$FFMPEG_CONFIGURATION\"" >> $TMPH -echo "PREFIX=$PREFIX" >> config.mak -echo "prefix=\$(DESTDIR)\$(PREFIX)" >> config.mak +echo "PREFIX=$prefix" >> config.mak echo "LIBDIR=\$(DESTDIR)$libdir" >> config.mak echo "SHLIBDIR=\$(DESTDIR)$shlibdir" >> 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 -echo "LDCONFIG=$LDCONFIG" >> config.mak echo "LN_S=$ln_s" >> config.mak -enabled dostrip && +enabled stripping && echo "STRIP=$strip" >> config.mak || echo "STRIP=echo ignoring strip" >> config.mak echo "OPTFLAGS=$CFLAGS" >> config.mak -echo "VHOOKCFLAGS=$VHOOKCFLAGS">>config.mak +echo "VHOOKCFLAGS=$VHOOKCFLAGS" >> config.mak echo "LDFLAGS=$LDFLAGS" >> config.mak echo "FFSERVERLDFLAGS=$FFSERVERLDFLAGS" >> config.mak echo "SHFLAGS=$SHFLAGS" >> config.mak @@ -1859,75 +2020,80 @@ echo "VHOOKSHFLAGS=$VHOOKSHFLAGS" >> config.mak echo "VHOOKLIBS=$VHOOKLIBS" >> config.mak echo "LIBOBJFLAGS=$LIBOBJFLAGS" >> config.mak echo "BUILD_STATIC=$static" >> config.mak -echo "BUILDSUF=$BUILDSUF" >> config.mak +echo "BUILDSUF=$build_suffix" >> config.mak +echo "FULLNAME=$FULLNAME" >> config.mak echo "LIBPREF=$LIBPREF" >> config.mak -echo "LIBSUF=\${BUILDSUF}$LIBSUF" >> config.mak -echo "LIB=$LIB" >> config.mak +echo "LIBSUF=$LIBSUF" >> config.mak +echo "LIBNAME=$LIBNAME" >> config.mak echo "SLIBPREF=$SLIBPREF" >> config.mak -echo "SLIBSUF=\${BUILDSUF}$SLIBSUF" >> config.mak -echo "EXESUF=\${BUILDSUF}$EXESUF" >> config.mak +echo "SLIBSUF=$SLIBSUF" >> config.mak +echo "EXESUF=$EXESUF" >> config.mak +echo "DEPEND_CMD=$DEPEND_CMD" >> config.mak if enabled bigendian; then - echo "WORDS_BIGENDIAN=yes" >> config.mak - echo "#define WORDS_BIGENDIAN 1" >> $TMPH -fi -if enabled mmx; then - echo "#define __CPU__ 586" >> $TMPH + echo "WORDS_BIGENDIAN=yes" >> config.mak + echo "#define WORDS_BIGENDIAN 1" >> $TMPH fi if enabled sdl; then - 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 fi if enabled texi2html; then - echo "BUILD_DOC=yes" >> config.mak + echo "BUILD_DOC=yes" >> config.mak fi -sws_version=`grep '#define LIBSWSCALE_VERSION ' "$source_path/libswscale/swscale.h" | sed 's/[^0-9\.]//g'` -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'` - +get_version(){ + name=$1 + file=$source_path/$2 + eval $(grep "#define ${name}_VERSION_M" "$file" | awk '{ print $2"="$3 }') + eval ${name}_VERSION=\$${name}_VERSION_MAJOR.\$${name}_VERSION_MINOR.\$${name}_VERSION_MICRO + lcname=$(tolower $name) + eval echo "${lcname}_VERSION=\$${name}_VERSION" >> config.mak + eval echo "${lcname}_VERSION_MAJOR=\$${name}_VERSION_MAJOR" >> config.mak +} +get_version LIBSWSCALE libswscale/swscale.h +get_version LIBPOSTPROC libpostproc/postprocess.h +get_version LIBAVCODEC libavcodec/avcodec.h +get_version LIBAVDEVICE libavdevice/avdevice.h +get_version LIBAVFORMAT libavformat/avformat.h +get_version LIBAVUTIL libavutil/avutil.h +get_version LIBAVFILTER libavfilter/avfilter.h if enabled shared; then - echo "BUILD_SHARED=yes" >> config.mak - echo "PIC=-fPIC -DPIC" >> config.mak - echo "SPPMAJOR=${pp_version%%.*}" >> config.mak - echo "SPPVERSION=$pp_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 "SWSMAJOR=${sws_version%%.*}" >> config.mak - echo "SWSVERSION=$sws_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 - echo "SLIB_EXTRA_CMD=${SLIB_EXTRA_CMD}" >> config.mak - echo "SLIB_INSTALL_EXTRA_CMD=${SLIB_INSTALL_EXTRA_CMD}" >> config.mak + echo "BUILD_SHARED=yes" >> config.mak + echo "PIC=-fPIC -DPIC" >> config.mak + echo "LIBTARGET=${LIBTARGET}" >> 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 + echo "SLIB_CREATE_DEF_CMD=${SLIB_CREATE_DEF_CMD}" >> config.mak + echo "SLIB_EXTRA_CMD=${SLIB_EXTRA_CMD}" >> config.mak + echo "SLIB_INSTALL_EXTRA_CMD=${SLIB_INSTALL_EXTRA_CMD}" >> config.mak + echo "SLIB_UNINSTALL_EXTRA_CMD=${SLIB_UNINSTALL_EXTRA_CMD}" >> config.mak fi echo "LIB_INSTALL_EXTRA_CMD=${LIB_INSTALL_EXTRA_CMD}" >> config.mak echo "EXTRALIBS=$extralibs" >> config.mak print_config ARCH_ $TMPH config.mak $ARCH_LIST print_config HAVE_ $TMPH config.mak $HAVE_LIST -print_config CONFIG_ $TMPH config.mak $CONFIG_LIST \ - $DECODER_LIST \ - $ENCODER_LIST \ - $PARSER_LIST \ - $BSF_LIST \ - $DEMUXER_LIST \ - $MUXER_LIST \ - $PROTOCOL_LIST \ +print_config CONFIG_ $TMPH config.mak $CONFIG_LIST \ + $DECODER_LIST \ + $ENCODER_LIST \ + $PARSER_LIST \ + $BSF_LIST \ + $DEMUXER_LIST \ + $MUXER_LIST \ + $FILTER_LIST \ + $PROTOCOL_LIST \ + $INDEV_LIST \ + $OUTDEV_LIST \ echo "#define restrict $_restrict" >> $TMPH if enabled small; then - echo "#define av_always_inline" >> $TMPH + echo "#define av_always_inline" >> $TMPH fi echo "SRC_PATH=\"$source_path\"" >> config.mak @@ -1936,50 +2102,58 @@ echo "BUILD_ROOT=\"$PWD\"" >> config.mak # Apparently it's not possible to portably echo a backslash. enabled asmalign_pot && - printf '#define ASMALIGN(ZEROBITS) ".align " #ZEROBITS "\\n\\t"\n' >> $TMPH || - printf '#define ASMALIGN(ZEROBITS) ".align 1<<" #ZEROBITS "\\n\\t"\n' >> $TMPH + printf '#define ASMALIGN(ZEROBITS) ".align " #ZEROBITS "\\n\\t"\n' >> $TMPH || + printf '#define ASMALIGN(ZEROBITS) ".align 1<<" #ZEROBITS "\\n\\t"\n' >> $TMPH + +echo "#define EXTERN_PREFIX \"${extern_prefix}\"" >> $TMPH +echo "#endif /* FFMPEG_CONFIG_H */" >> $TMPH -# Do not overwrite config.h if unchanged to avoid superfluous rebuilds. +# Do not overwrite an unchanged config.h to avoid superfluous rebuilds. cmp -s $TMPH config.h && echo "config.h is unchanged" || mv -f $TMPH config.h -rm -f $TMPO $TMPC $TMPE $TMPS $TMPH +rm -f $TMPC $TMPE $TMPH $TMPO $TMPS $TMPSH # build tree in object directory if source path is different from current one if enabled source_path_used; then DIRS="\ - doc \ - libavcodec \ - libavcodec/alpha \ - libavcodec/armv4l \ - libavcodec/bfin \ - libavcodec/i386 \ - libavcodec/mlib \ - libavcodec/ppc \ - libavcodec/sh4 \ - libavcodec/sparc \ - libavformat \ - libavutil \ - libpostproc \ - libswscale \ - tests \ - tools \ - vhook \ - " + doc \ + libavcodec \ + libavcodec/alpha \ + libavcodec/armv4l \ + libavcodec/bfin \ + libavcodec/i386 \ + libavcodec/mlib \ + libavcodec/ppc \ + libavcodec/sh4 \ + libavcodec/sparc \ + libavdevice \ + libavfilter \ + libavformat \ + libavutil \ + libpostproc \ + libswscale \ + tests \ + tools \ + vhook \ + " FILES="\ - Makefile \ - common.mak \ - doc/texi2pod.pl \ - libavcodec/Makefile \ - libavformat/Makefile \ - libavutil/Makefile \ - libpostproc/Makefile \ - libswscale/Makefile \ - " + Makefile \ + common.mak \ + subdir.mak \ + doc/texi2pod.pl \ + libavcodec/Makefile \ + libavdevice/Makefile \ + libavfilter/Makefile \ + libavformat/Makefile \ + libavutil/Makefile \ + libpostproc/Makefile \ + libswscale/Makefile \ + " for dir in $DIRS ; do - mkdir -p $dir + mkdir -p $dir done for f in $FILES ; do $ln_s "$source_path/$f" $f @@ -1988,43 +2162,35 @@ fi # build pkg-config files -# FIXME: libdir and includedir are hardcoded and may differ from the real path. pkgconfig_generate(){ name=$1 +shortname=${name#lib} comment=$2 version=$3 libs=$4 requires=$5 -include=$6 -cat <$name.pc -prefix=$PREFIX +cat < $name.pc +prefix=$prefix exec_prefix=\${prefix} -libdir=\${exec_prefix}/lib -includedir=\${prefix}/include +libdir=$libdir +includedir=$incdir Name: $name Description: $comment Version: $version -Requires: $requires +Requires: $(disabled shared && echo $requires) +Requires.private: $(enabled shared && echo $requires) Conflicts: -Libs: -L\${libdir} $libs -Cflags: -I\${includedir} -I\${includedir}/$include +Libs: -L\${libdir} -l${shortname} $(disabled shared && echo $libs) +Libs.private: $(enabled shared && echo $libs) +Cflags: -I\${includedir} EOF -} - -pkgconfig_generate_uninstalled(){ -name=$1 -shortname=${name#lib} -comment=$2 -version=$3 -libs=$4 -requires=$5 -cat <$name-uninstalled.pc +cat < $name-uninstalled.pc prefix= exec_prefix= libdir=\${pcfiledir}/$name -includedir=\${pcfiledir}/$name +includedir=\${pcfiledir} Name: $name Description: $comment @@ -2036,26 +2202,17 @@ Cflags: -I\${includedir} EOF } -pkgconfig_generate libavutil "FFmpeg utility library" "$lavu_version" -lavutil "" ffmpeg -pkgconfig_generate_uninstalled libavutil "FFmpeg utility library" "$lavu_version" - -pkgconfig_generate libavcodec "FFmpeg codec library" "$lavc_version" "-lavcodec $extralibs" "$pkg_requires libavutil = $lavu_version" ffmpeg -pkgconfig_generate_uninstalled libavcodec "FFmpeg codec library" "$lavc_version" "$extralibs" "$pkg_requires libavutil = $lavu_version" - -pkgconfig_generate libavformat "FFmpeg container format library" "$lavf_version" "-lavformat $extralibs" "$pkg_requires libavcodec = $lavc_version" ffmpeg -pkgconfig_generate_uninstalled libavformat "FFmpeg container format library" "$lavf_version" "$extralibs" "$pkg_requires libavcodec = $lavc_version" - -if enabled pp; then - pkgconfig_generate libpostproc "FFmpeg post processing library" "$pp_version" -lpostproc "" postproc - pkgconfig_generate_uninstalled libpostproc "FFmpeg post processing library" "$pp_version" -fi - -if enabled swscaler; then - pkgconfig_generate libswscale "FFmpeg image rescaling library" "$sws_version" -lswscale "libavutil = $lavu_version" ffmpeg - pkgconfig_generate_uninstalled libswscale "FFmpeg image rescaling library" "$sws_version" "" "libavutil = $lavu_version" +pkgconfig_generate libavutil "FFmpeg utility library" "$LIBAVUTIL_VERSION" +pkgconfig_generate libavcodec "FFmpeg codec library" "$LIBAVCODEC_VERSION" "$extralibs" "$pkg_requires libavutil = $LIBAVUTIL_VERSION" +pkgconfig_generate libavformat "FFmpeg container format library" "$LIBAVFORMAT_VERSION" "$extralibs" "$pkg_requires libavcodec = $LIBAVCODEC_VERSION" +pkgconfig_generate libavdevice "FFmpeg device handling library" "$LIBAVDEVICE_VERSION" "$extralibs" "$pkg_requires libavformat = $LIBAVFORMAT_VERSION" +enabled avfilter && \ + pkgconfig_generate libavfilter "FFmpeg video filtering library" "$LIBAVFILTER_VERSION" "$extralibs" "$pkg_requires libavutil = $LIBAVUTIL_VERSION" +enabled postproc && \ + pkgconfig_generate libpostproc "FFmpeg post processing library" "$LIBPOSTPROC_VERSION" +if enabled swscale; then + pkgconfig_generate libswscale "FFmpeg image rescaling library" "$LIBSWSCALE_VERSION" "" "libavutil = $LIBAVUTIL_VERSION" else - pkgconfig_generate libswscale "FFmpeg image rescaling library" "$sws_version" "" "$pkg_requires libavcodec = $lavc_version" ffmpeg - pkgconfig_generate_uninstalled libswscale "FFmpeg image rescaling library" "$sws_version" "" "$pkg_requires libavcodec = $lavc_version" - apply libswscale.pc sed s/^Libs:.*$/Libs:/ - apply libswscale-uninstalled.pc sed s/^Libs:.*$/Libs:/ + pkgconfig_generate libswscale "FFmpeg image rescaling library" "$LIBSWSCALE_VERSION" "" "$pkg_requires libavcodec = $LIBAVCODEC_VERSION" + apply libswscale.pc sed s/^Libs:.*$/Libs:/ fi