X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=configure;h=eb5109192366d005d10114eec588b220695c8aa6;hb=e0779152f7c9489ba89481272537e9ac0a1f733a;hp=41c48bca06afa9caff4a0df0a5e691eb948a1433;hpb=167abec138939a7475b481c6cf4a3738601f279a;p=x264 diff --git a/configure b/configure index 41c48bca..eb510919 100755 --- a/configure +++ b/configure @@ -7,10 +7,10 @@ echo "" echo "available options:" echo "" echo " --help print this message" -echo " --enable-avis-input enables avisynth input (win32 only)" -echo " --enable-mp4-output enables mp4 output (using gpac)" -echo " --enable-gtk build GTK+ interface" -echo " --enable-pthread enables multithreaded encoding" +echo " --disable-avis-input disables avisynth input (win32 only)" +echo " --disable-mp4-output disables mp4 output (using gpac)" +echo " --disable-pthread disables multithreaded encoding" +echo " --disable-asm disables assembly optimizations on x86" echo " --enable-debug adds -g, doesn't strip" echo " --enable-gprof adds -pg, doesn't strip" echo " --enable-visualize enables visualization (X11 only)" @@ -19,23 +19,29 @@ echo " --enable-shared build libx264.so" echo " --extra-asflags=EASFLAGS add EASFLAGS to ASFLAGS" echo " --extra-cflags=ECFLAGS add ECFLAGS to CFLAGS" echo " --extra-ldflags=ELDFLAGS add ELDFLAGS to LDFLAGS" +echo " --host=HOST build programs to run on HOST" echo "" exit 1 fi cc_check() { - rm -f conftest* cat > conftest.c << EOF #include <$1> int main () { $3 return 0; } EOF - $CC $CFLAGS $LDFLAGS $2 conftest.c -o conftest 2>$DEVNULL + $CC conftest.c $CFLAGS $LDFLAGS $2 -o conftest 2>$DEVNULL TMP="$?" - rm -f conftest.c conftest* return $TMP } -rm -f config.h config.mak x264.pc +as_check() { + echo "$1" > conftest.asm + $AS conftest.asm $ASFLAGS $2 -o conftest.o 2>$DEVNULL + TMP="$?" + return $TMP +} + +rm -f config.h config.mak x264.pc conftest* prefix='/usr/local' exec_prefix='${prefix}' @@ -47,26 +53,129 @@ DEVNULL='/dev/null' avis_input="auto" mp4_output="auto" pthread="auto" +asm="yes" debug="no" gprof="no" pic="no" -gtk="no" vis="no" shared="no" CC="${CC-gcc}" -CFLAGS="-Wall -I. -D__X264__" -LDFLAGS="" +CFLAGS="$CFLAGS -Wall -I." +LDFLAGS="$LDFLAGS" HAVE_GETOPT_LONG=1 -AS="nasm" +AS="yasm" ASFLAGS="" EXE="" -MACHINE="$(./config.guess)" +# check whether 'echo -n' works as expected, otherwise try printf +if [ "x`echo -n houba`" = xhouba ] +then + ECHON="echo -n" +elif [ "x`printf houba`" = xhouba ] +then + ECHON="printf" +else + echo "Neither 'echo -n' nor 'printf' are working with your shell!" + exit 1 +fi + +# parse options -case "${MACHINE#*-*-}" in +for opt do + optarg="${opt#*=}" + case "$opt" in + --prefix=*) + prefix="$optarg" + ;; + --exec-prefix=*) + exec_prefix="$optarg" + ;; + --bindir=*) + bindir="$optarg" + ;; + --libdir=*) + libdir="$optarg" + ;; + --includedir=*) + includedir="$optarg" + ;; + --enable-asm) + asm="yes" + ;; + --disable-asm) + asm="no" + ;; + --enable-avis-input) + avis_input="yes" + ;; + --disable-avis-input) + avis_input="no" + ;; + --enable-mp4-output) + mp4_output="yes" + ;; + --disable-mp4-output) + mp4_output="no" + ;; + --extra-asflags=*) + ASFLAGS="$ASFLAGS ${opt#--extra-asflags=}" + ;; + --extra-cflags=*) + CFLAGS="$CFLAGS ${opt#--extra-cflags=}" + ;; + --extra-ldflags=*) + LDFLAGS="$LDFLAGS ${opt#--extra-ldflags=}" + ;; + --enable-pthread) + pthread="auto" # can't skip detection, since it differs by OS + ;; + --disable-pthread) + pthread="no" + ;; + --enable-debug) + debug="yes" + ;; + --enable-gprof) + CFLAGS="$CFLAGS -pg" + LDFLAGS="$LDFLAGS -pg" + gprof="yes" + ;; + --enable-pic) + pic="yes" + ;; + --enable-shared) + shared="yes" + ;; + --enable-visualize) + LDFLAGS="$LDFLAGS -L/usr/X11R6/lib -lX11" + CFLAGS="$CFLAGS -DVISUALIZE=1" + vis="yes" + ;; + --host=*) + host="${opt#--host=}" + ;; + *) + echo "Unknown option $opt, ignored" + ;; + esac +done + +if [ "x$host" = x ]; then + host=`./config.guess` +fi +# normalize a triplet into a quadruplet +host=`./config.sub $host` + +# split $host +host_cpu="${host%%-*}" +host="${host#*-}" +host_vendor="${host%%-*}" +host_os="${host#*-}" + +case $host_os in beos*) SYS="BEOS" CFLAGS="$CFLAGS -DHAVE_MALLOC_H" @@ -75,6 +184,9 @@ case "${MACHINE#*-*-}" in SYS="MACOSX" CFLAGS="$CFLAGS -falign-loops=16" LDFLAGS="$LDFLAGS -lm -lmx" + if [ "$pic" = "no" ]; then + CFLAGS="$CFLAGS -mdynamic-no-pic" + fi ;; freebsd*) SYS="FREEBSD" @@ -100,7 +212,7 @@ case "${MACHINE#*-*-}" in LDFLAGS="$LDFLAGS -lm" ;; cygwin*) - SYS="CYGWIN" + SYS="MINGW" CFLAGS="$CFLAGS -mno-cygwin" LDFLAGS="$LDFLAGS -mno-cygwin" EXE=".exe" @@ -118,40 +230,40 @@ case "${MACHINE#*-*-}" in HAVE_GETOPT_LONG=0 ;; *) - echo "Unknown system $MACHINE, edit the configure" + echo "Unknown system $host, edit the configure" exit 1 ;; esac -case "${MACHINE%%-*}" in +case $host_cpu in i*86) ARCH="X86" - CFLAGS="$CFLAGS -DHAVE_MMXEXT -DHAVE_SSE2" - AS="nasm" ASFLAGS="-O2" if [ "$SYS" = MACOSX ]; then ASFLAGS="$ASFLAGS -f macho -DPREFIX" - elif [ "$SYS" = CYGWIN -o "$SYS" = MINGW ]; then + elif [ "$SYS" = MINGW ]; then ASFLAGS="$ASFLAGS -f win32 -DPREFIX" - elif [ "$SYS" = NETBSD ]; then - ASFLAGS="$ASFLAGS -f aoutb" else ASFLAGS="$ASFLAGS -f elf" fi ;; x86_64) ARCH="X86_64" - CFLAGS="$CFLAGS -DHAVE_MMXEXT -DHAVE_SSE2" - AS="yasm" - ASFLAGS="-f elf -m amd64" + if [ "$SYS" = MACOSX ];then + ASFLAGS="-f macho64 -m amd64 -DPIC -DPREFIX" + CFLAGS="$CFLAGS -arch x86_64" + LDFLAGS="$LDFLAGS -arch x86_64" + else + ASFLAGS="-f elf -m amd64" + fi ;; powerpc|powerpc64) ARCH="PPC" if [ $SYS = MACOSX ] then - CFLAGS="$CFLAGS -faltivec -fastf -mcpu=G4" + ALTIVECFLAGS="$ALTIVECFLAGS -faltivec -fastf -mcpu=G4" else - CFLAGS="$CFLAGS -maltivec -mabi=altivec" + ALTIVECFLAGS="$ALTIVECFLAGS -maltivec -mabi=altivec" fi ;; sparc) @@ -178,118 +290,70 @@ case "${MACHINE%%-*}" in ARCH="PARISC" ;; *) - ARCH="$(echo ${MACHINE%%-*} | tr a-z A-Z)" + ARCH="$(echo $host_cpu | tr a-z A-Z)" ;; esac -CFLAGS="$CFLAGS -DARCH_$ARCH -DSYS_$SYS" +# check requirements -# parse options +if [ $shared = yes -a \( $ARCH = "X86_64" -o $ARCH = "PPC" -o $ARCH = "ALPHA" \) ] ; then + pic="yes" +fi -for opt do - optarg="${opt#*=}" - case "$opt" in - --prefix=*) - prefix="$optarg" - ;; - --exec-prefix=*) - exec_prefix="$optarg" - ;; - --bindir=*) - bindir="$optarg" - ;; - --libdir=*) - libdir="$optarg" - ;; - --includedir=*) - includedir="$optarg" - ;; - --enable-avis-input) - avis_input="yes" - ;; - --disable-avis-input) - avis_input="no" - ;; - --enable-mp4-output) - mp4_output="yes" - ;; - --disable-mp4-output) - mp4_output="no" - ;; - --extra-asflags=*) - ASFLAGS="$ASFLAGS ${opt#--extra-asflags=}" - ;; - --extra-cflags=*) - CFLAGS="$CFLAGS ${opt#--extra-cflags=}" - ;; - --extra-ldflags=*) - LDFLAGS="$LDFLAGS ${opt#--extra-ldflags=}" - ;; - --enable-pthread) - pthread="yes" - ;; - --disable-pthread) - pthread="no" - ;; - --enable-debug) - debug="yes" - ;; - --enable-gprof) - CFLAGS="$CFLAGS -pg" - LDFLAGS="$LDFLAGS -pg" - gprof="yes" - ;; - --enable-pic) - pic="yes" - ;; - --enable-gtk) - gtk="yes" - ;; - --disable-gtk) - gtk="no" - ;; - --enable-shared) - shared="yes" - if [ $ARCH = "X86_64" -o $ARCH = "PPC" -o $ARCH = "ALPHA" ] ; then - pic="yes" - fi - ;; - --enable-visualize) - LDFLAGS="$LDFLAGS -L/usr/X11R6/lib -lX11" - CFLAGS="$CFLAGS -DVISUALIZE=1" - vis="yes" - ;; - *) - echo "Unknown option $opt, ignored" - ;; - esac -done +if [ $asm = yes -a \( $ARCH = X86 -o $ARCH = X86_64 \) ] ; then + if as_check "pinsrd xmm0, [esp], 0" ; then + CFLAGS="$CFLAGS -DHAVE_MMX" + else + VER=`($AS --version || echo no assembler) 2>$DEVNULL | head -n 1` + echo "Found $VER" + echo "Minimum version is yasm-0.6.1" + echo "If you really want to compile without asm, configure with --disable-asm." + exit 1 + fi +else + AS="" +fi + +CFLAGS="$CFLAGS -DARCH_$ARCH -DSYS_$SYS" + +echo "unsigned int endian = 'B' << 24 | 'I' << 16 | 'G' << 8 | 'E';" > conftest.c +$CC $CFLAGS conftest.c -c -o conftest.o 2>$DEVNULL || die "endian test failed" +grep -q BIGE conftest.o && CFLAGS="$CFLAGS -DWORDS_BIGENDIAN" # autodetect options that weren't forced nor disabled +libpthread="" if test "$pthread" = "auto" ; then + pthread="no" case $SYS in - MINGW|CYGWIN|BEOS) + BEOS) pthread="yes" ;; + MINGW) + if cc_check pthread.h -lpthread "pthread_create(0,0,0,0);" ; then + pthread="yes" + libpthread="-lpthread" + elif cc_check pthread.h -lpthreadGC2 "pthread_create(0,0,0,0);" ; then + pthread="yes" + libpthread="-lpthreadGC2" + elif cc_check pthread.h "-lpthreadGC2 -lwsock32 -DPTW32_STATIC_LIB" "pthread_create(0,0,0,0);" ; then + pthread="yes" + libpthread="-lpthreadGC2 -lwsock32" + CFLAGS="$CFLAGS -DPTW32_STATIC_LIB" + fi + ;; *) - pthread="no" - cc_check pthread.h -lpthread && pthread="yes" + cc_check pthread.h -lpthread && pthread="yes" && libpthread="-lpthread" ;; esac fi if test "$pthread" = "yes" ; then CFLAGS="$CFLAGS -DHAVE_PTHREAD" - case $SYS in - MINGW|CYGWIN|BEOS) - ;; - *) LDFLAGS="$LDFLAGS -lpthread" - ;; - esac + LDFLAGS="$LDFLAGS $libpthread" fi MP4_LDFLAGS="-lgpac_static" -if [ $SYS = CYGWIN -o $SYS = MINGW ]; then +if [ $SYS = MINGW ]; then MP4_LDFLAGS="$MP4_LDFLAGS -lwinmm" fi if [ "$mp4_output" = "auto" ] ; then @@ -302,7 +366,7 @@ if [ "$mp4_output" = "yes" ] ; then fi if [ "$avis_input" = "auto" ] ; then - if [ $SYS = CYGWIN -o $SYS = MINGW ]; then + if [ $SYS = MINGW ]; then avis_input="yes" else avis_input="no"; @@ -315,7 +379,9 @@ fi if [ "$pic" = "yes" ] ; then CFLAGS="$CFLAGS -fPIC" - ASFLAGS="$ASFLAGS -D__PIC__" + ASFLAGS="$ASFLAGS -DPIC" + # resolve textrels in the x86 asm + cc_check stdio.h -Wl,-Bsymbolic && LDFLAGS="$LDFLAGS -Wl,-Bsymbolic" fi if [ "$debug" != "yes" -a "$gprof" != "yes" ]; then @@ -337,6 +403,8 @@ elif cc_check "stdio.h" "" "fseeko64(stdin,0,0);" ; then echo "#define ftell ftello64" >> config.h fi +rm -f conftest* + # generate config files cat > config.mak << EOF @@ -349,49 +417,44 @@ ARCH=$ARCH SYS=$SYS CC=$CC CFLAGS=$CFLAGS +ALTIVECFLAGS=$ALTIVECFLAGS LDFLAGS=$LDFLAGS AS=$AS ASFLAGS=$ASFLAGS -GTK=$gtk EXE=$EXE VIS=$vis HAVE_GETOPT_LONG=$HAVE_GETOPT_LONG DEVNULL=$DEVNULL +ECHON=$ECHON EOF -echo -n 'CONFIGURE_ARGS=' >> config.mak +$ECHON 'CONFIGURE_ARGS=' >> config.mak for A in "$@" ; do - echo -n " '$A'" >> config.mak + $ECHON " '$A'" >> config.mak done echo '' >> config.mak -cp config.mak gtk/config.mak - if [ "$shared" = "yes" ]; then API=$(grep '#define X264_BUILD' < x264.h | cut -f 3 -d ' ') - echo "SONAME=libx264.so.$API" >> config.mak - echo 'default: $(SONAME)' >> config.mak - if [ "$gtk" = "yes" ]; then - echo "SONAMEGTK=libx264gtk.so.$API" >> gtk/config.mak + if [ "$SYS" = "MINGW" ]; then + echo "SONAME=libx264-$API.dll" >> config.mak + echo 'IMPLIBNAME=libx264.dll.a' >> config.mak + echo 'SOFLAGS=-Wl,--out-implib,$(IMPLIBNAME) -Wl,--enable-auto-image-base' >> config.mak + elif [ "$SYS" = "MACOSX" ]; then + echo "SOSUFFIX=dylib" >> config.mak + echo "SONAME=libx264.$API.dylib" >> config.mak + echo 'SOFLAGS=-dynamiclib -Wl,-single_module -Wl,-read_only_relocs,suppress -install_name $(DESTDIR)$(libdir)/$(SONAME)' >> config.mak + else + echo "SOSUFFIX=so" >> config.mak + echo "SONAME=libx264.so.$API" >> config.mak + echo 'SOFLAGS=-Wl,-soname,$(SONAME)' >> config.mak fi -fi - -if [ "$gtk" = "yes" ]; then - echo 'default: libx264gtk.a' >> config.mak - echo 'install: install-gtk' >> config.mak + echo 'default: $(SONAME)' >> config.mak fi ./version.sh -pclibs="-L$libdir -lx264" -if test "$pthread" = "yes" ; then - case $SYS in - MINGW|CYGWIN|BEOS) - ;; - *) pclibs="$pclibs -lpthread" - ;; - esac -fi +pclibs="-L$libdir -lx264 $libpthread" cat > x264.pc << EOF prefix=$prefix @@ -409,10 +472,10 @@ EOF echo "Platform: $ARCH" echo "System: $SYS" +echo "asm: $asm" echo "avis input: $avis_input" echo "mp4 output: $mp4_output" echo "pthread: $pthread" -echo "gtk: $gtk" echo "debug: $debug" echo "gprof: $gprof" echo "PIC: $pic"