X-Git-Url: https://git.kernel.dk/?p=fio.git;a=blobdiff_plain;f=configure;h=8125fc3ccfb685ae0f8149b191a079121adfbc81;hp=b49497b77a35d903b9d257f57d594d94147b13f8;hb=3ba1ba7f3d0fde62817e3e0c2aa284759de96ec8;hpb=f266b7f770b8985c07f835e17d76c617b7480723 diff --git a/configure b/configure index b49497b7..8125fc3c 100755 --- a/configure +++ b/configure @@ -24,10 +24,22 @@ trap "rm -f $TMPC $TMPO $TMPE" EXIT INT QUIT TERM rm -rf config.log config_host_mak="config-host.mak" -config_host_ld="config-host.ld" +config_host_h="config-host.h" + +rm -rf $config_host_mak +rm -rf $config_host_h + +fatal() { + echo $@ + echo "Configure failed, check config.log and/or the above output" + rm -rf $config_host_mak + rm -rf $config_host_h + exit 1 +} # Default CFLAGS CFLAGS="-D_GNU_SOURCE" +EXTFLAGS="-include config-host.h" # Print a helpful header at the top of config.log echo "# FIO configure log $(date)" >> config.log @@ -36,6 +48,14 @@ printf " '%s'" "$0" "$@" >> config.log echo >> config.log echo "#" >> config.log +# Print configure header at the top of $config_host_h +echo "/*" > $config_host_h +echo " * Automatically generated by configure - do not modify" >> $config_host_h +printf " * Configured with:" >> $config_host_h +printf " * '%s'" "$0" "$@" >> $config_host_h +echo "" >> $config_host_h +echo " */" >> $config_host_h + do_cc() { # Run the compiler, capturing its output to the log. echo $cc "$@" >> config.log @@ -58,8 +78,7 @@ do_cc() { echo "ERROR: configure test passed without -Werror but failed with -Werror." echo "This is probably a bug in the configure script. The failing command" echo "will be at the bottom of config.log." - echo "You can run configure with --disable-werror to bypass this check." - exit 1 + fatal "You can run configure with --disable-werror to bypass this check." } compile_object() { @@ -79,8 +98,7 @@ feature_not_found() { echo "ERROR" echo "ERROR: User requested feature $feature" echo "ERROR: configure was not able to find it" - echo "ERROR" - exit 1; + fatal "ERROR" } has() { @@ -100,24 +118,52 @@ EOF compile_object } +output_sym() { + echo "$1=y" >> $config_host_mak + echo "#define $1" >> $config_host_h +} + targetos="" cpu="" cc="${CC-${cross_prefix}gcc}" +show_help="no" +exit_val=0 + # parse options for opt do optarg=`expr "x$opt" : 'x[^=]*=\(.*\)'` case "$opt" in + --cpu=*) cpu="$optarg" + ;; --cc=*) CC="$optarg" ;; + --extra-cflags=*) CFLAGS="$CFLAGS $optarg" + ;; + --build-32bit-win=*) build_32bit_win="$optarg" + ;; + --help) + show_help="yes" + ;; *) echo "Bad option $opt" - exit 1 + show_help="yes" + exit_val=1 esac done -if check_define __linux__ ; then +if test "$show_help" = "yes" ; then + echo "--cpu= Specify target CPU if auto-detect fails" + echo "--cc= Specify compiler to use" + echo "--extra-cflags= Specify extra CFLAGS to pass to compiler" + echo "--build-32bit-win= Specify yes for a 32-bit build on Windows" + exit $exit_val +fi + +if check_define __ANDROID__ ; then + targetos="Android" +elif check_define __linux__ ; then targetos="Linux" elif check_define __OpenBSD__ ; then targetos='OpenBSD' @@ -151,22 +197,43 @@ SunOS) CYGWIN*) echo "Forcing known good options on Windows" if test -z "$CC" ; then - CC="x86_64-w64-mingw32-gcc" + if test ! -z "$build_32bit_win" && test "$build_32bit_win" = "yes"; then + CC="i686-w64-mingw32-gcc" + else + CC="x86_64-w64-mingw32-gcc" + fi fi - echo "CC=$CC" > $config_host_mak - echo "CONFIG_LITTLE_ENDIAN=y" >> $config_host_mak - echo "CONFIG_64BIT_LLP64=y" >> $config_host_mak - echo "CONFIG_CLOCK_GETTIME=y" >> $config_host_mak - echo "CONFIG_CLOCK_MONOTONIC=y" >> $config_host_mak - echo "CONFIG_GETTIMEOFDAY=y" >> $config_host_mak - echo "CONFIG_FADVISE=y" >> $config_host_mak - echo "CONFIG_SOCKLEN_T=y" >> $config_host_mak - echo "CONFIG_POSIX_FALLOCATE=y" >> $config_host_mak - echo "CONFIG_FADVISE=y" >> $config_host_mak - echo "CONFIG_SFAA=y" >> $config_host_mak - echo "CONFIG_RUSAGE_THREAD=y" >> $config_host_mak - echo "CONFIG_WINDOWSAIO=y" >> $config_host_mak - echo "CONFIG_FDATASYNC=y" >> $config_host_mak + output_sym "CONFIG_LITTLE_ENDIAN" + if test ! -z "$build_32bit_win" && test "$build_32bit_win" = "yes"; then + output_sym "CONFIG_32BIT" + else + output_sym "CONFIG_64BIT_LLP64" + fi + output_sym "CONFIG_FADVISE" + output_sym "CONFIG_SOCKLEN_T" + output_sym "CONFIG_FADVISE" + output_sym "CONFIG_SFAA" + output_sym "CONFIG_RUSAGE_THREAD" + output_sym "CONFIG_WINDOWSAIO" + output_sym "CONFIG_FDATASYNC" + output_sym "CONFIG_CLOCK_MONOTONIC" + output_sym "CONFIG_GETTIMEOFDAY" + output_sym "CONFIG_CLOCK_GETTIME" + output_sym "CONFIG_SCHED_IDLE" + output_sym "CONFIG_TCP_NODELAY" + echo "CC=$CC" >> $config_host_mak + echo "EXTFLAGS=$CFLAGS -include config-host.h -D_GNU_SOURCE" >> $config_host_mak + exit 0 + ;; +Android) + output_sym "CONFIG_32BIT" + output_sym "CONFIG_LITTLE_ENDIAN" + output_sym "CONFIG_SOCKLEN_T" + output_sym "CONFIG_GETTIMEOFDAY" + output_sym "CONFIG_CLOCK_GETTIME" + output_sym "CONFIG_CLOCK_MONOTONIC" + echo "CC=$cc" >> $config_host_mak + echo "EXTFLAGS=$CFLAGS -include config-host.h -DFIO_NO_HAVE_SHM_H -D_GNU_SOURCE" >> $config_host_mak exit 0 esac @@ -231,12 +298,11 @@ case "$cpu" in cpu="sparc" ;; *) - echo "Unknown CPU" - exit 1; + echo "Unknown CPU" ;; esac -if test -z $CC; then +if test -z "$CC" ; then if test "$targetos" = "FreeBSD"; then if has clang; then CC=clang @@ -283,7 +349,7 @@ int main(void) } EOF if compile_prog "" "" "wordsize"; then - wordsize=$($TMPE) + wordsize=`$TMPE` fi echo "Wordsize $wordsize" @@ -809,6 +875,40 @@ if compile_prog "" "" "RUSAGE_THREAD"; then fi echo "RUSAGE_THREAD $rusage_thread" +########################################## +# Check whether we have SCHED_IDLE +sched_idle="no" +cat > $TMPC << EOF +#include +int main(int argc, char **argv) +{ + struct sched_param p; + return sched_setscheduler(0, SCHED_IDLE, &p); +} +EOF +if compile_prog "" "" "SCHED_IDLE"; then + sched_idle="yes" +fi +echo "SCHED_IDLE $sched_idle" + +########################################## +# Check whether we have TCP_NODELAY +tcp_nodelay="no" +cat > $TMPC << EOF +#include +#include +#include +#include +int main(int argc, char **argv) +{ + return getsockopt(0, 0, TCP_NODELAY, NULL, NULL); +} +EOF +if compile_prog "" "" "TCP_NODELAY"; then + tcp_nodelay="yes" +fi +echo "TCP_NODELAY $tcp_nodelay" + ############################################################################# echo "# Automatically generated by configure - do not modify" > $config_host_mak @@ -817,102 +917,107 @@ printf " '%s'" "$0" "$@" >> $config_host_mak echo >> $config_host_mak if test "$wordsize" = "64" ; then - echo "CONFIG_64BIT=y" >> $config_host_mak + output_sym "CONFIG_64BIT" elif test "$wordsize" = "32" ; then - echo "CONFIG_32BIT=y" >> $config_host_mak + output_sym "CONFIG_32BIT" else - echo "Unknown wordsize!" - exit 1 + fatal "Unknown wordsize!" fi if test "$bigendian" = "yes" ; then - echo "CONFIG_BIG_ENDIAN=y" >> $config_host_mak + output_sym "CONFIG_BIG_ENDIAN" else - echo "CONFIG_LITTLE_ENDIAN=y" >> $config_host_mak + output_sym "CONFIG_LITTLE_ENDIAN" fi if test "$libaio" = "yes" ; then - echo "CONFIG_LIBAIO=y" >> $config_host_mak + output_sym "CONFIG_LIBAIO" fi if test "$posix_aio" = "yes" ; then - echo "CONFIG_POSIXAIO=y" >> $config_host_mak + output_sym "CONFIG_POSIXAIO" fi if test "$posix_aio_fsync" = "yes" ; then - echo "CONFIG_POSIXAIO_FSYNC=y" >> $config_host_mak + output_sym "CONFIG_POSIXAIO_FSYNC" fi if test "$linux_fallocate" = "yes" ; then - echo "CONFIG_LINUX_FALLOCATE=y" >> $config_host_mak + output_sym "CONFIG_LINUX_FALLOCATE" fi if test "$posix_fallocate" = "yes" ; then - echo "CONFIG_POSIX_FALLOCATE=y" >> $config_host_mak + output_sym "CONFIG_POSIX_FALLOCATE" fi if test "$fdatasync" = "yes" ; then - echo "CONFIG_FDATASYNC=y" >> $config_host_mak + output_sym "CONFIG_FDATASYNC" fi if test "$sync_file_range" = "yes" ; then - echo "CONFIG_SYNC_FILE_RANGE=y" >> $config_host_mak + output_sym "CONFIG_SYNC_FILE_RANGE" fi if test "$sfaa" = "yes" ; then - echo "CONFIG_SFAA=y" >> $config_host_mak + output_sym "CONFIG_SFAA" fi if test "$libverbs" = "yes" -o "rdmacm" = "yes" ; then - echo "CONFIG_RDMA=y" >> $config_host_mak + output_sym "CONFIG_RDMA" fi if test "$clock_gettime" = "yes" ; then - echo "CONFIG_CLOCK_GETTIME=y" >> $config_host_mak + output_sym "CONFIG_CLOCK_GETTIME" fi if test "$clock_monotonic" = "yes" ; then - echo "CONFIG_CLOCK_MONOTONIC=y" >> $config_host_mak + output_sym "CONFIG_CLOCK_MONOTONIC" fi if test "$clock_monotonic_precise" = "yes" ; then - echo "CONFIG_CLOCK_MONOTONIC_PRECISE=y" >> $config_host_mak + output_sym "CONFIG_CLOCK_MONOTONIC_PRECISE" fi if test "$gettimeofday" = "yes" ; then - echo "CONFIG_GETTIMEOFDAY=y" >> $config_host_mak + output_sym "CONFIG_GETTIMEOFDAY" fi if test "$posix_fadvise" = "yes" ; then - echo "CONFIG_POSIX_FADVISE=y" >> $config_host_mak + output_sym "CONFIG_POSIX_FADVISE" fi if test "$linux_3arg_affinity" = "yes" ; then - echo "CONFIG_3ARG_AFFINITY=y" >> $config_host_mak + output_sym "CONFIG_3ARG_AFFINITY" elif test "$linux_2arg_affinity" = "yes" ; then - echo "CONFIG_2ARG_AFFINITY=y" >> $config_host_mak + output_sym "CONFIG_2ARG_AFFINITY" fi if test "$strsep" = "yes" ; then - echo "CONFIG_STRSEP=y" >> $config_host_mak + output_sym "CONFIG_STRSEP" fi if test "$getopt_long_only" = "yes" ; then - echo "CONFIG_GETOPT_LONG_ONLY=y" >> $config_host_mak + output_sym "CONFIG_GETOPT_LONG_ONLY" fi if test "$inet_aton" = "yes" ; then - echo "CONFIG_INET_ATON=y" >> $config_host_mak + output_sym "CONFIG_INET_ATON" fi if test "$socklen_t" = "yes" ; then - echo "CONFIG_SOCKLEN_T=y" >> $config_host_mak + output_sym "CONFIG_SOCKLEN_T" fi if test "$ext4_me" = "yes" ; then - echo "CONFIG_LINUX_EXT4_MOVE_EXTENT=y" >> $config_host_mak + output_sym "CONFIG_LINUX_EXT4_MOVE_EXTENT" fi if test "$linux_splice" = "yes" ; then - echo "CONFIG_LINUX_SPLICE=y" >> $config_host_mak + output_sym "CONFIG_LINUX_SPLICE" fi if test "$guasi" = "yes" ; then - echo "CONFIG_GUASI=y" >> $config_host_mak + output_sym "CONFIG_GUASI" fi if test "$fusion_aw" = "yes" ; then - echo "CONFIG_FUSION_AW=y" >> $config_host_mak + output_sym "CONFIG_FUSION_AW" fi if test "$libnuma" = "yes" ; then - echo "CONFIG_LIBNUMA=y" >> $config_host_mak + output_sym "CONFIG_LIBNUMA" fi if test "$solaris_aio" = "yes" ; then - echo "CONFIG_SOLARISAIO=y" >> $config_host_mak + output_sym "CONFIG_SOLARISAIO" fi if test "$tls_thread" = "yes" ; then - echo "CONFIG_TLS_THREAD=y" >> $config_host_mak + output_sym "CONFIG_TLS_THREAD" fi if test "$rusage_thread" = "yes" ; then - echo "CONFIG_RUSAGE_THREAD=y" >> $config_host_mak + output_sym "CONFIG_RUSAGE_THREAD" +fi +if test "$sched_idle" = "yes" ; then + output_sym "CONFIG_SCHED_IDLE" +fi +if test "$tcp_nodelay" = "yes" ; then + output_sym "CONFIG_TCP_NODELAY" fi echo "LIBS+=$LIBS" >> $config_host_mak echo "CC=$cc" >> $config_host_mak -echo "CFLAGS=$CFLAGS" >> $config_host_mak +echo "EXTFLAGS=$EXTFLAGS $CFLAGS" >> $config_host_mak