X-Git-Url: https://git.kernel.dk/?a=blobdiff_plain;f=configure;h=748977525aff99ab77dbd46251596b63e14a8dda;hb=18dc4295f53c83af3feba6861b5bdbaf09d720fe;hp=e5cf34d68a87fbb4c18e8d5c218e5766679eae2c;hpb=2a2743361cf643b9dd2ba3e491da62e7cb83a101;p=fio.git diff --git a/configure b/configure index e5cf34d6..74897752 100755 --- a/configure +++ b/configure @@ -168,7 +168,9 @@ for opt do ;; --enable-libhdfs) libhdfs="yes" ;; - --disable-shm) output_sym "CONFIG_NO_SHM" + --disable-shm) no_shm="yes" + ;; + --disable-optimizations) disable_opt="yes" ;; --help) show_help="yes" @@ -193,6 +195,7 @@ if test "$show_help" = "yes" ; then echo "--disable-gfapi Disable gfapi" echo "--enable-libhdfs Enable hdfs support" echo "--disable-shm Disable SHM support" + echo "--disable-optimizations Don't enable compiler optimizations" exit $exit_val fi @@ -220,6 +223,14 @@ printf " '%s'" "$0" "$@" >> $config_host_mak echo >> $config_host_mak echo "CONFIG_TARGET_OS=$targetos" >> $config_host_mak +if test "$no_shm" = "yes" ; then + output_sym "CONFIG_NO_SHM" +fi + +if test "$disable_opt" = "yes" ; then + output_sym "CONFIG_FIO_NO_OPT" +fi + # Some host OSes need non-standard checks for which CPU to use. # Note that these checks are broken for cross-compilation: if you're # cross-compiling to one of these OSes then you'll need to specify @@ -271,7 +282,6 @@ CYGWIN*) output_sym "CONFIG_TCP_NODELAY" output_sym "CONFIG_TLS_THREAD" output_sym "CONFIG_IPV6" - output_sym "CONFIG_SFA" echo "CC=$CC" >> $config_host_mak echo "BUILD_CFLAGS=$CFLAGS -include config-host.h -D_GNU_SOURCE" >> $config_host_mak exit 0 @@ -548,17 +558,18 @@ fi echo "Solaris AIO support $solaris_aio" ########################################## -# __sync_fetch_and_and test +# __sync_fetch_and_add test sfaa="no" cat > $TMPC << EOF -static int sfaa(int *ptr) +#include +static int sfaa(uint64_t *ptr) { return __sync_fetch_and_add(ptr, 0); } int main(int argc, char **argv) { - int val = 42; + uint64_t val = 42; sfaa(&val); return val; } @@ -928,7 +939,8 @@ cat > $TMPC << EOF #include int main(int argc, char **argv) { - strsep(NULL, NULL); + static char *string = "This is a string"; + strsep(&string, "needle"); return 0; } EOF @@ -952,6 +964,25 @@ if compile_prog "" "" "strcasestr"; then fi echo "strcasestr $strcasestr" +########################################## +# strlcat() probe +strlcat="no" +cat > $TMPC << EOF +#include +int main(int argc, char **argv) +{ + static char dst[64]; + static char *string = "This is a string"; + memset(dst, 0, sizeof(dst)); + strlcat(dst, string, sizeof(dst)); + return 0; +} +EOF +if compile_prog "" "" "strlcat"; then + strlcat="yes" +fi +echo "strlcat $strlcat" + ########################################## # getopt_long_only() probe getopt_long_only="no" @@ -1398,11 +1429,14 @@ echo "HDFS engine $libhdfs" # Check whether we have MTD mtd="no" cat > $TMPC << EOF +#include #include #include int main(int argc, char **argv) { + struct mtd_write_req ops; struct mtd_info_user info; + memset(&ops, 0, sizeof(ops)); info.type = MTD_MLCNANDFLASH; return ioctl(0, MEMGETINFO, &info); } @@ -1466,7 +1500,7 @@ int main(int argc, char **argv) { FILE *mtab = setmntent(NULL, "r"); struct mntent *mnt = getmntent(mtab); - endmntent(mnt); + endmntent(mtab); return 0; } EOF @@ -1494,23 +1528,36 @@ fi echo "getmntinfo $getmntinfo" ########################################## -# Check whether we have __sync_fetch_and_add() -sfa=="no" +# Check whether we have _Static_assert +static_assert="no" cat > $TMPC << EOF -#include +#include #include -#include +#undef offsetof +#ifdef __compiler_offsetof +#define offsetof(TYPE,MEMBER) __compiler_offsetof(TYPE,MEMBER) +#else +#define offsetof(TYPE, MEMBER) ((size_t) &((TYPE *)0)->MEMBER) +#endif + +#define container_of(ptr, type, member) ({ \ + const typeof( ((type *)0)->member ) *__mptr = (ptr); \ + (type *)( (char *)__mptr - offsetof(type,member) );}) + +struct foo { + int a, b; +}; + int main(int argc, char **argv) { - uint64_t dst = 1, src = 3; - __sync_fetch_and_add(&dst, src); + _Static_assert(offsetof(struct foo, a) == 0 , "Check"); + return 0 ; } EOF -if compile_prog "" "" "__sync_fetch_and_add"; then - sfa="yes" +if compile_prog "" "" "static_assert"; then + static_assert="yes" fi -echo "__sync_fetch_and_add $sfa" - +echo "Static Assert $static_assert" ############################################################################# if test "$wordsize" = "64" ; then @@ -1584,6 +1631,9 @@ fi if test "$strcasestr" = "yes" ; then output_sym "CONFIG_STRCASESTR" fi +if test "$strlcat" = "yes" ; then + output_sym "CONFIG_STRLCAT" +fi if test "$getopt_long_only" = "yes" ; then output_sym "CONFIG_GETOPT_LONG_ONLY" fi @@ -1690,8 +1740,8 @@ fi if test "$getmntinfo" = "yes" ; then output_sym "CONFIG_GETMNTINFO" fi -if test "$sfa" = "yes" ; then - output_sym "CONFIG_SFA" +if test "$static_assert" = "yes" ; then + output_sym "CONFIG_STATIC_ASSERT" fi if test "$zlib" = "no" ; then @@ -1705,3 +1755,10 @@ echo "LDFLAGS+=$LDFLAGS" >> $config_host_mak echo "CC=$cc" >> $config_host_mak echo "BUILD_CFLAGS=$BUILD_CFLAGS $CFLAGS" >> $config_host_mak echo "INSTALL_PREFIX=$prefix" >> $config_host_mak + +if [ `dirname $0` != "." -a ! -e Makefile ]; then + cat > Makefile <