From: wanchao.xu Date: Tue, 15 Apr 2025 07:02:02 +0000 (+0800) Subject: Optimize the meson build for qemu-tools package. X-Git-Tag: qemu-tools_5.2^0 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=d7010fe01d40894688ce5a8ed426b23ace15636f;p=tools%2Fqemu-tools.git Optimize the meson build for qemu-tools package. Change-Id: I85a3c35bde7781c2313c940d65adbdc455612f1e Signed-off-by: wanchao.xu --- diff --git a/meson.build b/meson.build index 135b40a1e..fa5257c83 100644 --- a/meson.build +++ b/meson.build @@ -40,65 +40,25 @@ qemu_icondir = get_option('datadir') / 'icons' config_host_data = configuration_data() genh = [] -target_dirs = config_host['TARGET_DIRS'].split() have_user = false have_system = false -foreach target : target_dirs - have_user = have_user or target.endswith('-user') - have_system = have_system or target.endswith('-softmmu') -endforeach have_tools = 'CONFIG_TOOLS' in config_host have_block = have_system or have_tools python = import('python').find_installation() -supported_oses = ['windows', 'freebsd', 'netbsd', 'openbsd', 'darwin', 'sunos', 'linux'] -supported_cpus = ['ppc', 'ppc64', 's390x', 'riscv32', 'riscv64', 'x86', 'x86_64', - 'arm', 'aarch64', 'mips', 'mips64', 'sparc', 'sparc64'] +supported_oses = ['linux'] +supported_cpus = ['riscv64', 'x86', 'x86_64', 'arm', 'aarch64'] cpu = host_machine.cpu_family() targetos = host_machine.system() -if cpu in ['x86', 'x86_64'] - kvm_targets = ['i386-softmmu', 'x86_64-softmmu'] -elif cpu == 'aarch64' - kvm_targets = ['aarch64-softmmu'] -elif cpu == 's390x' - kvm_targets = ['s390x-softmmu'] -elif cpu in ['ppc', 'ppc64'] - kvm_targets = ['ppc-softmmu', 'ppc64-softmmu'] -elif cpu in ['mips', 'mips64'] - kvm_targets = ['mips-softmmu', 'mipsel-softmmu', 'mips64-softmmu', 'mips64el-softmmu'] -else - kvm_targets = [] -endif - -accelerator_targets = { 'CONFIG_KVM': kvm_targets } -if cpu in ['x86', 'x86_64', 'arm', 'aarch64'] - # i368 emulator provides xenpv machine type for multiple architectures - accelerator_targets += { - 'CONFIG_XEN': ['i386-softmmu', 'x86_64-softmmu'], - } -endif -if cpu in ['x86', 'x86_64'] - accelerator_targets += { - 'CONFIG_HAX': ['i386-softmmu', 'x86_64-softmmu'], - 'CONFIG_HVF': ['x86_64-softmmu'], - 'CONFIG_WHPX': ['i386-softmmu', 'x86_64-softmmu'], - } -endif - ################## # Compiler flags # ################## # Specify linker-script with add_project_link_arguments so that it is not placed # within a linker --start-group/--end-group pair -if 'CONFIG_FUZZ' in config_host - add_project_link_arguments(['-Wl,-T,', - (meson.current_source_dir() / 'tests/qtest/fuzz/fork_fuzz.ld')], - native: false, language: ['c', 'cpp', 'objc']) -endif add_project_arguments(config_host['QEMU_CFLAGS'].split(), native: false, language: ['c', 'objc']) @@ -107,42 +67,15 @@ add_project_arguments(config_host['QEMU_CXXFLAGS'].split(), add_project_link_arguments(config_host['QEMU_LDFLAGS'].split(), native: false, language: ['c', 'cpp', 'objc']) -if targetos == 'linux' - add_project_arguments('-isystem', meson.current_source_dir() / 'linux-headers', - '-isystem', 'linux-headers', - language: ['c', 'cpp']) -endif - -if 'CONFIG_TCG_INTERPRETER' in config_host - tcg_arch = 'tci' -elif config_host['ARCH'] == 'sparc64' - tcg_arch = 'sparc' -elif config_host['ARCH'] == 's390x' - tcg_arch = 's390' -elif config_host['ARCH'] in ['x86_64', 'x32'] - tcg_arch = 'i386' -elif config_host['ARCH'] == 'ppc64' - tcg_arch = 'ppc' -elif config_host['ARCH'] in ['riscv32', 'riscv64'] - tcg_arch = 'riscv' -else - tcg_arch = config_host['ARCH'] -endif -add_project_arguments('-iquote', meson.current_source_dir() / 'tcg' / tcg_arch, - '-iquote', '.', +add_project_arguments('-iquote', '.', '-iquote', meson.current_source_dir(), - '-iquote', meson.current_source_dir() / 'accel/tcg', '-iquote', meson.current_source_dir() / 'include', - '-iquote', meson.current_source_dir() / 'disas/libvixl', language: ['c', 'cpp', 'objc']) link_language = meson.get_external_property('link_language', 'cpp') if link_language == 'cpp' add_languages('cpp', required: true, native: false) endif -if host_machine.system() == 'darwin' - add_languages('objc', required: false, native: false) -endif sparse = find_program('cgcc', required: get_option('sparse')) if sparse.found() @@ -164,101 +97,8 @@ endif m = cc.find_library('m', required: false) util = cc.find_library('util', required: false) winmm = [] -socket = [] -version_res = [] coref = [] iokit = [] -emulator_link_args = [] -cocoa = not_found -hvf = not_found -if targetos == 'windows' - socket = cc.find_library('ws2_32') - winmm = cc.find_library('winmm') - - win = import('windows') - version_res = win.compile_resources('version.rc', - depend_files: files('pc-bios/qemu-nsis.ico'), - include_directories: include_directories('.')) -elif targetos == 'darwin' - coref = dependency('appleframeworks', modules: 'CoreFoundation') - iokit = dependency('appleframeworks', modules: 'IOKit') - cocoa = dependency('appleframeworks', modules: 'Cocoa', required: get_option('cocoa')) -elif targetos == 'sunos' - socket = [cc.find_library('socket'), - cc.find_library('nsl'), - cc.find_library('resolv')] -elif targetos == 'haiku' - socket = [cc.find_library('posix_error_mapper'), - cc.find_library('network'), - cc.find_library('bsd')] -elif targetos == 'openbsd' - if not get_option('tcg').disabled() and target_dirs.length() > 0 - # Disable OpenBSD W^X if available - emulator_link_args = cc.get_supported_link_arguments('-Wl,-z,wxneeded') - endif -endif - -accelerators = [] -if not get_option('kvm').disabled() and targetos == 'linux' - accelerators += 'CONFIG_KVM' -endif -if not get_option('xen').disabled() and 'CONFIG_XEN_BACKEND' in config_host - accelerators += 'CONFIG_XEN' - have_xen_pci_passthrough = not get_option('xen_pci_passthrough').disabled() and targetos == 'linux' -else - have_xen_pci_passthrough = false -endif -if not get_option('whpx').disabled() and targetos == 'windows' - if get_option('whpx').enabled() and host_machine.cpu() != 'x86_64' - error('WHPX requires 64-bit host') - elif cc.has_header('WinHvPlatform.h', required: get_option('whpx')) and \ - cc.has_header('WinHvEmulation.h', required: get_option('whpx')) - accelerators += 'CONFIG_WHPX' - endif -endif -if not get_option('hvf').disabled() - hvf = dependency('appleframeworks', modules: 'Hypervisor', - required: get_option('hvf')) - if hvf.found() - accelerators += 'CONFIG_HVF' - endif -endif -if not get_option('hax').disabled() - if get_option('hax').enabled() or targetos in ['windows', 'darwin', 'netbsd'] - accelerators += 'CONFIG_HAX' - endif -endif -if not get_option('tcg').disabled() - if cpu not in supported_cpus - if 'CONFIG_TCG_INTERPRETER' in config_host - warning('Unsupported CPU @0@, will use TCG with TCI (experimental)'.format(cpu)) - else - error('Unsupported CPU @0@, try --enable-tcg-interpreter'.format(cpu)) - endif - endif - accelerators += 'CONFIG_TCG' - config_host += { 'CONFIG_TCG': 'y' } -endif - -if 'CONFIG_KVM' not in accelerators and get_option('kvm').enabled() - error('KVM not available on this platform') -endif -if 'CONFIG_HVF' not in accelerators and get_option('hvf').enabled() - error('HVF not available on this platform') -endif -if 'CONFIG_WHPX' not in accelerators and get_option('whpx').enabled() - error('WHPX not available on this platform') -endif -if not have_xen_pci_passthrough and get_option('xen_pci_passthrough').enabled() - if 'CONFIG_XEN' in accelerators - error('Xen PCI passthrough not available on this platform') - else - error('Xen PCI passthrough requested but Xen not enabled') - endif -endif -if not cocoa.found() and get_option('cocoa').enabled() - error('Cocoa not available on this platform') -endif ################ # Dependencies # @@ -275,39 +115,6 @@ if config_host.has_key('HAVE_GLIB_WITH_SLICE_ALLOCATOR') config_host_data.set('HAVE_GLIB_WITH_SLICE_ALLOCATOR', true) endif -gio = not_found -if 'CONFIG_GIO' in config_host - gio = declare_dependency(compile_args: config_host['GIO_CFLAGS'].split(), - link_args: config_host['GIO_LIBS'].split()) -endif -lttng = not_found -if 'CONFIG_TRACE_UST' in config_host - lttng = declare_dependency(link_args: config_host['LTTNG_UST_LIBS'].split()) -endif -urcubp = not_found -if 'CONFIG_TRACE_UST' in config_host - urcubp = declare_dependency(link_args: config_host['URCU_BP_LIBS'].split()) -endif -gcrypt = not_found -if 'CONFIG_GCRYPT' in config_host - gcrypt = declare_dependency(compile_args: config_host['GCRYPT_CFLAGS'].split(), - link_args: config_host['GCRYPT_LIBS'].split()) -endif -nettle = not_found -if 'CONFIG_NETTLE' in config_host - nettle = declare_dependency(compile_args: config_host['NETTLE_CFLAGS'].split(), - link_args: config_host['NETTLE_LIBS'].split()) -endif -gnutls = not_found -if 'CONFIG_GNUTLS' in config_host - gnutls = declare_dependency(compile_args: config_host['GNUTLS_CFLAGS'].split(), - link_args: config_host['GNUTLS_LIBS'].split()) -endif -pixman = not_found -if have_system or have_tools - pixman = dependency('pixman-1', required: have_system, version:'>=0.21.8', - method: 'pkg-config', static: enable_static) -endif pam = not_found if 'CONFIG_AUTH_PAM' in config_host pam = cc.find_library('pam') @@ -328,43 +135,6 @@ libnfs = not_found if 'CONFIG_LIBNFS' in config_host libnfs = declare_dependency(link_args: config_host['LIBNFS_LIBS'].split()) endif -libattr = not_found -if 'CONFIG_ATTR' in config_host - libattr = declare_dependency(link_args: config_host['LIBATTR_LIBS'].split()) -endif -seccomp = not_found -if 'CONFIG_SECCOMP' in config_host - seccomp = declare_dependency(compile_args: config_host['SECCOMP_CFLAGS'].split(), - link_args: config_host['SECCOMP_LIBS'].split()) -endif -libcap_ng = not_found -if 'CONFIG_LIBCAP_NG' in config_host - libcap_ng = declare_dependency(link_args: config_host['LIBCAP_NG_LIBS'].split()) -endif -if get_option('xkbcommon').auto() and not have_system and not have_tools - xkbcommon = not_found -else - xkbcommon = dependency('xkbcommon', required: get_option('xkbcommon'), - method: 'pkg-config', static: enable_static) -endif -vde = not_found -if config_host.has_key('CONFIG_VDE') - vde = declare_dependency(link_args: config_host['VDE_LIBS'].split()) -endif -pulse = not_found -if 'CONFIG_LIBPULSE' in config_host - pulse = declare_dependency(compile_args: config_host['PULSE_CFLAGS'].split(), - link_args: config_host['PULSE_LIBS'].split()) -endif -alsa = not_found -if 'CONFIG_ALSA' in config_host - alsa = declare_dependency(compile_args: config_host['ALSA_CFLAGS'].split(), - link_args: config_host['ALSA_LIBS'].split()) -endif -jack = not_found -if 'CONFIG_LIBJACK' in config_host - jack = declare_dependency(link_args: config_host['JACK_LIBS'].split()) -endif spice = not_found spice_headers = not_found if 'CONFIG_SPICE' in config_host @@ -372,11 +142,6 @@ if 'CONFIG_SPICE' in config_host link_args: config_host['SPICE_LIBS'].split()) spice_headers = declare_dependency(compile_args: config_host['SPICE_CFLAGS'].split()) endif -rt = cc.find_library('rt', required: false) -libdl = not_found -if 'CONFIG_PLUGIN' in config_host - libdl = cc.find_library('dl', required: true) -endif libiscsi = not_found if 'CONFIG_LIBISCSI' in config_host libiscsi = declare_dependency(compile_args: config_host['LIBISCSI_CFLAGS'].split(), @@ -387,217 +152,11 @@ if 'CONFIG_ZSTD' in config_host zstd = declare_dependency(compile_args: config_host['ZSTD_CFLAGS'].split(), link_args: config_host['ZSTD_LIBS'].split()) endif -gbm = not_found -if 'CONFIG_GBM' in config_host - gbm = declare_dependency(compile_args: config_host['GBM_CFLAGS'].split(), - link_args: config_host['GBM_LIBS'].split()) -endif -virgl = not_found -if 'CONFIG_VIRGL' in config_host - virgl = declare_dependency(compile_args: config_host['VIRGL_CFLAGS'].split(), - link_args: config_host['VIRGL_LIBS'].split()) -endif curl = not_found if 'CONFIG_CURL' in config_host curl = declare_dependency(compile_args: config_host['CURL_CFLAGS'].split(), link_args: config_host['CURL_LIBS'].split()) endif -libudev = not_found -if targetos == 'linux' and (have_system or have_tools) - libudev = dependency('libudev', - required: get_option('libudev'), - static: enable_static) -endif - -mpathlibs = [libudev] -mpathpersist = not_found -mpathpersist_new_api = false -if targetos == 'linux' and have_tools and not get_option('mpath').disabled() - mpath_test_source_new = ''' - #include - #include - unsigned mpath_mx_alloc_len = 1024; - int logsink; - static struct config *multipath_conf; - extern struct udev *udev; - extern struct config *get_multipath_config(void); - extern void put_multipath_config(struct config *conf); - struct udev *udev; - struct config *get_multipath_config(void) { return multipath_conf; } - void put_multipath_config(struct config *conf) { } - int main(void) { - udev = udev_new(); - multipath_conf = mpath_lib_init(); - return 0; - }''' - mpath_test_source_old = ''' - #include - #include - unsigned mpath_mx_alloc_len = 1024; - int logsink; - int main(void) { - struct udev *udev = udev_new(); - mpath_lib_init(udev); - return 0; - }''' - libmpathpersist = cc.find_library('mpathpersist', - required: get_option('mpath'), - static: enable_static) - if libmpathpersist.found() - mpathlibs += libmpathpersist - if enable_static - mpathlibs += cc.find_library('devmapper', - required: get_option('mpath'), - static: enable_static) - endif - mpathlibs += cc.find_library('multipath', - required: get_option('mpath'), - static: enable_static) - foreach lib: mpathlibs - if not lib.found() - mpathlibs = [] - break - endif - endforeach - if mpathlibs.length() == 0 - msg = 'Dependencies missing for libmpathpersist' - elif cc.links(mpath_test_source_new, dependencies: mpathlibs) - mpathpersist = declare_dependency(dependencies: mpathlibs) - mpathpersist_new_api = true - elif cc.links(mpath_test_source_old, dependencies: mpathlibs) - mpathpersist = declare_dependency(dependencies: mpathlibs) - else - msg = 'Cannot detect libmpathpersist API' - endif - if not mpathpersist.found() - if get_option('mpath').enabled() - error(msg) - else - warning(msg + ', disabling') - endif - endif - endif -endif - -iconv = not_found -curses = not_found -if have_system and not get_option('curses').disabled() - curses_test = ''' - #include - #include - #include - int main(void) { - wchar_t wch = L'w'; - setlocale(LC_ALL, ""); - resize_term(0, 0); - addwstr(L"wide chars\n"); - addnwstr(&wch, 1); - add_wch(WACS_DEGREE); - return 0; - }''' - - curses_dep_list = targetos == 'windows' ? ['ncurses', 'ncursesw'] : ['ncursesw'] - foreach curses_dep : curses_dep_list - if not curses.found() - curses = dependency(curses_dep, - required: false, - method: 'pkg-config', - static: enable_static) - endif - endforeach - msg = get_option('curses').enabled() ? 'curses library not found' : '' - if curses.found() - if cc.links(curses_test, dependencies: [curses]) - curses = declare_dependency(compile_args: '-DNCURSES_WIDECHAR', dependencies: [curses]) - else - msg = 'curses package not usable' - curses = not_found - endif - endif - if not curses.found() - curses_compile_args = ['-DNCURSES_WIDECHAR'] - has_curses_h = cc.has_header('curses.h', args: curses_compile_args) - if targetos != 'windows' and not has_curses_h - message('Trying with /usr/include/ncursesw') - curses_compile_args += ['-I/usr/include/ncursesw'] - has_curses_h = cc.has_header('curses.h', args: curses_compile_args) - endif - if has_curses_h - curses_libname_list = (targetos == 'windows' ? ['pdcurses'] : ['ncursesw', 'cursesw']) - foreach curses_libname : curses_libname_list - libcurses = cc.find_library(curses_libname, - required: false, - static: enable_static) - if libcurses.found() - if cc.links(curses_test, args: curses_compile_args, dependencies: libcurses) - curses = declare_dependency(compile_args: curses_compile_args, - dependencies: [libcurses]) - break - else - msg = 'curses library not usable' - endif - endif - endforeach - endif - endif - if not get_option('iconv').disabled() - foreach link_args : [ ['-liconv'], [] ] - # Programs will be linked with glib and this will bring in libiconv on FreeBSD. - # We need to use libiconv if available because mixing libiconv's headers with - # the system libc does not work. - # However, without adding glib to the dependencies -L/usr/local/lib will not be - # included in the command line and libiconv will not be found. - if cc.links(''' - #include - int main(void) { - iconv_t conv = iconv_open("WCHAR_T", "UCS-2"); - return conv != (iconv_t) -1; - }''', args: config_host['GLIB_CFLAGS'].split() + config_host['GLIB_LIBS'].split() + link_args) - iconv = declare_dependency(link_args: link_args, dependencies: glib) - break - endif - endforeach - endif - if curses.found() and not iconv.found() - if get_option('iconv').enabled() - error('iconv not available') - endif - msg = 'iconv required for curses UI but not available' - curses = not_found - endif - if not curses.found() and msg != '' - if get_option('curses').enabled() - error(msg) - else - warning(msg + ', disabling') - endif - endif -endif - -brlapi = not_found -if 'CONFIG_BRLAPI' in config_host - brlapi = declare_dependency(link_args: config_host['BRLAPI_LIBS'].split()) -endif - -sdl = not_found -if have_system - sdl = dependency('sdl2', required: get_option('sdl'), static: enable_static) - sdl_image = not_found -endif -if sdl.found() - # work around 2.0.8 bug - sdl = declare_dependency(compile_args: '-Wno-undef', - dependencies: sdl) - sdl_image = dependency('SDL2_image', required: get_option('sdl_image'), - method: 'pkg-config', static: enable_static) -else - if get_option('sdl_image').enabled() - error('sdl-image required, but SDL was @0@'.format( - get_option('sdl').disabled() ? 'disabled' : 'not found')) - endif - sdl_image = not_found -endif - rbd = not_found if 'CONFIG_RBD' in config_host rbd = declare_dependency(link_args: config_host['RBD_LIBS'].split()) @@ -612,159 +171,6 @@ if 'CONFIG_LIBSSH' in config_host libssh = declare_dependency(compile_args: config_host['LIBSSH_CFLAGS'].split(), link_args: config_host['LIBSSH_LIBS'].split()) endif -libbzip2 = not_found -if 'CONFIG_BZIP2' in config_host - libbzip2 = declare_dependency(link_args: config_host['BZIP2_LIBS'].split()) -endif -liblzfse = not_found -if 'CONFIG_LZFSE' in config_host - liblzfse = declare_dependency(link_args: config_host['LZFSE_LIBS'].split()) -endif -oss = not_found -if 'CONFIG_AUDIO_OSS' in config_host - oss = declare_dependency(link_args: config_host['OSS_LIBS'].split()) -endif -dsound = not_found -if 'CONFIG_AUDIO_DSOUND' in config_host - dsound = declare_dependency(link_args: config_host['DSOUND_LIBS'].split()) -endif -coreaudio = not_found -if 'CONFIG_AUDIO_COREAUDIO' in config_host - coreaudio = declare_dependency(link_args: config_host['COREAUDIO_LIBS'].split()) -endif -opengl = not_found -if 'CONFIG_OPENGL' in config_host - opengl = declare_dependency(compile_args: config_host['OPENGL_CFLAGS'].split(), - link_args: config_host['OPENGL_LIBS'].split()) -endif -gtk = not_found -if 'CONFIG_GTK' in config_host - gtk = declare_dependency(compile_args: config_host['GTK_CFLAGS'].split(), - link_args: config_host['GTK_LIBS'].split()) -endif -vte = not_found -if 'CONFIG_VTE' in config_host - vte = declare_dependency(compile_args: config_host['VTE_CFLAGS'].split(), - link_args: config_host['VTE_LIBS'].split()) -endif -x11 = not_found -if 'CONFIG_X11' in config_host - x11 = declare_dependency(compile_args: config_host['X11_CFLAGS'].split(), - link_args: config_host['X11_LIBS'].split()) -endif -vnc = not_found -png = not_found -jpeg = not_found -sasl = not_found -if get_option('vnc').enabled() - vnc = declare_dependency() # dummy dependency - png = dependency('libpng', required: get_option('vnc_png'), - method: 'pkg-config', static: enable_static) - jpeg = dependency('libjpeg', required: get_option('vnc_jpeg'), - method: 'pkg-config', static: enable_static) - sasl = cc.find_library('sasl2', has_headers: ['sasl/sasl.h'], - required: get_option('vnc_sasl'), - static: enable_static) - if sasl.found() - sasl = declare_dependency(dependencies: sasl, - compile_args: '-DSTRUCT_IOVEC_DEFINED') - endif -endif -snappy = not_found -if 'CONFIG_SNAPPY' in config_host - snappy = declare_dependency(link_args: config_host['SNAPPY_LIBS'].split()) -endif -lzo = not_found -if 'CONFIG_LZO' in config_host - lzo = declare_dependency(link_args: config_host['LZO_LIBS'].split()) -endif -rdma = not_found -if 'CONFIG_RDMA' in config_host - rdma = declare_dependency(link_args: config_host['RDMA_LIBS'].split()) -endif -numa = not_found -if 'CONFIG_NUMA' in config_host - numa = declare_dependency(link_args: config_host['NUMA_LIBS'].split()) -endif -xen = not_found -if 'CONFIG_XEN_BACKEND' in config_host - xen = declare_dependency(compile_args: config_host['XEN_CFLAGS'].split(), - link_args: config_host['XEN_LIBS'].split()) -endif -cacard = not_found -if 'CONFIG_SMARTCARD' in config_host - cacard = declare_dependency(compile_args: config_host['SMARTCARD_CFLAGS'].split(), - link_args: config_host['SMARTCARD_LIBS'].split()) -endif -u2f = not_found -if have_system - u2f = dependency('u2f-emu', required: get_option('u2f'), - method: 'pkg-config', - static: enable_static) -endif -usbredir = not_found -if 'CONFIG_USB_REDIR' in config_host - usbredir = declare_dependency(compile_args: config_host['USB_REDIR_CFLAGS'].split(), - link_args: config_host['USB_REDIR_LIBS'].split()) -endif -libusb = not_found -if 'CONFIG_USB_LIBUSB' in config_host - libusb = declare_dependency(compile_args: config_host['LIBUSB_CFLAGS'].split(), - link_args: config_host['LIBUSB_LIBS'].split()) -endif -libpmem = not_found -if 'CONFIG_LIBPMEM' in config_host - libpmem = declare_dependency(compile_args: config_host['LIBPMEM_CFLAGS'].split(), - link_args: config_host['LIBPMEM_LIBS'].split()) -endif -libdaxctl = not_found -if 'CONFIG_LIBDAXCTL' in config_host - libdaxctl = declare_dependency(link_args: config_host['LIBDAXCTL_LIBS'].split()) -endif -tasn1 = not_found -if 'CONFIG_TASN1' in config_host - tasn1 = declare_dependency(compile_args: config_host['TASN1_CFLAGS'].split(), - link_args: config_host['TASN1_LIBS'].split()) -endif -keyutils = dependency('libkeyutils', required: false, - method: 'pkg-config', static: enable_static) - -has_gettid = cc.has_function('gettid') - -# Malloc tests - -malloc = [] -if get_option('malloc') == 'system' - has_malloc_trim = \ - not get_option('malloc_trim').disabled() and \ - cc.links('''#include - int main(void) { malloc_trim(0); return 0; }''') -else - has_malloc_trim = false - malloc = cc.find_library(get_option('malloc'), required: true) -endif -if not has_malloc_trim and get_option('malloc_trim').enabled() - if get_option('malloc') == 'system' - error('malloc_trim not available on this platform.') - else - error('malloc_trim not available with non-libc memory allocator') - endif -endif - -# Check whether the glibc provides statx() - -statx_test = ''' - #ifndef _GNU_SOURCE - #define _GNU_SOURCE - #endif - #include - int main(void) { - struct statx statxbuf; - statx(0, "", 0, STATX_BASIC_STATS, &statxbuf); - return 0; - }''' - -has_statx = cc.links(statx_test) have_vhost_user_blk_server = (targetos == 'linux' and 'CONFIG_VHOST_USER' in config_host) @@ -796,30 +202,11 @@ config_host_data.set_quoted('CONFIG_QEMU_LOCALSTATEDIR', get_option('prefix') / config_host_data.set_quoted('CONFIG_QEMU_MODDIR', get_option('prefix') / qemu_moddir) config_host_data.set_quoted('CONFIG_SYSCONFDIR', get_option('prefix') / get_option('sysconfdir')) -config_host_data.set('CONFIG_COCOA', cocoa.found()) -config_host_data.set('CONFIG_LIBUDEV', libudev.found()) -config_host_data.set('CONFIG_MPATH', mpathpersist.found()) -config_host_data.set('CONFIG_MPATH_NEW_API', mpathpersist_new_api) -config_host_data.set('CONFIG_CURSES', curses.found()) -config_host_data.set('CONFIG_SDL', sdl.found()) -config_host_data.set('CONFIG_SDL_IMAGE', sdl_image.found()) -config_host_data.set('CONFIG_VHOST_USER_BLK_SERVER', have_vhost_user_blk_server) -config_host_data.set('CONFIG_VNC', vnc.found()) -config_host_data.set('CONFIG_VNC_JPEG', jpeg.found()) -config_host_data.set('CONFIG_VNC_PNG', png.found()) -config_host_data.set('CONFIG_VNC_SASL', sasl.found()) -config_host_data.set('CONFIG_XKBCOMMON', xkbcommon.found()) -config_host_data.set('CONFIG_KEYUTILS', keyutils.found()) -config_host_data.set('CONFIG_GETTID', has_gettid) -config_host_data.set('CONFIG_MALLOC_TRIM', has_malloc_trim) -config_host_data.set('CONFIG_STATX', has_statx) config_host_data.set('QEMU_VERSION', '"@0@"'.format(meson.project_version())) config_host_data.set('QEMU_VERSION_MAJOR', meson.project_version().split('.')[0]) config_host_data.set('QEMU_VERSION_MINOR', meson.project_version().split('.')[1]) config_host_data.set('QEMU_VERSION_MICRO', meson.project_version().split('.')[2]) -config_host_data.set('HAVE_SYS_IOCCOM_H', cc.has_header('sys/ioccom.h')) - ignored = ['CONFIG_QEMU_INTERP_PREFIX'] # actually per-target arrays = ['CONFIG_AUDIO_DRIVERS', 'CONFIG_BDRV_RW_WHITELIST', 'CONFIG_BDRV_RO_WHITELIST'] strings = ['HOST_DSOSUF', 'CONFIG_IASL'] @@ -847,454 +234,14 @@ endforeach # Target configuration # ######################## -minikconf = find_program('scripts/minikconf.py') config_all = {} -config_all_devices = {} -config_all_disas = {} -config_devices_mak_list = [] -config_target = {} -config_devices_h = {} -config_target_h = {} -config_target_mak = {} - -disassemblers = { - 'alpha' : ['CONFIG_ALPHA_DIS'], - 'arm' : ['CONFIG_ARM_DIS'], - 'avr' : ['CONFIG_AVR_DIS'], - 'cris' : ['CONFIG_CRIS_DIS'], - 'hppa' : ['CONFIG_HPPA_DIS'], - 'i386' : ['CONFIG_I386_DIS'], - 'x86_64' : ['CONFIG_I386_DIS'], - 'x32' : ['CONFIG_I386_DIS'], - 'lm32' : ['CONFIG_LM32_DIS'], - 'm68k' : ['CONFIG_M68K_DIS'], - 'microblaze' : ['CONFIG_MICROBLAZE_DIS'], - 'mips' : ['CONFIG_MIPS_DIS'], - 'moxie' : ['CONFIG_MOXIE_DIS'], - 'nios2' : ['CONFIG_NIOS2_DIS'], - 'or1k' : ['CONFIG_OPENRISC_DIS'], - 'ppc' : ['CONFIG_PPC_DIS'], - 'riscv' : ['CONFIG_RISCV_DIS'], - 'rx' : ['CONFIG_RX_DIS'], - 's390' : ['CONFIG_S390_DIS'], - 'sh4' : ['CONFIG_SH4_DIS'], - 'sparc' : ['CONFIG_SPARC_DIS'], - 'xtensa' : ['CONFIG_XTENSA_DIS'], -} -if link_language == 'cpp' - disassemblers += { - 'aarch64' : [ 'CONFIG_ARM_A64_DIS'], - 'arm' : [ 'CONFIG_ARM_DIS', 'CONFIG_ARM_A64_DIS'], - 'mips' : [ 'CONFIG_MIPS_DIS', 'CONFIG_NANOMIPS_DIS'], - } -endif - -kconfig_external_symbols = [ - 'CONFIG_KVM', - 'CONFIG_XEN', - 'CONFIG_TPM', - 'CONFIG_SPICE', - 'CONFIG_IVSHMEM', - 'CONFIG_OPENGL', - 'CONFIG_X11', - 'CONFIG_VHOST_USER', - 'CONFIG_VHOST_VDPA', - 'CONFIG_VHOST_KERNEL', - 'CONFIG_VIRTFS', - 'CONFIG_LINUX', - 'CONFIG_PVRDMA', -] -ignored = [ 'TARGET_XML_FILES', 'TARGET_ABI_DIR', 'TARGET_ARCH' ] - -default_targets = 'CONFIG_DEFAULT_TARGETS' in config_host -actual_target_dirs = [] -fdt_required = [] -foreach target : target_dirs - config_target = { 'TARGET_NAME': target.split('-')[0] } - if target.endswith('linux-user') - if targetos != 'linux' - if default_targets - continue - endif - error('Target @0@ is only available on a Linux host'.format(target)) - endif - config_target += { 'CONFIG_LINUX_USER': 'y' } - elif target.endswith('bsd-user') - if 'CONFIG_BSD' not in config_host - if default_targets - continue - endif - error('Target @0@ is only available on a BSD host'.format(target)) - endif - config_target += { 'CONFIG_BSD_USER': 'y' } - elif target.endswith('softmmu') - config_target += { 'CONFIG_SOFTMMU': 'y' } - endif - if target.endswith('-user') - config_target += { - 'CONFIG_USER_ONLY': 'y', - 'CONFIG_QEMU_INTERP_PREFIX': - config_host['CONFIG_QEMU_INTERP_PREFIX'].format(config_target['TARGET_NAME']) - } - endif - - have_accel = false - foreach sym: accelerators - if sym == 'CONFIG_TCG' or target in accelerator_targets.get(sym, []) - config_target += { sym: 'y' } - config_all += { sym: 'y' } - if sym == 'CONFIG_XEN' and have_xen_pci_passthrough - config_target += { 'CONFIG_XEN_PCI_PASSTHROUGH': 'y' } - endif - have_accel = true - endif - endforeach - if not have_accel - if default_targets - continue - endif - error('No accelerator available for target @0@'.format(target)) - endif - - actual_target_dirs += target - config_target += keyval.load('default-configs/targets' / target + '.mak') - config_target += { 'TARGET_' + config_target['TARGET_ARCH'].to_upper(): 'y' } - - if 'TARGET_NEED_FDT' in config_target - fdt_required += target - endif - - # Add default keys - if 'TARGET_BASE_ARCH' not in config_target - config_target += {'TARGET_BASE_ARCH': config_target['TARGET_ARCH']} - endif - if 'TARGET_ABI_DIR' not in config_target - config_target += {'TARGET_ABI_DIR': config_target['TARGET_ARCH']} - endif - - foreach k, v: disassemblers - if config_host['ARCH'].startswith(k) or config_target['TARGET_BASE_ARCH'].startswith(k) - foreach sym: v - config_target += { sym: 'y' } - config_all_disas += { sym: 'y' } - endforeach - endif - endforeach - - config_target_data = configuration_data() - foreach k, v: config_target - if not k.startswith('TARGET_') and not k.startswith('CONFIG_') - # do nothing - elif ignored.contains(k) - # do nothing - elif k == 'TARGET_BASE_ARCH' - # Note that TARGET_BASE_ARCH ends up in config-target.h but it is - # not used to select files from sourcesets. - config_target_data.set('TARGET_' + v.to_upper(), 1) - elif k == 'TARGET_NAME' or k == 'CONFIG_QEMU_INTERP_PREFIX' - config_target_data.set_quoted(k, v) - elif v == 'y' - config_target_data.set(k, 1) - else - config_target_data.set(k, v) - endif - endforeach - config_target_h += {target: configure_file(output: target + '-config-target.h', - configuration: config_target_data)} - - if target.endswith('-softmmu') - base_kconfig = [] - foreach sym : kconfig_external_symbols - if sym in config_target or sym in config_host - base_kconfig += '@0@=y'.format(sym) - endif - endforeach - - config_devices_mak = target + '-config-devices.mak' - config_devices_mak = configure_file( - input: ['default-configs/devices' / target + '.mak', 'Kconfig'], - output: config_devices_mak, - depfile: config_devices_mak + '.d', - capture: true, - command: [minikconf, config_host['CONFIG_MINIKCONF_MODE'], - config_devices_mak, '@DEPFILE@', '@INPUT@', - base_kconfig]) - - config_devices_data = configuration_data() - config_devices = keyval.load(config_devices_mak) - foreach k, v: config_devices - config_devices_data.set(k, 1) - endforeach - config_devices_mak_list += config_devices_mak - config_devices_h += {target: configure_file(output: target + '-config-devices.h', - configuration: config_devices_data)} - config_target += config_devices - config_all_devices += config_devices - endif - config_target_mak += {target: config_target} -endforeach -target_dirs = actual_target_dirs - -# This configuration is used to build files that are shared by -# multiple binaries, and then extracted out of the "common" -# static_library target. -# -# We do not use all_sources()/all_dependencies(), because it would -# build literally all source files, including devices only used by -# targets that are not built for this compilation. The CONFIG_ALL -# pseudo symbol replaces it. - -config_all += config_all_devices config_all += config_host -config_all += config_all_disas config_all += { - 'CONFIG_XEN': config_host.has_key('CONFIG_XEN_BACKEND'), 'CONFIG_SOFTMMU': have_system, 'CONFIG_USER_ONLY': have_user, 'CONFIG_ALL': true, } -############## -# Submodules # -############## - -capstone = not_found -capstone_opt = get_option('capstone') -if capstone_opt in ['enabled', 'auto', 'system'] - have_internal = fs.exists(meson.current_source_dir() / 'capstone/Makefile') - capstone = dependency('capstone', version: '>=4.0', - static: enable_static, method: 'pkg-config', - required: capstone_opt == 'system' or - capstone_opt == 'enabled' and not have_internal) - if capstone.found() - capstone_opt = 'system' - elif have_internal - capstone_opt = 'internal' - else - capstone_opt = 'disabled' - endif -endif -if capstone_opt == 'internal' - capstone_data = configuration_data() - capstone_data.set('CAPSTONE_USE_SYS_DYN_MEM', '1') - - capstone_files = files( - 'capstone/cs.c', - 'capstone/MCInst.c', - 'capstone/MCInstrDesc.c', - 'capstone/MCRegisterInfo.c', - 'capstone/SStream.c', - 'capstone/utils.c' - ) - - if 'CONFIG_ARM_DIS' in config_all_disas - capstone_data.set('CAPSTONE_HAS_ARM', '1') - capstone_files += files( - 'capstone/arch/ARM/ARMDisassembler.c', - 'capstone/arch/ARM/ARMInstPrinter.c', - 'capstone/arch/ARM/ARMMapping.c', - 'capstone/arch/ARM/ARMModule.c' - ) - endif - - # FIXME: This config entry currently depends on a c++ compiler. - # Which is needed for building libvixl, but not for capstone. - if 'CONFIG_ARM_A64_DIS' in config_all_disas - capstone_data.set('CAPSTONE_HAS_ARM64', '1') - capstone_files += files( - 'capstone/arch/AArch64/AArch64BaseInfo.c', - 'capstone/arch/AArch64/AArch64Disassembler.c', - 'capstone/arch/AArch64/AArch64InstPrinter.c', - 'capstone/arch/AArch64/AArch64Mapping.c', - 'capstone/arch/AArch64/AArch64Module.c' - ) - endif - - if 'CONFIG_PPC_DIS' in config_all_disas - capstone_data.set('CAPSTONE_HAS_POWERPC', '1') - capstone_files += files( - 'capstone/arch/PowerPC/PPCDisassembler.c', - 'capstone/arch/PowerPC/PPCInstPrinter.c', - 'capstone/arch/PowerPC/PPCMapping.c', - 'capstone/arch/PowerPC/PPCModule.c' - ) - endif - - if 'CONFIG_S390_DIS' in config_all_disas - capstone_data.set('CAPSTONE_HAS_SYSZ', '1') - capstone_files += files( - 'capstone/arch/SystemZ/SystemZDisassembler.c', - 'capstone/arch/SystemZ/SystemZInstPrinter.c', - 'capstone/arch/SystemZ/SystemZMapping.c', - 'capstone/arch/SystemZ/SystemZModule.c', - 'capstone/arch/SystemZ/SystemZMCTargetDesc.c' - ) - endif - - if 'CONFIG_I386_DIS' in config_all_disas - capstone_data.set('CAPSTONE_HAS_X86', 1) - capstone_files += files( - 'capstone/arch/X86/X86Disassembler.c', - 'capstone/arch/X86/X86DisassemblerDecoder.c', - 'capstone/arch/X86/X86ATTInstPrinter.c', - 'capstone/arch/X86/X86IntelInstPrinter.c', - 'capstone/arch/X86/X86InstPrinterCommon.c', - 'capstone/arch/X86/X86Mapping.c', - 'capstone/arch/X86/X86Module.c' - ) - endif - - configure_file(output: 'capstone-defs.h', configuration: capstone_data) - - capstone_cargs = [ - # FIXME: There does not seem to be a way to completely replace the c_args - # that come from add_project_arguments() -- we can only add to them. - # So: disable all warnings with a big hammer. - '-Wno-error', '-w', - - # Include all configuration defines via a header file, which will wind up - # as a dependency on the object file, and thus changes here will result - # in a rebuild. - '-include', 'capstone-defs.h' - ] - - libcapstone = static_library('capstone', - sources: capstone_files, - c_args: capstone_cargs, - include_directories: 'capstone/include') - capstone = declare_dependency(link_with: libcapstone, - include_directories: 'capstone/include/capstone') -endif - -slirp = not_found -slirp_opt = 'disabled' -if have_system - slirp_opt = get_option('slirp') - if slirp_opt in ['enabled', 'auto', 'system'] - have_internal = fs.exists(meson.current_source_dir() / 'slirp/meson.build') - slirp = dependency('slirp', static: enable_static, - method: 'pkg-config', - required: slirp_opt == 'system' or - slirp_opt == 'enabled' and not have_internal) - if slirp.found() - slirp_opt = 'system' - elif have_internal - slirp_opt = 'internal' - else - slirp_opt = 'disabled' - endif - endif - if slirp_opt == 'internal' - slirp_deps = [] - if targetos == 'windows' - slirp_deps = cc.find_library('iphlpapi') - endif - slirp_conf = configuration_data() - slirp_conf.set('SLIRP_MAJOR_VERSION', meson.project_version().split('.')[0]) - slirp_conf.set('SLIRP_MINOR_VERSION', meson.project_version().split('.')[1]) - slirp_conf.set('SLIRP_MICRO_VERSION', meson.project_version().split('.')[2]) - slirp_conf.set_quoted('SLIRP_VERSION_STRING', meson.project_version()) - slirp_cargs = ['-DG_LOG_DOMAIN="Slirp"'] - slirp_files = [ - 'slirp/src/arp_table.c', - 'slirp/src/bootp.c', - 'slirp/src/cksum.c', - 'slirp/src/dhcpv6.c', - 'slirp/src/dnssearch.c', - 'slirp/src/if.c', - 'slirp/src/ip6_icmp.c', - 'slirp/src/ip6_input.c', - 'slirp/src/ip6_output.c', - 'slirp/src/ip_icmp.c', - 'slirp/src/ip_input.c', - 'slirp/src/ip_output.c', - 'slirp/src/mbuf.c', - 'slirp/src/misc.c', - 'slirp/src/ncsi.c', - 'slirp/src/ndp_table.c', - 'slirp/src/sbuf.c', - 'slirp/src/slirp.c', - 'slirp/src/socket.c', - 'slirp/src/state.c', - 'slirp/src/stream.c', - 'slirp/src/tcp_input.c', - 'slirp/src/tcp_output.c', - 'slirp/src/tcp_subr.c', - 'slirp/src/tcp_timer.c', - 'slirp/src/tftp.c', - 'slirp/src/udp.c', - 'slirp/src/udp6.c', - 'slirp/src/util.c', - 'slirp/src/version.c', - 'slirp/src/vmstate.c', - ] - - configure_file( - input : 'slirp/src/libslirp-version.h.in', - output : 'libslirp-version.h', - configuration: slirp_conf) - - slirp_inc = include_directories('slirp', 'slirp/src') - libslirp = static_library('slirp', - sources: slirp_files, - c_args: slirp_cargs, - include_directories: slirp_inc) - slirp = declare_dependency(link_with: libslirp, - dependencies: slirp_deps, - include_directories: slirp_inc) - endif -endif - -fdt = not_found -fdt_opt = get_option('fdt') -if have_system - if fdt_opt in ['enabled', 'auto', 'system'] - have_internal = fs.exists(meson.current_source_dir() / 'dtc/libfdt/Makefile.libfdt') - fdt = cc.find_library('fdt', static: enable_static, - required: fdt_opt == 'system' or - fdt_opt == 'enabled' and not have_internal) - if fdt.found() and cc.links(''' - #include - #include - int main(void) { fdt_check_full(NULL, 0); return 0; }''', - dependencies: fdt) - fdt_opt = 'system' - elif have_internal - fdt_opt = 'internal' - else - fdt_opt = 'disabled' - endif - endif - if fdt_opt == 'internal' - fdt_files = files( - 'dtc/libfdt/fdt.c', - 'dtc/libfdt/fdt_ro.c', - 'dtc/libfdt/fdt_wip.c', - 'dtc/libfdt/fdt_sw.c', - 'dtc/libfdt/fdt_rw.c', - 'dtc/libfdt/fdt_strerror.c', - 'dtc/libfdt/fdt_empty_tree.c', - 'dtc/libfdt/fdt_addresses.c', - 'dtc/libfdt/fdt_overlay.c', - 'dtc/libfdt/fdt_check.c', - ) - - fdt_inc = include_directories('dtc/libfdt') - libfdt = static_library('fdt', - sources: fdt_files, - include_directories: fdt_inc) - fdt = declare_dependency(link_with: libfdt, - include_directories: fdt_inc) - endif -endif -if not fdt.found() and fdt_required.length() > 0 - error('fdt not available but required by targets ' + ', '.join(fdt_required)) -endif - -config_host_data.set('CONFIG_CAPSTONE', capstone.found()) -config_host_data.set('CONFIG_FDT', fdt.found()) -config_host_data.set('CONFIG_SLIRP', slirp.found()) - ##################### # Generated sources # ##################### @@ -1365,26 +312,17 @@ genh += hxdep authz_ss = ss.source_set() blockdev_ss = ss.source_set() block_ss = ss.source_set() -bsd_user_ss = ss.source_set() -chardev_ss = ss.source_set() -common_ss = ss.source_set() crypto_ss = ss.source_set() io_ss = ss.source_set() -linux_user_ss = ss.source_set() qmp_ss = ss.source_set() qom_ss = ss.source_set() softmmu_ss = ss.source_set() -specific_fuzz_ss = ss.source_set() specific_ss = ss.source_set() stub_ss = ss.source_set() trace_ss = ss.source_set() -user_ss = ss.source_set() util_ss = ss.source_set() modules = {} -hw_arch = {} -target_arch = {} -target_softmmu_arch = {} ############### # Trace files # @@ -1393,14 +331,10 @@ target_softmmu_arch = {} # TODO: add each directory to the subdirs from its own meson.build, once # we have those trace_events_subdirs = [ -# 'accel/kvm', -# 'accel/tcg', 'crypto', 'monitor', ] -if have_user - trace_events_subdirs += [ 'linux-user' ] -endif + if have_block trace_events_subdirs += [ 'authz', @@ -1410,79 +344,13 @@ if have_block 'scsi', ] endif -if have_system - trace_events_subdirs += [ - 'audio', - 'backends', - 'backends/tpm', - 'chardev', - 'hw/9pfs', - 'hw/acpi', - 'hw/alpha', - 'hw/arm', - 'hw/audio', - 'hw/block', - 'hw/block/dataplane', - 'hw/char', - 'hw/display', - 'hw/dma', - 'hw/hppa', - 'hw/hyperv', - 'hw/i2c', - 'hw/i386', - 'hw/i386/xen', - 'hw/ide', - 'hw/input', - 'hw/intc', - 'hw/isa', - 'hw/mem', - 'hw/mips', - 'hw/misc', - 'hw/misc/macio', - 'hw/net', - 'hw/nvram', - 'hw/pci', - 'hw/pci-host', - 'hw/ppc', - 'hw/rdma', - 'hw/rdma/vmw', - 'hw/rtc', - 'hw/s390x', - 'hw/scsi', - 'hw/sd', - 'hw/sparc', - 'hw/sparc64', - 'hw/ssi', - 'hw/timer', - 'hw/tpm', - 'hw/usb', - 'hw/vfio', - 'hw/virtio', - 'hw/watchdog', - 'hw/xen', - 'hw/gpio', - 'migration', - 'net', - 'softmmu', - 'ui', - ] -endif + trace_events_subdirs += [ -# 'hw/core', 'qapi', 'qom', -# 'target/arm', -# 'target/hppa', -# 'target/i386', -# 'target/mips', -# 'target/ppc', -# 'target/riscv', -# 'target/s390x', -# 'target/sparc', 'util', ] -#subdir('contrib/libvhost-user') subdir('qapi') subdir('qobject') subdir('stubs') @@ -1491,13 +359,6 @@ subdir('util') subdir('qom') subdir('authz') subdir('crypto') -#subdir('ui') - - -if enable_modules - libmodulecommon = static_library('module-common', files('module-common.c') + genh, pic: true, c_args: '-DBUILD_DSO') - modulecommon = declare_dependency(link_whole: libmodulecommon, compile_args: '-DBUILD_DSO') -endif stub_ss = stub_ss.apply(config_all, strict: false) @@ -1505,21 +366,11 @@ util_ss.add_all(trace_ss) util_ss = util_ss.apply(config_all, strict: false) libqemuutil = static_library('qemuutil', sources: util_ss.sources() + stub_ss.sources() + genh, - dependencies: [util_ss.dependencies(), m, glib, socket, malloc]) + dependencies: [util_ss.dependencies(), m, glib]) qemuutil = declare_dependency(link_with: libqemuutil, - sources: genh + version_res) + sources: genh) -decodetree = generator(find_program('scripts/decodetree.py'), - output: 'decode-@BASENAME@.c.inc', - arguments: ['@INPUT@', '@EXTRA_ARGS@', '-o', '@OUTPUT@']) - -#subdir('audio') subdir('io') -#subdir('chardev') -#subdir('fsdev') -#subdir('libdecnumber') -#subdir('target') -#subdir('dump') block_ss.add(files( 'block.c', @@ -1527,7 +378,6 @@ block_ss.add(files( 'job.c', 'qemu-io-cmds.c', )) -#block_ss.add(when: 'CONFIG_REPLICATION', if_true: files('replication.c')) subdir('nbd') subdir('scsi') @@ -1541,56 +391,15 @@ blockdev_ss.add(files( )) # os-posix.c contains POSIX-specific functions used by qemu-storage-daemon, -# os-win32.c does not blockdev_ss.add(when: 'CONFIG_POSIX', if_true: files('os-posix.c')) -#softmmu_ss.add(when: 'CONFIG_WIN32', if_true: [files('os-win32.c')]) - -#common_ss.add(files('cpus-common.c')) - -#subdir('softmmu') - -#common_ss.add(capstone) -#specific_ss.add(files('cpu.c', 'disas.c', 'gdbstub.c'), capstone) -#specific_ss.add(files('exec-vary.c')) -#specific_ss.add(when: 'CONFIG_TCG', if_true: files( -# 'fpu/softfloat.c', -# 'tcg/optimize.c', -# 'tcg/tcg-common.c', -# 'tcg/tcg-op-gvec.c', -# 'tcg/tcg-op-vec.c', -# 'tcg/tcg-op.c', -# 'tcg/tcg.c', -#)) -#specific_ss.add(when: 'CONFIG_TCG_INTERPRETER', if_true: files('disas/tci.c', 'tcg/tci.c')) - -#subdir('backends') -#subdir('disas') -#subdir('migration') -subdir('monitor') -#subdir('net') -#subdir('replay') -#subdir('hw') -#subdir('accel') -#subdir('plugins') -#subdir('bsd-user') -#subdir('linux-user') - -#bsd_user_ss.add(files('gdbstub.c')) -#specific_ss.add_all(when: 'CONFIG_BSD_USER', if_true: bsd_user_ss) - -#linux_user_ss.add(files('gdbstub.c', 'thunk.c')) -#specific_ss.add_all(when: 'CONFIG_LINUX_USER', if_true: linux_user_ss) -# needed for fuzzing binaries -#subdir('tests/qtest/libqos') -#subdir('tests/qtest/fuzz') +subdir('monitor') ######################## # Library dependencies # ######################## block_mods = [] -softmmu_mods = [] foreach d, list : modules foreach m, module_ss : list if enable_modules and targetos != 'windows' @@ -1599,14 +408,10 @@ foreach d, list : modules dependencies: [modulecommon, module_ss.dependencies()], pic: true) if d == 'block' block_mods += sl - else - softmmu_mods += sl endif else if d == 'block' block_ss.add_all(module_ss) - else - softmmu_ss.add_all(module_ss) endif endif endforeach @@ -1618,10 +423,6 @@ block_syms = custom_target('block.syms', output: 'block.syms', input: [libqemuutil, block_mods], capture: true, command: [undefsym, nm, '@INPUT@']) -qemu_syms = custom_target('qemu.syms', output: 'qemu.syms', - input: [libqemuutil, softmmu_mods], - capture: true, - command: [undefsym, nm, '@INPUT@']) qom_ss = qom_ss.apply(config_host, strict: false) libqom = static_library('qom', qom_ss.sources() + genh, @@ -1657,13 +458,6 @@ libio = static_library('io', io_ss.sources() + genh, io = declare_dependency(link_whole: libio, dependencies: [crypto, qom]) -#libmigration = static_library('migration', sources: migration_files + genh, -# name_suffix: 'fa', -# build_by_default: false) -#migration = declare_dependency(link_with: libmigration, -# dependencies: [zlib, qom, io]) -#softmmu_ss.add(migration) - block_ss = block_ss.apply(config_host, strict: false) libblock = static_library('block', block_ss.sources() + genh, dependencies: block_ss.dependencies(), @@ -1684,31 +478,11 @@ libblockdev = static_library('blockdev', blockdev_ss.sources() + genh, blockdev = declare_dependency(link_whole: [libblockdev], dependencies: [block]) -#qmp_ss = qmp_ss.apply(config_host, strict: false) -#libqmp = static_library('qmp', qmp_ss.sources() + genh, -# dependencies: qmp_ss.dependencies(), -# name_suffix: 'fa', -# build_by_default: false) - -#qmp = declare_dependency(link_whole: [libqmp]) - -#libchardev = static_library('chardev', chardev_ss.sources() + genh, -# name_suffix: 'fa', -# build_by_default: false) - -#chardev = declare_dependency(link_whole: libchardev) - -#libhwcore = static_library('hwcore', sources: hwcore_files + genh, -# name_suffix: 'fa', -# build_by_default: false) -#hwcore = declare_dependency(link_whole: libhwcore) -#common_ss.add(hwcore) - ########### # Targets # ########### -foreach m : block_mods + softmmu_mods +foreach m : block_mods shared_module(m.name(), name_prefix: '', link_whole: m, @@ -1716,201 +490,8 @@ foreach m : block_mods + softmmu_mods install_dir: qemu_moddir) endforeach -#softmmu_ss.add(authz, blockdev, chardev, crypto, io, qmp) -#common_ss.add(qom, qemuutil) - -#common_ss.add_all(when: 'CONFIG_SOFTMMU', if_true: [softmmu_ss]) -#common_ss.add_all(when: 'CONFIG_USER_ONLY', if_true: user_ss) - -#common_all = common_ss.apply(config_all, strict: false) -#common_all = static_library('common', -# build_by_default: false, -# sources: common_all.sources() + genh, -# dependencies: common_all.dependencies(), -# name_suffix: 'fa') - -feature_to_c = find_program('scripts/feature_to_c.sh') - -emulators = {} -foreach target : target_dirs - config_target = config_target_mak[target] - target_name = config_target['TARGET_NAME'] - arch = config_target['TARGET_BASE_ARCH'] - arch_srcs = [config_target_h[target]] - arch_deps = [] - c_args = ['-DNEED_CPU_H', - '-DCONFIG_TARGET="@0@-config-target.h"'.format(target), - '-DCONFIG_DEVICES="@0@-config-devices.h"'.format(target)] - link_args = emulator_link_args - - config_target += config_host - target_inc = [include_directories('target' / config_target['TARGET_BASE_ARCH'])] - if targetos == 'linux' - target_inc += include_directories('linux-headers', is_system: true) - endif - if target.endswith('-softmmu') - qemu_target_name = 'qemu-system-' + target_name - target_type='system' - t = target_softmmu_arch[arch].apply(config_target, strict: false) - arch_srcs += t.sources() - arch_deps += t.dependencies() - - hw_dir = target_name == 'sparc64' ? 'sparc64' : arch - hw = hw_arch[hw_dir].apply(config_target, strict: false) - arch_srcs += hw.sources() - arch_deps += hw.dependencies() - - arch_srcs += config_devices_h[target] - link_args += ['@block.syms', '@qemu.syms'] - else - abi = config_target['TARGET_ABI_DIR'] - target_type='user' - qemu_target_name = 'qemu-' + target_name - if 'CONFIG_LINUX_USER' in config_target - base_dir = 'linux-user' - target_inc += include_directories('linux-user/host/' / config_host['ARCH']) - else - base_dir = 'bsd-user' - endif - target_inc += include_directories( - base_dir, - base_dir / abi, - ) - if 'CONFIG_LINUX_USER' in config_target - dir = base_dir / abi - arch_srcs += files(dir / 'signal.c', dir / 'cpu_loop.c') - if config_target.has_key('TARGET_SYSTBL_ABI') - arch_srcs += \ - syscall_nr_generators[abi].process(base_dir / abi / config_target['TARGET_SYSTBL'], - extra_args : config_target['TARGET_SYSTBL_ABI']) - endif - endif - endif - - if 'TARGET_XML_FILES' in config_target - gdbstub_xml = custom_target(target + '-gdbstub-xml.c', - output: target + '-gdbstub-xml.c', - input: files(config_target['TARGET_XML_FILES'].split()), - command: [feature_to_c, '@INPUT@'], - capture: true) - arch_srcs += gdbstub_xml - endif - - t = target_arch[arch].apply(config_target, strict: false) - arch_srcs += t.sources() - arch_deps += t.dependencies() - - target_common = common_ss.apply(config_target, strict: false) - objects = common_all.extract_objects(target_common.sources()) - deps = target_common.dependencies() - - target_specific = specific_ss.apply(config_target, strict: false) - arch_srcs += target_specific.sources() - arch_deps += target_specific.dependencies() - - lib = static_library('qemu-' + target, - sources: arch_srcs + genh, - dependencies: arch_deps, - objects: objects, - include_directories: target_inc, - c_args: c_args, - build_by_default: false, - name_suffix: 'fa') - - if target.endswith('-softmmu') - execs = [{ - 'name': 'qemu-system-' + target_name, - 'gui': false, - 'sources': files('softmmu/main.c'), - 'dependencies': [] - }] - if targetos == 'windows' and (sdl.found() or gtk.found()) - execs += [{ - 'name': 'qemu-system-' + target_name + 'w', - 'gui': true, - 'sources': files('softmmu/main.c'), - 'dependencies': [] - }] - endif - if config_host.has_key('CONFIG_FUZZ') - specific_fuzz = specific_fuzz_ss.apply(config_target, strict: false) - execs += [{ - 'name': 'qemu-fuzz-' + target_name, - 'gui': false, - 'sources': specific_fuzz.sources(), - 'dependencies': specific_fuzz.dependencies(), - }] - endif - else - execs = [{ - 'name': 'qemu-' + target_name, - 'gui': false, - 'sources': [], - 'dependencies': [] - }] - endif - foreach exe: execs - emulators += {exe['name']: - executable(exe['name'], exe['sources'], - install: true, - c_args: c_args, - dependencies: arch_deps + deps + exe['dependencies'], - objects: lib.extract_all_objects(recursive: true), - link_language: link_language, - link_depends: [block_syms, qemu_syms] + exe.get('link_depends', []), - link_args: link_args, - gui_app: exe['gui']) - } - - if 'CONFIG_TRACE_SYSTEMTAP' in config_host - foreach stp: [ - {'ext': '.stp-build', 'fmt': 'stap', 'bin': meson.current_build_dir() / exe['name'], 'install': false}, - {'ext': '.stp', 'fmt': 'stap', 'bin': get_option('prefix') / get_option('bindir') / exe['name'], 'install': true}, - {'ext': '-simpletrace.stp', 'fmt': 'simpletrace-stap', 'bin': '', 'install': true}, - {'ext': '-log.stp', 'fmt': 'log-stap', 'bin': '', 'install': true}, - ] - custom_target(exe['name'] + stp['ext'], - input: trace_events_all, - output: exe['name'] + stp['ext'], - capture: true, - install: stp['install'], - install_dir: get_option('datadir') / 'systemtap/tapset', - command: [ - tracetool, '--group=all', '--format=' + stp['fmt'], - '--binary=' + stp['bin'], - '--target-name=' + target_name, - '--target-type=' + target_type, - '--probe-prefix=qemu.' + target_type + '.' + target_name, - '@INPUT@', - ]) - endforeach - endif - endforeach -endforeach - # Other build targets -if 'CONFIG_LINUX_USER' in config_target - executable('qemu-binfmt', files('linux-user/binfmt.c'), - install: true) -endif - -if 'CONFIG_PLUGIN' in config_host - install_headers('include/qemu/qemu-plugin.h') -endif - -if 'CONFIG_GUEST_AGENT' in config_host - subdir('qga') -endif - -# Don't build qemu-keymap if xkbcommon is not explicitly enabled -# when we don't build tools or system -if xkbcommon.found() - # used for the update-keymaps target, so include rules even if !have_tools - qemu_keymap = executable('qemu-keymap', files('qemu-keymap.c', 'ui/input-keymap.c') + genh, - dependencies: [qemuutil, xkbcommon], install: have_tools) -endif - if have_tools qemu_img = executable('qemu-img', [files('qemu-img.c'), hxdep], dependencies: [authz, block, crypto, io, qom, qemuutil], install: true) @@ -1918,73 +499,9 @@ if have_tools dependencies: [block, qemuutil], install: true) qemu_nbd = executable('qemu-nbd', files('qemu-nbd.c'), dependencies: [blockdev, qemuutil], install: true) - -# subdir('storage-daemon') -# subdir('contrib/rdmacm-mux') -# subdir('contrib/elf2dmp') - -# executable('qemu-edid', files('qemu-edid.c', 'hw/display/edid-generate.c'), -# dependencies: qemuutil, -# install: true) - - if 'CONFIG_VHOST_USER' in config_host - subdir('contrib/vhost-user-blk') - subdir('contrib/vhost-user-gpu') - subdir('contrib/vhost-user-input') - subdir('contrib/vhost-user-scsi') - endif - -# if targetos == 'linux' -# executable('qemu-bridge-helper', files('qemu-bridge-helper.c'), -# dependencies: [qemuutil, libcap_ng], -# install: true, -# install_dir: get_option('libexecdir')) - -# executable('qemu-pr-helper', files('scsi/qemu-pr-helper.c', 'scsi/utils.c'), -# dependencies: [authz, crypto, io, qom, qemuutil, -# libcap_ng, mpathpersist], -# install: true) -# endif - -# if 'CONFIG_IVSHMEM' in config_host -# subdir('contrib/ivshmem-client') -# subdir('contrib/ivshmem-server') -# endif endif subdir('scripts') -#subdir('tools') -#subdir('pc-bios') -#subdir('docs') -#subdir('tests') -#if 'CONFIG_GTK' in config_host -# subdir('po') -#endif - -if host_machine.system() == 'windows' - nsis_cmd = [ - find_program('scripts/nsis.py'), - '@OUTPUT@', - get_option('prefix'), - meson.current_source_dir(), - host_machine.cpu(), - '--', - '-DDISPLAYVERSION=' + meson.project_version(), - ] - if build_docs - nsis_cmd += '-DCONFIG_DOCUMENTATION=y' - endif - if 'CONFIG_GTK' in config_host - nsis_cmd += '-DCONFIG_GTK=y' - endif - - nsis = custom_target('nsis', - output: 'qemu-setup-' + meson.project_version() + '.exe', - input: files('qemu.nsi'), - build_always_stale: true, - command: nsis_cmd + ['@INPUT@']) - alias_target('installer', nsis) -endif ######################### # Configuration summary # @@ -2000,12 +517,8 @@ summary_info += {'module directory': qemu_moddir} summary_info += {'libexec directory': get_option('libexecdir')} summary_info += {'include directory': get_option('includedir')} summary_info += {'config directory': get_option('sysconfdir')} -if targetos != 'windows' - summary_info += {'local state directory': get_option('localstatedir')} - summary_info += {'Manual directory': get_option('mandir')} -else - summary_info += {'local state directory': 'queried at runtime'} -endif +summary_info += {'local state directory': get_option('localstatedir')} +summary_info += {'Manual directory': get_option('mandir')} summary_info += {'Doc directory': get_option('docdir')} summary_info += {'Build directory': meson.current_build_dir()} summary_info += {'Source path': meson.current_source_dir()} @@ -2018,9 +531,7 @@ if link_language == 'cpp' else summary_info += {'C++ compiler': false} endif -if targetos == 'darwin' - summary_info += {'Objective-C compiler': meson.get_compiler('objc').cmd_array()[0]} -endif + summary_info += {'ARFLAGS': config_host['ARFLAGS']} summary_info += {'CFLAGS': ' '.join(get_option('c_args') + ['-O' + get_option('optimization')] @@ -2038,21 +549,17 @@ summary_info += {'QEMU_CFLAGS': config_host['QEMU_CFLAGS']} summary_info += {'QEMU_LDFLAGS': config_host['QEMU_LDFLAGS']} summary_info += {'make': config_host['MAKE']} summary_info += {'python': '@0@ (version: @1@)'.format(python.full_path(), python.language_version())} -#summary_info += {'sphinx-build': sphinx_build.found()} summary_info += {'sphinx-build': false} summary_info += {'genisoimage': config_host['GENISOIMAGE']} # TODO: add back version -summary_info += {'slirp support': slirp_opt == 'disabled' ? false : slirp_opt} -if slirp_opt != 'disabled' - summary_info += {'smbd': config_host['CONFIG_SMBD_COMMAND']} -endif +summary_info += {'slirp support': false} summary_info += {'module support': config_host.has_key('CONFIG_MODULES')} if config_host.has_key('CONFIG_MODULES') summary_info += {'alternative module path': config_host.has_key('CONFIG_MODULE_UPGRADES')} endif summary_info += {'host CPU': cpu} summary_info += {'host endianness': build_machine.endian()} -summary_info += {'target list': ' '.join(target_dirs)} +summary_info += {'target list': ' '} summary_info += {'gprof enabled': config_host.has_key('CONFIG_GPROF')} summary_info += {'sparse enabled': sparse.found()} summary_info += {'strip binaries': get_option('strip')} @@ -2062,12 +569,12 @@ if targetos == 'darwin' summary_info += {'Cocoa support': config_host.has_key('CONFIG_COCOA')} endif # TODO: add back version -summary_info += {'SDL support': sdl.found()} -summary_info += {'SDL image support': sdl_image.found()} +summary_info += {'SDL support': false} +summary_info += {'SDL image support': false} # TODO: add back version summary_info += {'GTK support': config_host.has_key('CONFIG_GTK')} summary_info += {'GTK GL support': config_host.has_key('CONFIG_GTK_GL')} -summary_info += {'pixman': pixman.found()} +summary_info += {'pixman': false} # TODO: add back version summary_info += {'VTE support': config_host.has_key('CONFIG_VTE')} summary_info += {'TLS priority': config_host['CONFIG_TLS_PRIORITY']} @@ -2085,8 +592,8 @@ if config_host.has_key('CONFIG_NETTLE') endif summary_info += {'libtasn1': config_host.has_key('CONFIG_TASN1')} summary_info += {'PAM': config_host.has_key('CONFIG_AUTH_PAM')} -summary_info += {'iconv support': iconv.found()} -summary_info += {'curses support': curses.found()} +summary_info += {'iconv support': false} +summary_info += {'curses support': false} # TODO: add back version summary_info += {'virgl support': config_host.has_key('CONFIG_VIRGL')} summary_info += {'curl support': config_host.has_key('CONFIG_CURL')} @@ -2095,21 +602,14 @@ summary_info += {'Audio drivers': config_host['CONFIG_AUDIO_DRIVERS']} summary_info += {'Block whitelist (rw)': config_host['CONFIG_BDRV_RW_WHITELIST']} summary_info += {'Block whitelist (ro)': config_host['CONFIG_BDRV_RO_WHITELIST']} summary_info += {'VirtFS support': config_host.has_key('CONFIG_VIRTFS')} -#summary_info += {'build virtiofs daemon': have_virtiofsd} summary_info += {'build virtiofs daemon': false} -summary_info += {'Multipath support': mpathpersist.found()} -summary_info += {'VNC support': vnc.found()} -if vnc.found() - summary_info += {'VNC SASL support': sasl.found()} - summary_info += {'VNC JPEG support': jpeg.found()} - summary_info += {'VNC PNG support': png.found()} -endif +summary_info += {'Multipath support': false} +summary_info += {'VNC support': false} summary_info += {'xen support': config_host.has_key('CONFIG_XEN_BACKEND')} if config_host.has_key('CONFIG_XEN_BACKEND') summary_info += {'xen ctrl version': config_host['CONFIG_XEN_CTRL_INTERFACE_VERSION']} endif summary_info += {'brlapi support': config_host.has_key('CONFIG_BRLAPI')} -#summary_info += {'Documentation': build_docs} summary_info += {'Documentation': false} summary_info += {'PIE': get_option('b_pie')} summary_info += {'vde support': config_host.has_key('CONFIG_VDE')} @@ -2127,10 +627,10 @@ if config_all.has_key('CONFIG_TCG') summary_info += {'TCG debug enabled': config_host.has_key('CONFIG_DEBUG_TCG')} summary_info += {'TCG interpreter': config_host.has_key('CONFIG_TCG_INTERPRETER')} endif -summary_info += {'malloc trim support': has_malloc_trim} +summary_info += {'malloc trim support': false} summary_info += {'RDMA support': config_host.has_key('CONFIG_RDMA')} summary_info += {'PVRDMA support': config_host.has_key('CONFIG_PVRDMA')} -summary_info += {'fdt support': fdt_opt == 'disabled' ? false : fdt_opt} +summary_info += {'fdt support': false} summary_info += {'membarrier': config_host.has_key('CONFIG_MEMBARRIER')} summary_info += {'preadv support': config_host.has_key('CONFIG_PREADV')} summary_info += {'fdatasync': config_host.has_key('CONFIG_FDATASYNC')} @@ -2156,7 +656,7 @@ summary_info += {'spice support': config_host.has_key('CONFIG_SPICE')} summary_info += {'rbd support': config_host.has_key('CONFIG_RBD')} summary_info += {'xfsctl support': config_host.has_key('CONFIG_XFS')} summary_info += {'smartcard support': config_host.has_key('CONFIG_SMARTCARD')} -summary_info += {'U2F support': u2f.found()} +summary_info += {'U2F support': false} summary_info += {'libusb': config_host.has_key('CONFIG_USB_LIBUSB')} summary_info += {'usb net redir': config_host.has_key('CONFIG_USB_REDIR')} summary_info += {'OpenGL support': config_host.has_key('CONFIG_OPENGL')} @@ -2164,14 +664,6 @@ summary_info += {'OpenGL dmabufs': config_host.has_key('CONFIG_OPENGL_DMABUF' summary_info += {'libiscsi support': config_host.has_key('CONFIG_LIBISCSI')} summary_info += {'libnfs support': config_host.has_key('CONFIG_LIBNFS')} summary_info += {'build guest agent': config_host.has_key('CONFIG_GUEST_AGENT')} -if targetos == 'windows' - if 'WIN_SDK' in config_host - summary_info += {'Windows SDK': config_host['WIN_SDK']} - endif - summary_info += {'QGA VSS support': config_host.has_key('CONFIG_QGA_VSS')} - summary_info += {'QGA w32 disk info': config_host.has_key('CONFIG_QGA_NTDDSCSI')} - summary_info += {'QGA MSI support': config_host.has_key('CONFIG_QGA_MSI')} -endif summary_info += {'seccomp support': config_host.has_key('CONFIG_SECCOMP')} summary_info += {'coroutine backend': config_host['CONFIG_COROUTINE_BACKEND']} summary_info += {'coroutine pool': config_host['CONFIG_COROUTINE_POOL'] == '1'} @@ -2204,10 +696,10 @@ summary_info += {'vvfat support': config_host.has_key('CONFIG_VVFAT')} summary_info += {'qed support': config_host.has_key('CONFIG_QED')} summary_info += {'parallels support': config_host.has_key('CONFIG_PARALLELS')} summary_info += {'sheepdog support': config_host.has_key('CONFIG_SHEEPDOG')} -summary_info += {'capstone': capstone_opt == 'disabled' ? false : capstone_opt} +summary_info += {'capstone': false} summary_info += {'libpmem support': config_host.has_key('CONFIG_LIBPMEM')} summary_info += {'libdaxctl support': config_host.has_key('CONFIG_LIBDAXCTL')} -summary_info += {'libudev': libudev.found()} +summary_info += {'libudev': false} summary_info += {'default devices': config_host['CONFIG_MINIKCONF_MODE'] == '--defconfig'} summary_info += {'plugin support': config_host.has_key('CONFIG_PLUGIN')} summary_info += {'fuzzing support': config_host.has_key('CONFIG_FUZZ')}