diff options
author | Wolfgang Mauerer <wolfgang.mauerer@siemens.com> | 2011-07-11 14:57:43 +0200 |
---|---|---|
committer | Stefan Hajnoczi <stefanha@linux.vnet.ibm.com> | 2011-07-27 08:58:56 +0100 |
commit | 023367e6cd41199521613674b44e9c703c8be1a1 (patch) | |
tree | b5d4a0a8ee283843b534fbe3f6eae05b02052a28 /configure | |
parent | c886edfb851c0c590d4e77f058f2ec8ed95ad1b5 (diff) | |
download | qemu-023367e6cd41199521613674b44e9c703c8be1a1.zip qemu-023367e6cd41199521613674b44e9c703c8be1a1.tar.gz qemu-023367e6cd41199521613674b44e9c703c8be1a1.tar.bz2 |
vhost build fix for i386
vhost.c uses __sync_fetch_and_and(), which is only
available for -march=i486 and above (see
https://bugzilla.redhat.com/show_bug.cgi?id=624279).
Signed-off-by: Wolfgang Mauerer <wolfgang.mauerer@siemens.com>
Signed-off-by: Stefan Hajnoczi <stefanha@linux.vnet.ibm.com>
Diffstat (limited to 'configure')
-rwxr-xr-x | configure | 23 |
1 files changed, 23 insertions, 0 deletions
@@ -2510,6 +2510,29 @@ if test "$trace_backend" = "dtrace"; then fi ########################################## +# __sync_fetch_and_and requires at least -march=i486. Many toolchains +# use i686 as default anyway, but for those that don't, an explicit +# specification is necessary +if test $vhost_net = "yes" && test $cpu = "i386"; then + cat > $TMPC << EOF +int sfaa(unsigned *ptr) +{ + return __sync_fetch_and_and(ptr, 0); +} + +int main(int argc, char **argv) +{ + int val = 42; + sfaa(&val); + return val; +} +EOF + if ! compile_prog "" "" ; then + CFLAGS+="-march=i486" + fi +fi + +########################################## # End of CC checks # After here, no more $cc or $ld runs |