]> git.proxmox.com Git - mirror_qemu.git/blame - qga/meson.build
meson: remove CONFIG_POSIX and CONFIG_WIN32 from config_targetos
[mirror_qemu.git] / qga / meson.build
CommitLineData
20cf5cb4
PB
1if not have_ga
2 if get_option('guest_agent_msi').enabled()
3 error('Guest agent MSI requested, but the guest agent is not being built')
4 endif
8821a389 5 have_qga_vss = false
20cf5cb4
PB
6 subdir_done()
7endif
8
8821a389
MAL
9have_qga_vss = get_option('qga_vss') \
10 .require(targetos == 'windows',
11 error_message: 'VSS support requires Windows') \
785abf0d 12 .require('cpp' in all_languages,
8821a389
MAL
13 error_message: 'VSS support requires a C++ compiler') \
14 .require(have_vss, error_message: '''VSS support requires VSS headers.
15 If your Visual Studio installation doesn't have the VSS headers,
16 Please download and install Microsoft VSS SDK:
17 http://www.microsoft.com/en-us/download/details.aspx?id=23490
b770f6ce 18 On POSIX-systems, MinGW should provide headers in >=10.0 releases.
8821a389
MAL
19 you can extract the SDK headers by:
20 $ scripts/extract-vsssdk-headers setup.exe
21 The headers are extracted in the directory 'inc/win2003'.
22 Then run configure with: --extra-cxxflags="-isystem /path/to/vss/inc/win2003"''') \
23011f44
MAL
23 .require(midl.found() or widl.found(),
24 error_message: 'VSS support requires midl or widl') \
a0cbd2e8 25 .require(not get_option('prefer_static'),
e23460ce 26 error_message: 'VSS support requires dynamic linking with GLib') \
8821a389
MAL
27 .allowed()
28
87263685
PB
29all_qga = []
30
f15bff25
PB
31qga_qapi_outputs = [
32 'qga-qapi-commands.c',
33 'qga-qapi-commands.h',
f15bff25
PB
34 'qga-qapi-emit-events.c',
35 'qga-qapi-emit-events.h',
36 'qga-qapi-events.c',
37 'qga-qapi-events.h',
38 'qga-qapi-init-commands.c',
39 'qga-qapi-init-commands.h',
40 'qga-qapi-introspect.c',
41 'qga-qapi-introspect.h',
42 'qga-qapi-types.c',
43 'qga-qapi-types.h',
44 'qga-qapi-visit.c',
45 'qga-qapi-visit.h',
46]
47
378dfa48
VSO
48# Problem: to generate trace events, we'd have to add the .trace-events
49# file to qapi_trace_events like we do in qapi/meson.build. Since
50# qapi_trace_events is used by trace/meson.build, we'd have to move
51# subdir('qga') above subdir('trace') in the top-level meson.build.
52# Can't, because it would break the dependency of qga on qemuutil (which
53# depends on trace_ss). Not worth solving now; simply suppress trace
54# event generation instead.
f15bff25 55qga_qapi_files = custom_target('QGA QAPI files',
db16115f 56 output: qga_qapi_outputs,
f15bff25 57 input: 'qapi-schema.json',
761a1a48
VSO
58 command: [ qapi_gen, '-o', 'qga', '-p', 'qga-', '@INPUT0@',
59 '--suppress-tracing' ],
f15bff25 60 depend_files: qapi_gen_depends)
acfdaac5 61
f15bff25 62qga_ss = ss.source_set()
2a127f96 63qga_ss.add(qga_qapi_files.to_list())
f15bff25
PB
64qga_ss.add(files(
65 'commands.c',
66 'guest-agent-command-state.c',
67 'main.c',
0edbfbe3 68 'cutils.c',
f15bff25 69))
dc495494
PB
70if targetos == 'windows'
71 qga_ss.add(files(
72 'channel-win32.c',
73 'commands-win32.c',
74 'service-win32.c',
75 'vss-win32.c'
76 ))
77else
78 qga_ss.add(files(
79 'channel-posix.c',
80 'commands-posix.c',
81 'commands-posix-ssh.c',
82 ))
83 if targetos == 'linux'
84 qga_ss.add(files('commands-linux.c'))
85 elif targetos in bsd_oses
86 qga_ss.add(files('commands-bsd.c'))
87 endif
53e8868d 88endif
f15bff25 89
1f2146f7 90qga_ss = qga_ss.apply(config_targetos, strict: false)
f15bff25 91
87263685
PB
92gen_tlb = []
93qga_libs = []
7272fc72 94if targetos == 'windows'
3015321d
MAL
95 qga_libs += ['-lws2_32', '-lwinmm', '-lpowrprof', '-lwtsapi32', '-lwininet', '-liphlpapi', '-lnetapi32',
96 '-lsetupapi', '-lcfgmgr32']
8821a389 97 if have_qga_vss
87263685 98 qga_libs += ['-lole32', '-loleaut32', '-lshlwapi', '-lstdc++', '-Wl,--enable-stdcall-fixup']
7272fc72 99 subdir('vss-win32')
328ec32d 100 endif
87263685 101endif
328ec32d 102
f9f0e617
AD
103qga_objs = []
104if targetos == 'windows'
105 windmc = find_program('windmc', required: true)
106 windres = find_program('windres', required: true)
107
108 msgrc = custom_target('messages-win32.rc',
109 input: 'messages-win32.mc',
110 output: ['messages-win32.rc', 'MSG00409.bin', 'messages-win32.h'],
111 command: [windmc, '-h', '@OUTDIR@', '-r', '@OUTDIR@', '@INPUT@'])
112 msgobj = custom_target('messages-win32.o',
113 input: msgrc[0],
114 output: 'messages-win32.o',
115 command: [windres, '-I', '@OUTDIR@', '-o', '@OUTPUT@', '@INPUT@'])
116
117 qga_objs = [msgobj]
118endif
119
120qga = executable('qemu-ga', qga_ss.sources() + qga_objs,
87263685
PB
121 link_args: qga_libs,
122 dependencies: [qemuutil, libudev],
123 install: true)
124all_qga += qga
125
126if targetos == 'windows'
b846ab7c
PB
127 qemu_ga_msi_arch = {
128 'x86': ['-D', 'Arch=32'],
129 'x86_64': ['-a', 'x64', '-D', 'Arch=64']
130 }
131 wixl = not_found
132 if cpu in qemu_ga_msi_arch
133 wixl = find_program('wixl', required: get_option('guest_agent_msi'))
134 elif get_option('guest_agent_msi').enabled()
135 error('CPU not supported for building guest agent installation package')
136 endif
137
328ec32d
MAL
138 if wixl.found()
139 deps = [gen_tlb, qga]
b846ab7c 140 qemu_ga_msi_vss = []
8821a389 141 if have_qga_vss
b846ab7c 142 qemu_ga_msi_vss = ['-D', 'InstallVss']
328ec32d
MAL
143 deps += qga_vss
144 endif
7b47b13e 145 if glib.version().version_compare('<2.73.2')
9ca180bc
AD
146 libpcre = 'libpcre1'
147 else
148 libpcre = 'libpcre2'
149 endif
e20d68aa 150 qga_msi_version = get_option('qemu_ga_version') == '' \
7e5b1979 151 ? meson.project_version() \
e20d68aa 152 : get_option('qemu_ga_version')
b846ab7c
PB
153 qga_msi = custom_target('QGA MSI',
154 input: files('installer/qemu-ga.wxs'),
6bee0960 155 output: 'qemu-ga-@0@.msi'.format(host_arch),
b846ab7c
PB
156 depends: deps,
157 command: [
b846ab7c
PB
158 wixl, '-o', '@OUTPUT0@', '@INPUT0@',
159 qemu_ga_msi_arch[cpu],
160 qemu_ga_msi_vss,
ca5765c8 161 '-D', 'BUILD_DIR=' + meson.project_build_root(),
91a2e688 162 '-D', 'BIN_DIR=' + glib_pc.get_variable('bindir'),
e20d68aa
PB
163 '-D', 'QEMU_GA_VERSION=' + qga_msi_version,
164 '-D', 'QEMU_GA_MANUFACTURER=' + get_option('qemu_ga_manufacturer'),
165 '-D', 'QEMU_GA_DISTRO=' + get_option('qemu_ga_distro'),
9ca180bc 166 '-D', 'LIBPCRE=' + libpcre,
b846ab7c
PB
167 ])
168 all_qga += [qga_msi]
169 alias_target('msi', qga_msi)
7272fc72 170 endif
8ab1aabc 171else
b846ab7c
PB
172 if get_option('guest_agent_msi').enabled()
173 error('MSI guest agent package is available only for MinGW Windows cross-compilation')
174 endif
8a29c205 175 install_emptydir(get_option('localstatedir') / 'run')
7272fc72 176endif
588a19fa
PB
177
178alias_target('qemu-ga', all_qga)
8d769ec7
MAL
179
180test_env = environment()
181test_env.set('G_TEST_SRCDIR', meson.current_source_dir())
182test_env.set('G_TEST_BUILDDIR', meson.current_build_dir())
183
184# disable qga-ssh-test for now. glib's G_TEST_OPTION_ISOLATE_DIRS triggers
185# the leak detector in build-oss-fuzz Gitlab CI test. we should re-enable
186# this when an alternative is implemented or when the underlying glib
187# issue is identified/fix
1f2146f7 188#if targetos != 'windows'
8d769ec7 189if false
cad97c08
MAL
190 srcs = [files('commands-posix-ssh.c')]
191 i = 0
192 foreach output: qga_qapi_outputs
193 if output.startswith('qga-qapi-types') or output.startswith('qga-qapi-visit')
194 srcs += qga_qapi_files[i]
195 endif
196 i = i + 1
197 endforeach
198 qga_ssh_test = executable('qga-ssh-test', srcs,
8d769ec7
MAL
199 dependencies: [qemuutil],
200 c_args: ['-DQGA_BUILD_UNIT_TEST'])
201
202 test('qga-ssh-test',
203 qga_ssh_test,
204 env: test_env,
205 suite: ['unit', 'qga'])
206endif