meson: allow configuring the x86-64 baseline
Add a Meson option to configure which x86-64 instruction set to use. QEMU will now default to x86-64-v1 + cmpxchg16b for 64-bit builds (that corresponds to a Pentium 4 for 32-bit builds). The baseline can be tuned down to Pentium Pro for 32-bit builds (with -Dx86_version=0), or up as desired. Acked-by: Richard Henderson <richard.henderson@linaro.org> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
parent
87b8bde55d
commit
ef7d1adfa8
41
meson.build
41
meson.build
@ -336,15 +336,40 @@ if host_arch == 'i386' and not cc.links('''
|
|||||||
qemu_common_flags = ['-march=i486'] + qemu_common_flags
|
qemu_common_flags = ['-march=i486'] + qemu_common_flags
|
||||||
endif
|
endif
|
||||||
|
|
||||||
# Assume x86-64-v2 (minus CMPXCHG16B for 32-bit code)
|
# Pick x86-64 baseline version
|
||||||
if host_arch == 'i386'
|
|
||||||
qemu_common_flags = ['-mfpmath=sse'] + qemu_common_flags
|
|
||||||
endif
|
|
||||||
if host_arch in ['i386', 'x86_64']
|
if host_arch in ['i386', 'x86_64']
|
||||||
qemu_common_flags = ['-mpopcnt', '-msse4.2'] + qemu_common_flags
|
if get_option('x86_version') == '0' and host_arch == 'x86_64'
|
||||||
endif
|
error('x86_64-v1 required for x86-64 hosts')
|
||||||
if host_arch == 'x86_64'
|
endif
|
||||||
qemu_common_flags = ['-mcx16'] + qemu_common_flags
|
|
||||||
|
# add flags for individual instruction set extensions
|
||||||
|
if get_option('x86_version') >= '1'
|
||||||
|
if host_arch == 'i386'
|
||||||
|
qemu_common_flags = ['-mfpmath=sse'] + qemu_common_flags
|
||||||
|
else
|
||||||
|
# present on basically all processors but technically not part of
|
||||||
|
# x86-64-v1, so only include -mneeded for x86-64 version 2 and above
|
||||||
|
qemu_common_flags = ['-mcx16'] + qemu_common_flags
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
if get_option('x86_version') >= '2'
|
||||||
|
qemu_common_flags = ['-mpopcnt'] + qemu_common_flags
|
||||||
|
qemu_common_flags = cc.get_supported_arguments('-mneeded') + qemu_common_flags
|
||||||
|
endif
|
||||||
|
if get_option('x86_version') >= '3'
|
||||||
|
qemu_common_flags = ['-mmovbe', '-mabm', '-mbmi1', '-mbmi2', '-mfma', '-mf16c'] + qemu_common_flags
|
||||||
|
endif
|
||||||
|
|
||||||
|
# add required vector instruction set (each level implies those below)
|
||||||
|
if get_option('x86_version') == '1'
|
||||||
|
qemu_common_flags = ['-msse2'] + qemu_common_flags
|
||||||
|
elif get_option('x86_version') == '2'
|
||||||
|
qemu_common_flags = ['-msse4.2'] + qemu_common_flags
|
||||||
|
elif get_option('x86_version') == '3'
|
||||||
|
qemu_common_flags = ['-mavx2'] + qemu_common_flags
|
||||||
|
elif get_option('x86_version') == '4'
|
||||||
|
qemu_common_flags = ['-mavx512f', '-mavx512bw', '-mavx512cd', '-mavx512dq', '-mavx512vl'] + qemu_common_flags
|
||||||
|
endif
|
||||||
endif
|
endif
|
||||||
|
|
||||||
if get_option('prefer_static')
|
if get_option('prefer_static')
|
||||||
|
@ -370,3 +370,6 @@ option('qemu_ga_version', type: 'string', value: '',
|
|||||||
|
|
||||||
option('hexagon_idef_parser', type : 'boolean', value : true,
|
option('hexagon_idef_parser', type : 'boolean', value : true,
|
||||||
description: 'use idef-parser to automatically generate TCG code for the Hexagon frontend')
|
description: 'use idef-parser to automatically generate TCG code for the Hexagon frontend')
|
||||||
|
|
||||||
|
option('x86_version', type : 'combo', choices : ['0', '1', '2', '3', '4'], value: '1',
|
||||||
|
description: 'tweak required x86_64 architecture version beyond compiler default')
|
||||||
|
@ -82,6 +82,8 @@ meson_options_help() {
|
|||||||
printf "%s\n" ' --with-suffix=VALUE Suffix for QEMU data/modules/config directories'
|
printf "%s\n" ' --with-suffix=VALUE Suffix for QEMU data/modules/config directories'
|
||||||
printf "%s\n" ' (can be empty) [qemu]'
|
printf "%s\n" ' (can be empty) [qemu]'
|
||||||
printf "%s\n" ' --with-trace-file=VALUE Trace file prefix for simple backend [trace]'
|
printf "%s\n" ' --with-trace-file=VALUE Trace file prefix for simple backend [trace]'
|
||||||
|
printf "%s\n" ' --x86-version=CHOICE tweak required x86_64 architecture version beyond'
|
||||||
|
printf "%s\n" ' compiler default [1] (choices: 0/1/2/3)'
|
||||||
printf "%s\n" ''
|
printf "%s\n" ''
|
||||||
printf "%s\n" 'Optional features, enabled with --enable-FEATURE and'
|
printf "%s\n" 'Optional features, enabled with --enable-FEATURE and'
|
||||||
printf "%s\n" 'disabled with --disable-FEATURE, default is enabled if available'
|
printf "%s\n" 'disabled with --disable-FEATURE, default is enabled if available'
|
||||||
@ -552,6 +554,7 @@ _meson_option_parse() {
|
|||||||
--disable-werror) printf "%s" -Dwerror=false ;;
|
--disable-werror) printf "%s" -Dwerror=false ;;
|
||||||
--enable-whpx) printf "%s" -Dwhpx=enabled ;;
|
--enable-whpx) printf "%s" -Dwhpx=enabled ;;
|
||||||
--disable-whpx) printf "%s" -Dwhpx=disabled ;;
|
--disable-whpx) printf "%s" -Dwhpx=disabled ;;
|
||||||
|
--x86-version=*) quote_sh "-Dx86_version=$2" ;;
|
||||||
--enable-xen) printf "%s" -Dxen=enabled ;;
|
--enable-xen) printf "%s" -Dxen=enabled ;;
|
||||||
--disable-xen) printf "%s" -Dxen=disabled ;;
|
--disable-xen) printf "%s" -Dxen=disabled ;;
|
||||||
--enable-xen-pci-passthrough) printf "%s" -Dxen_pci_passthrough=enabled ;;
|
--enable-xen-pci-passthrough) printf "%s" -Dxen_pci_passthrough=enabled ;;
|
||||||
|
Loading…
Reference in New Issue
Block a user