X-Git-Url: https://git.kernel.dk/?p=fio.git;a=blobdiff_plain;f=configure;h=aaad70e20958129ef8f837411c7b1235f0306f1b;hp=7ce874d75275e22f12997c0151951da6954edb39;hb=e9353e191187bbe8d7f8d29454539af4b2c64008;hpb=b470a02cade02049509d22442addfbc88d10116e diff --git a/configure b/configure index 7ce874d7..aaad70e2 100755 --- a/configure +++ b/configure @@ -133,7 +133,7 @@ cpu="" # default options show_help="no" exit_val=0 -gfio="no" +gfio_check="no" libhdfs="no" # parse options @@ -152,8 +152,10 @@ for opt do ;; --build-32bit-win) build_32bit_win="yes" ;; + --build-static) build_static="yes" + ;; --enable-gfio) - gfio="yes" + gfio_check="yes" ;; --disable-numa) disable_numa="yes" ;; @@ -178,6 +180,7 @@ if test "$show_help" = "yes" ; then echo "--cc= Specify compiler to use" echo "--extra-cflags= Specify extra CFLAGS to pass to compiler" echo "--build-32bit-win Enable 32-bit build on Windows" + echo "--build-static Build a static fio" echo "--esx Configure build options for esx" echo "--enable-gfio Enable building of gtk gfio" echo "--disable-numa Disable libnuma even if found" @@ -399,6 +402,16 @@ echo "Compiler $cc" echo "Cross compile $cross_compile" echo +########################################## +# See if we need to build a static build +if test "$build_static" = "yes" ; then + CFLAGS="$CFLAGS -ffunction-sections -fdata-sections" + LDFLAGS="$LDFLAGS -static -Wl,--gc-sections" +else + build_static="no" +fi +echo "Static build $build_static" + ########################################## # check for wordsize wordsize="0" @@ -982,7 +995,8 @@ echo "__thread $tls_thread" ########################################## # Check if we have required gtk/glib support for gfio -if test "$gfio" = "yes" ; then +gfio="no" +if test "$gfio_check" = "yes" ; then cat > $TMPC << EOF #include #include @@ -1021,7 +1035,9 @@ else fi fi -echo "gtk 2.18 or higher $gfio" +if test "$gfio_check" = "yes" ; then + echo "gtk 2.18 or higher $gfio" +fi # Check whether we have getrusage(RUSAGE_THREAD) rusage_thread="no" @@ -1074,6 +1090,45 @@ if compile_prog "" "" "TCP_NODELAY"; then fi echo "TCP_NODELAY $tcp_nodelay" +########################################## +# Check whether we have SO_SNDBUF +window_size="no" +cat > $TMPC << EOF +#include +#include +#include +#include +int main(int argc, char **argv) +{ + setsockopt(0, SOL_SOCKET, SO_SNDBUF, NULL, 0); + setsockopt(0, SOL_SOCKET, SO_RCVBUF, NULL, 0); +} +EOF +if compile_prog "" "" "SO_SNDBUF"; then + window_size="yes" +fi +echo "Net engine window_size $window_size" + +########################################## +# Check whether we have TCP_MAXSEG +mss="no" +cat > $TMPC << EOF +#include +#include +#include +#include +#include +#include +int main(int argc, char **argv) +{ + return setsockopt(0, IPPROTO_TCP, TCP_MAXSEG, NULL, 0); +} +EOF +if compile_prog "" "" "TCP_MAXSEG"; then + mss="yes" +fi +echo "TCP_MAXSEG $mss" + ########################################## # Check whether we have RLIMIT_MEMLOCK rlimit_memlock="no" @@ -1160,6 +1215,26 @@ if test "$disable_rbd" != "yes" && compile_prog "" "-lrbd -lrados" "rbd"; then fi echo "Rados Block Device engine $rbd" +########################################## +# check for rbd_invaidate_cache() +rbd_inval="no" +if test "$rbd" = "yes"; then +cat > $TMPC << EOF +#include + +int main(int argc, char **argv) +{ + rbd_image_t image; + + return rbd_invalidate_cache(image); +} +EOF +if compile_prog "" "-lrbd -lrados" "rbd"; then + rbd_inval="yes" +fi +echo "rbd_invalidate_cache $rbd_inval" +fi + ########################################## # Check whether we have setvbuf setvbuf="no" @@ -1199,6 +1274,7 @@ fi ########################################## # check for gfapi fadvise support +if test "$gfapi" = "yes" ; then gf_fadvise="no" cat > $TMPC << EOF #include @@ -1211,11 +1287,29 @@ int main(int argc, char **argv) return 0; } EOF - if compile_prog "" "-lgfapi -lglusterfs" "gfapi"; then gf_fadvise="yes" fi echo "Gluster API use fadvise $gf_fadvise" +fi + +########################################## +# check for gfapi trim support +gf_trim="no" +if test "$gfapi" = "yes" ; then +cat > $TMPC << EOF +#include + +int main(int argc, char **argv) +{ + return glfs_discard_async(NULL, 0, 0); +} +EOF +if compile_prog "" "-lgfapi -lglusterfs" "gf trim"; then + gf_trim="yes" +fi +echo "Gluster API trim support $gf_trim" +fi ########################################## # Check if we support stckf on s390 @@ -1272,15 +1366,23 @@ echo "HDFS engine $libhdfs" # Check if we have lex/yacc available yacc="no" +yacc_is_bison="no" lex="no" arith="no" -LEX=$(which lex) +if test "$targetos" != "SunOS" ; then +LEX=$(which lex 2> /dev/null) if test -x "$LEX" ; then lex="yes" fi -YACC=$(which yacc) +YACC=$(which bison 2> /dev/null) if test -x "$YACC" ; then yacc="yes" + yacc_is_bison="yes" +else + YACC=$(which yacc 2> /dev/null) + if test -x "$YACC" ; then + yacc="yes" + fi fi if test "$yacc" = "yes" && test "$lex" = "yes" ; then arith="yes" @@ -1296,13 +1398,13 @@ int main(int argc, char **argv) return 0; } EOF - -if compile_prog "" "-ll -ly" "lex"; then - LIBS="-ll -ly $LIBS" +if compile_prog "" "-ll" "lex"; then + LIBS="-ll $LIBS" else arith="no" fi fi +fi echo "lex/yacc for arithmetic $arith" @@ -1422,6 +1524,12 @@ fi if test "$tcp_nodelay" = "yes" ; then output_sym "CONFIG_TCP_NODELAY" fi +if test "$window_size" = "yes" ; then + output_sym "CONFIG_NET_WINDOWSIZE" +fi +if test "$mss" = "yes" ; then + output_sym "CONFIG_NET_MSS" +fi if test "$rlimit_memlock" = "yes" ; then output_sym "CONFIG_RLIMIT_MEMLOCK" fi @@ -1434,6 +1542,9 @@ fi if test "$rbd" = "yes" ; then output_sym "CONFIG_RBD" fi +if test "$rbd_inval" = "yes" ; then + output_sym "CONFIG_RBD_INVAL" +fi if test "$setvbuf" = "yes" ; then output_sym "CONFIG_SETVBUF" fi @@ -1447,11 +1558,19 @@ fi if test "$gf_fadvise" = "yes" ; then output_sym "CONFIG_GF_FADVISE" fi +if test "$gf_trim" = "yes" ; then + output_sym "CONFIG_GF_TRIM" +fi if test "$libhdfs" = "yes" ; then output_sym "CONFIG_LIBHDFS" fi if test "$arith" = "yes" ; then output_sym "CONFIG_ARITHMETIC" + if test "$yacc_is_bison" = "yes" ; then + echo "YACC=$YACC -y" >> $config_host_mak + else + echo "YACC=$YACC" >> $config_host_mak + fi fi if test "$zlib" = "no" ; then @@ -1460,5 +1579,6 @@ fi echo "LIBS+=$LIBS" >> $config_host_mak echo "CFLAGS+=$CFLAGS" >> $config_host_mak +echo "LDFLAGS+=$LDFLAGS" >> $config_host_mak echo "CC=$cc" >> $config_host_mak echo "BUILD_CFLAGS=$BUILD_CFLAGS $CFLAGS" >> $config_host_mak