Commit 826288b7 authored by glantau's avatar glantau

added bigendian support - added cross compilation support - added generation...

added bigendian support - added cross compilation support - added generation of objects in another directory for simultaneous compilations (needs testing) - simplified redundant code


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@530 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 903fe59a
#!/bin/sh #!/bin/sh
#
TMPC="ffmpeg-conf-${RANDOM}-$$-${RANDOM}.c" # ffmpeg configure script (c) 2000, 2001, 2002 Gerard Lantau
TMPO="ffmpeg-conf-${RANDOM}-$$-${RANDOM}.o" #
TMPS="ffmpeg-conf-${RANDOM}-$$-${RANDOM}.S" # set temporary file name
TMPH="ffmpeg-conf-${RANDOM}-$$-${RANDOM}.h"
if test ! -z "$TMPDIR" ; then if test ! -z "$TMPDIR" ; then
TMPC="${TMPDIR}/${TMPC}" TMPDIR1="${TMPDIR}"
TMPCPP="${TMPDIR}/${TMPCPP}"
TMPO="${TMPDIR}/${TMPO}"
TMPS="${TMPDIR}/${TMPS}"
TMPH="${TMPDIR}/${TMPH}"
elif test ! -z "$TEMPDIR" ; then elif test ! -z "$TEMPDIR" ; then
TMPC="${TEMPDIR}/${TMPC}" TMPDIR1="${TEMPDIR}"
TMPCPP="${TEMPDIR}/${TMPCPP}"
TMPO="${TEMPDIR}/${TMPO}"
TMPS="${TEMPDIR}/${TMPS}"
TMPH="${TEMPDIR}/${TMPH}"
else else
TMPC="/tmp/${TMPC}" TMPDIR1="/tmp"
TMPCPP="/tmp/${TMPCPP}"
TMPO="/tmp/${TMPO}"
TMPS="/tmp/${TMPS}"
TMPH="/tmp/${TMPH}"
fi fi
TMPC="${TMPDIR1}/ffmpeg-conf-${RANDOM}-$$-${RANDOM}.c"
TMPO="${TMPDIR1}/ffmpeg-conf-${RANDOM}-$$-${RANDOM}.o"
TMPS="${TMPDIR1}/ffmpeg-conf-${RANDOM}-$$-${RANDOM}.S"
TMPH="${TMPDIR1}/ffmpeg-conf-${RANDOM}-$$-${RANDOM}.h"
# default parameters # default parameters
prefix="/usr/local" prefix="/usr/local"
cross_prefix=""
cc="gcc" cc="gcc"
ar="ar" ar="ar"
strip="strip"
cpu=`uname -m` cpu=`uname -m`
mmx="default"
case "$cpu" in case "$cpu" in
i386|i486|i586|i686|i86pc|BePC) i386|i486|i586|i686|i86pc|BePC)
cpu="x86" cpu="x86"
mmx="yes"
;; ;;
armv4l) armv4l)
cpu="armv4l" cpu="armv4l"
mmx="no"
;; ;;
alpha) alpha)
cpu="alpha" cpu="alpha"
mmx="no"
;; ;;
*) *)
mmx="no" cpu="unknown"
;; ;;
esac esac
gprof="no" gprof="no"
...@@ -55,6 +46,7 @@ win32="no" ...@@ -55,6 +46,7 @@ win32="no"
lshared="no" lshared="no"
extralibs="-lm" extralibs="-lm"
simpleidct="yes" simpleidct="yes"
bigendian="no"
# OS specific # OS specific
targetos=`uname -s` targetos=`uname -s`
...@@ -75,34 +67,33 @@ fi ;; ...@@ -75,34 +67,33 @@ fi ;;
*) ;; *) ;;
esac esac
if test "$1" = "-h" -o "$1" = "--help" ; then # find source path
cat << EOF # XXX: we assume an absolute path is given when launching configure,
# except in './configure' case.
Usage: configure [options] source_path=${0%configure}
Options: [defaults in brackets after descriptions] source_path=${source_path%/}
source_path_used="yes"
--help print this message if test -z "$source_path" -o "$source_path" = "." ; then
EOF source_path=`pwd`
echo " --prefix=PREFIX install in PREFIX [$prefix]" source_path_used="no"
echo " --cc=CC use C compiler CC [$cc]"
echo " --cpu=CPU force cpu to CPU [$cpu]"
echo " --disable-mmx disable mmx usage"
echo " --enable-gprof enable profiling with gprof [$gprof]"
echo " --disable-grab disable audio/video grabbing code"
echo " --disable-simple_idct disable simple IDCT routines [default=no]"
echo " --enable-mp3lame enable mp3 encoding via libmp3lame [default=no]"
echo " --enable-win32 enable win32 cross compile"
echo " --enable-a52bin open liba52.so.0 at runtime [default=no]"
echo " --enable-shared build shared libraries [default=no]"
exit 1
fi fi
for opt do for opt do
case "$opt" in case "$opt" in
--prefix=*) prefix=`echo $opt | cut -d '=' -f 2` --prefix=*) prefix=`echo $opt | cut -d '=' -f 2`
;; ;;
--source-path=*) source_path=`echo $opt | cut -d '=' -f 2`
;;
--cross-prefix=*) cross_prefix=`echo $opt | cut -d '=' -f 2`
;;
--cc=*) cc=`echo $opt | cut -d '=' -f 2` --cc=*) cc=`echo $opt | cut -d '=' -f 2`
;; ;;
--extra-cflags=*) CFLAGS="${opt#--extra-cflags=}"
;;
--extra-ldflags=*) LDFLAGS=${opt#--extra-ldflags=}
;;
--extra-libs=*) extralibs=${opt#--extra-libs=}
;;
--cpu=*) cpu=`echo $opt | cut -d '=' -f 2` --cpu=*) cpu=`echo $opt | cut -d '=' -f 2`
;; ;;
--disable-mmx) mmx="no" --disable-mmx) mmx="no"
...@@ -124,6 +115,15 @@ for opt do ...@@ -124,6 +115,15 @@ for opt do
esac esac
done done
# compute mmx state
if test $mmx = "default"; then
if test $cpu = "x86"; then
mmx="yes"
else
mmx="no"
fi
fi
# Checking for CFLAGS # Checking for CFLAGS
if test -z "$CFLAGS"; then if test -z "$CFLAGS"; then
CFLAGS="-O2" CFLAGS="-O2"
...@@ -131,11 +131,18 @@ fi ...@@ -131,11 +131,18 @@ fi
if test "$win32" = "yes" ; then if test "$win32" = "yes" ; then
cross_prefix="i386-mingw32msvc-" cross_prefix="i386-mingw32msvc-"
cc="${cross_prefix}gcc"
ar="${cross_prefix}ar"
grab="no" grab="no"
fi fi
# endianness : guess with cpu type. Should also use prefix
if test "$cpu" = "powerpc"; then
bigendian="yes"
fi
cc="${cross_prefix}${cc}"
ar="${cross_prefix}${ar}"
strip="${cross_prefix}${strip}"
# --- # ---
# check availability of some header files # check availability of some header files
...@@ -161,9 +168,43 @@ EOF ...@@ -161,9 +168,43 @@ EOF
$cc -o $TMPO $TMPC 2> /dev/null || _memalign=no $cc -o $TMPO $TMPC 2> /dev/null || _memalign=no
fi fi
if test "$1" = "-h" -o "$1" = "--help" ; then
cat << EOF
Usage: configure [options]
Options: [defaults in brackets after descriptions]
EOF
echo "Standard options:"
echo " --help print this message"
echo " --prefix=PREFIX install in PREFIX [$prefix]"
echo " --disable-grab disable audio/video grabbing code"
echo " --disable-simple_idct disable simple IDCT routines [default=no]"
echo " --enable-mp3lame enable mp3 encoding via libmp3lame [default=no]"
echo " --enable-win32 enable win32 cross compile"
echo " --enable-a52bin open liba52.so.0 at runtime [default=no]"
echo " --enable-shared build shared libraries [default=no]"
echo ""
echo "Advanced options (experts only):"
echo " --source-path=PATH path of source code [$source_path]"
echo " --cross-prefix=PREFIX use PREFIX for compile tools [$cross_prefix]"
echo " --cc=CC use C compiler CC [$cc]"
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 " --cpu=CPU force cpu to CPU [$cpu]"
echo " --disable-mmx disable mmx usage"
echo " --enable-gprof enable profiling with gprof [$gprof]"
echo ""
echo "NOTE: The object files are build at the place where configure is launched"
exit 1
fi
echo "Install prefix $prefix" echo "Install prefix $prefix"
echo "Source path $source_path"
echo "C compiler $cc" echo "C compiler $cc"
echo "CPU $cpu" echo "CPU $cpu"
echo "Big Endian $bigendian"
echo "MMX enabled $mmx" echo "MMX enabled $mmx"
echo "gprof enabled $gprof" echo "gprof enabled $gprof"
echo "grab enabled $grab" echo "grab enabled $grab"
...@@ -179,18 +220,25 @@ echo "prefix=$prefix" >> config.mak ...@@ -179,18 +220,25 @@ echo "prefix=$prefix" >> config.mak
echo "MAKE=make" >> config.mak echo "MAKE=make" >> config.mak
echo "CC=$cc" >> config.mak echo "CC=$cc" >> config.mak
echo "AR=$ar" >> config.mak echo "AR=$ar" >> config.mak
echo "STRIP=$strip" >> config.mak
echo "OPTFLAGS=$CFLAGS" >> config.mak echo "OPTFLAGS=$CFLAGS" >> config.mak
echo "LDFLAGS=$LDFLAGS" >> config.mak
if test "$cpu" = "x86" ; then if test "$cpu" = "x86" ; then
echo "TARGET_ARCH_X86=yes" >> config.mak echo "TARGET_ARCH_X86=yes" >> config.mak
echo "#define ARCH_X86 1" >> $TMPH echo "#define ARCH_X86 1" >> $TMPH
fi elif test "$cpu" = "armv4l" ; then
if test "$cpu" = "armv4l" ; then
echo "TARGET_ARCH_ARMV4L=yes" >> config.mak echo "TARGET_ARCH_ARMV4L=yes" >> config.mak
echo "#define ARCH_ARMV4L 1" >> $TMPH echo "#define ARCH_ARMV4L 1" >> $TMPH
fi elif test "$cpu" = "alpha" ; then
if test "$cpu" = "alpha" ; then
echo "TARGET_ARCH_ALPHA=yes" >> config.mak echo "TARGET_ARCH_ALPHA=yes" >> config.mak
echo "#define ARCH_ALPHA 1" >> $TMPH echo "#define ARCH_ALPHA 1" >> $TMPH
elif test "$cpu" = "powerpc" ; then
echo "TARGET_ARCH_POWERPC=yes" >> config.mak
echo "#define ARCH_POWERPC 1" >> $TMPH
fi
if test "$bigendian" = "yes" ; then
echo "WORDS_BIGENDIAN=yes" >> config.mak
echo "#define WORDS_BIGENDIAN 1" >> $TMPH
fi fi
if test "$mmx" = "yes" ; then if test "$mmx" = "yes" ; then
echo "TARGET_MMX=yes" >> config.mak echo "TARGET_MMX=yes" >> config.mak
...@@ -207,7 +255,7 @@ else ...@@ -207,7 +255,7 @@ else
fi fi
echo "EXTRALIBS=$extralibs" >> config.mak echo "EXTRALIBS=$extralibs" >> config.mak
echo -n "VERSION=" >>config.mak echo -n "VERSION=" >>config.mak
head VERSION >>config.mak head $source_path/VERSION >>config.mak
echo "" >>config.mak echo "" >>config.mak
# if you do not want to use encoders, disable that. # if you do not want to use encoders, disable that.
echo "#define CONFIG_ENCODERS 1" >> $TMPH echo "#define CONFIG_ENCODERS 1" >> $TMPH
...@@ -260,6 +308,20 @@ if test "$simpleidct" = "yes" ; then ...@@ -260,6 +308,20 @@ if test "$simpleidct" = "yes" ; then
echo "#define SIMPLE_IDCT 1" >> $TMPH echo "#define SIMPLE_IDCT 1" >> $TMPH
fi fi
# build tree in object directory if source path is different from current one
if test "$source_path_used" = "yes" ; then
DIRS="libav libavcodec libavcodec/alpha libavcodec/armv4l libavcodec/i386 \
libavcodec/liba52 libavcodec/mlib tests"
FILES="Makefile libav/Makefile libavcodec/Makefile tests/Makefile"
for dir in $DIRS ; do
mkdir -p $dir
done
for f in $FILES ; do
ln -sf $source_path/$f $f
done
fi
echo "SRC_PATH=$source_path" >> config.mak
diff $TMPH config.h >/dev/null 2>&1 diff $TMPH config.h >/dev/null 2>&1
if test $? -ne 0 ; then if test $? -ne 0 ; then
mv -f $TMPH config.h mv -f $TMPH config.h
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment