X-Git-Url: https://git.kernel.dk/?p=fio.git;a=blobdiff_plain;f=configure;h=0a404d00e2241520d6567cceac6b64cf0d6eb109;hp=c9932b570629850c4f08f5d1ab5d025e7f49dac8;hb=4feafb1e7864b736e1bfe83fe185fbba933b1c60;hpb=c11a9ddfb9a53f9faa78b72fc79be2f46addc8aa;ds=sidebyside diff --git a/configure b/configure index c9932b57..0a404d00 100755 --- a/configure +++ b/configure @@ -24,7 +24,13 @@ 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 + +# Default CFLAGS +EXTFLAGS="-include config-host.h -D_GNU_SOURCE" # Print a helpful header at the top of config.log echo "# FIO configure log $(date)" >> config.log @@ -97,27 +103,30 @@ EOF compile_object } +output_sym() { + echo "$1=y" >> $config_host_mak + echo "#define $1" >> $config_host_h +} + targetos="" cpu="" cc="${CC-${cross_prefix}gcc}" +# parse options +for opt do + optarg=`expr "x$opt" : 'x[^=]*=\(.*\)'` + case "$opt" in + --cc=*) CC="$optarg" + ;; + *) + echo "Bad option $opt" + exit 1 + esac +done + if check_define __linux__ ; then targetos="Linux" -elif test `uname -o` = Cygwin ; then - echo "Forcing known good options on Windows" - echo "CC=x86_64-w64-mingw32-gcc" >> $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_STRSEP=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 - exit 0 elif check_define __OpenBSD__ ; then targetos='OpenBSD' elif check_define __sun__ ; then @@ -146,6 +155,27 @@ SunOS) if test -z "$cpu" && test "$(isainfo -k)" = "amd64"; then cpu="x86_64" fi + ;; +CYGWIN*) + echo "Forcing known good options on Windows" + if test -z "$CC" ; then + CC="x86_64-w64-mingw32-gcc" + fi + output_sym "CONFIG_LITTLE_ENDIAN" + output_sym "CONFIG_64BIT_LLP64" + output_sym "CONFIG_CLOCK_GETTIME" + output_sym "CONFIG_CLOCK_MONOTONIC" + output_sym "CONFIG_GETTIMEOFDAY" + output_sym "CONFIG_FADVISE" + output_sym "CONFIG_SOCKLEN_T" + output_sym "CONFIG_POSIX_FALLOCATE" + output_sym "CONFIG_FADVISE" + output_sym "CONFIG_SFAA" + output_sym "CONFIG_RUSAGE_THREAD" + output_sym "CONFIG_WINDOWSAIO" + output_sym "CONFIG_FDATASYNC" + echo "CC=$CC" >> $config_host_mak + exit 0 esac if test ! -z "$cpu" ; then @@ -226,8 +256,25 @@ fi cc="${CC-${cross_prefix}gcc}" +########################################## +# check endianness +bigendian="no" +cat > $TMPC < +int main(void) +{ + volatile uint32_t i=0x01234567; + return (*((uint8_t*)(&i))) == 0x67; +} +EOF +if compile_prog "" "" "endian"; then + $TMPE && bigendian="yes" +fi + + echo "Operating system $targetos" echo "CPU $cpu" +echo "Big endian $bigendian" echo "Compiler $cc" echo @@ -447,7 +494,6 @@ echo "POSIX fallocate $posix_fallocate" linux_2arg_affinity="no" linux_3arg_affinity="no" cat > $TMPC << EOF -#define _GNU_SOURCE #include int main(int argc, char **argv) { @@ -459,7 +505,6 @@ if compile_prog "" "" "sched_setaffinity(,,)"; then linux_3arg_affinity="yes" else cat > $TMPC << EOF -#define _GNU_SOURCE #include int main(int argc, char **argv) { @@ -568,7 +613,6 @@ sync_file_range="no" cat > $TMPC << EOF #include #include -#define _GNU_SOURCE #include #include int main(int argc, char **argv) @@ -609,7 +653,6 @@ echo "EXT4 move extent $ext4_me" # splice probe linux_splice="no" cat > $TMPC << EOF -#define _GNU_SOURCE #include #include int main(int argc, char **argv) @@ -643,14 +686,15 @@ echo "GUASI $guasi" # fusion-aw probe fusion_aw="no" cat > $TMPC << EOF -#include +#include int main(int argc, char **argv) { struct vsl_iovec iov; return vsl_vectored_write(0, &iov, 0, O_ATOMIC); } EOF -if compile_prog "" "-lvsldpexp" "fusion-aw"; then +if compile_prog "" "-L/usr/lib/fio -lnvm-primitives" "fusion-aw"; then + LIBS="-L/usr/lib/fio -lnvm-primitives $LIBS" fusion_aw="yes" fi echo "Fusion-io atomic engine $fusion_aw" @@ -755,6 +799,24 @@ if compile_prog "" "" "__thread"; then fi echo "__thread $tls_thread" +########################################## +# Check whether we have getrusage(RUSAGE_THREAD) +rusage_thread="no" +cat > $TMPC << EOF +#include +#include +int main(int argc, char **argv) +{ + struct rusage ru; + getrusage(RUSAGE_THREAD, &ru); + return 0; +} +EOF +if compile_prog "" "" "RUSAGE_THREAD"; then + rusage_thread="yes" +fi +echo "RUSAGE_THREAD $rusage_thread" + ############################################################################# echo "# Automatically generated by configure - do not modify" > $config_host_mak @@ -763,93 +825,102 @@ 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 fi +if test "$bigendian" = "yes" ; then + output_sym "CONFIG_BIG_ENDIAN" +else + 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 + output_sym "CONFIG_RUSAGE_THREAD" fi echo "LIBS+=$LIBS" >> $config_host_mak echo "CC=$cc" >> $config_host_mak +echo "EXTFLAGS=$EXTFLAGS" >> $config_host_mak