Skip to content

Commit

Permalink
configure: detect ifunc and avx2 attribute
Browse files Browse the repository at this point in the history
Detect if the compiler can support the ifun and avx2, if so, set
CONFIG_AVX2_OPT which will be used to turn on the avx2 instruction
optimization.

Suggested-by: Paolo Bonzini <pbonzini@redhat.com>
Suggested-by: Peter Maydell <peter.maydell@linaro.org>
Signed-off-by: Liang Li <liang.z.li@intel.com>
Message-Id: <1457416397-26671-2-git-send-email-liang.z.li@intel.com>
Signed-off-by: Amit Shah <amit.shah@redhat.com>
  • Loading branch information
Liang Li authored and Amit Shah committed Mar 8, 2016
1 parent 614e801 commit 99f2dbd
Showing 1 changed file with 21 additions and 0 deletions.
21 changes: 21 additions & 0 deletions configure
Expand Up @@ -280,6 +280,7 @@ libusb=""
usb_redir=""
opengl=""
opengl_dmabuf="no"
avx2_opt="no"
zlib="yes"
lzo=""
snappy=""
Expand Down Expand Up @@ -1773,6 +1774,21 @@ EOF
fi

##########################################
# avx2 optimization requirement check

cat > $TMPC << EOF
static void bar(void) {}
static void *bar_ifunc(void) {return (void*) bar;}
static void foo(void) __attribute__((ifunc("bar_ifunc")));
int main(void) { foo(); return 0; }
EOF
if compile_prog "-mavx2" "" ; then
if readelf --syms $TMPE |grep "IFUNC.*foo" >/dev/null 2>&1; then
avx2_opt="yes"
fi
fi

#########################################
# zlib check

if test "$zlib" != "no" ; then
Expand Down Expand Up @@ -4790,6 +4806,7 @@ echo "bzip2 support $bzip2"
echo "NUMA host support $numa"
echo "tcmalloc support $tcmalloc"
echo "jemalloc support $jemalloc"
echo "avx2 optimization $avx2_opt"

if test "$sdl_too_old" = "yes"; then
echo "-> Your SDL version is too old - please upgrade to have SDL support"
Expand Down Expand Up @@ -5178,6 +5195,10 @@ if test "$opengl" = "yes" ; then
fi
fi

if test "$avx2_opt" = "yes" ; then
echo "CONFIG_AVX2_OPT=y" >> $config_host_mak
fi

if test "$lzo" = "yes" ; then
echo "CONFIG_LZO=y" >> $config_host_mak
fi
Expand Down

0 comments on commit 99f2dbd

Please sign in to comment.