]>
Commit | Line | Data |
---|---|---|
20cf5cb4 PB |
1 | if 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() |
7 | endif | |
8 | ||
8821a389 | 9 | have_qga_vss = get_option('qga_vss') \ |
d0cda6f4 | 10 | .require(host_os == 'windows', |
8821a389 | 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 |
29 | all_qga = [] |
30 | ||
f15bff25 PB |
31 | qga_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 | 55 | qga_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 | 62 | qga_ss = ss.source_set() |
2a127f96 | 63 | qga_ss.add(qga_qapi_files.to_list()) |
f15bff25 PB |
64 | qga_ss.add(files( |
65 | 'commands.c', | |
66 | 'guest-agent-command-state.c', | |
67 | 'main.c', | |
0edbfbe3 | 68 | 'cutils.c', |
f15bff25 | 69 | )) |
d0cda6f4 | 70 | if host_os == 'windows' |
dc495494 PB |
71 | qga_ss.add(files( |
72 | 'channel-win32.c', | |
73 | 'commands-win32.c', | |
74 | 'service-win32.c', | |
75 | 'vss-win32.c' | |
76 | )) | |
77 | else | |
78 | qga_ss.add(files( | |
79 | 'channel-posix.c', | |
80 | 'commands-posix.c', | |
81 | 'commands-posix-ssh.c', | |
82 | )) | |
d0cda6f4 | 83 | if host_os == 'linux' |
dc495494 | 84 | qga_ss.add(files('commands-linux.c')) |
d0cda6f4 | 85 | elif host_os in bsd_oses |
dc495494 PB |
86 | qga_ss.add(files('commands-bsd.c')) |
87 | endif | |
53e8868d | 88 | endif |
f15bff25 | 89 | |
1220f581 | 90 | qga_ss = qga_ss.apply({}) |
f15bff25 | 91 | |
87263685 PB |
92 | gen_tlb = [] |
93 | qga_libs = [] | |
d0cda6f4 | 94 | if host_os == '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 | 101 | endif |
328ec32d | 102 | |
f9f0e617 | 103 | qga_objs = [] |
d0cda6f4 | 104 | if host_os == 'windows' |
f9f0e617 AD |
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] | |
118 | endif | |
119 | ||
120 | qga = executable('qemu-ga', qga_ss.sources() + qga_objs, | |
87263685 PB |
121 | link_args: qga_libs, |
122 | dependencies: [qemuutil, libudev], | |
123 | install: true) | |
124 | all_qga += qga | |
125 | ||
d0cda6f4 | 126 | if host_os == '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 | 171 | else |
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 | 176 | endif |
588a19fa PB |
177 | |
178 | alias_target('qemu-ga', all_qga) | |
8d769ec7 MAL |
179 | |
180 | test_env = environment() | |
181 | test_env.set('G_TEST_SRCDIR', meson.current_source_dir()) | |
182 | test_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 | |
d0cda6f4 | 188 | #if host_os != 'windows' |
8d769ec7 | 189 | if 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']) | |
206 | endif |