VirtualBox

source: vbox/trunk/src/VBox/Frontends/VBoxManage/VBoxManageModifyVM.cpp@ 65855

Last change on this file since 65855 was 65652, checked in by vboxsync, 8 years ago

gcc 7: VBoxManage: fall thru

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 128.1 KB
Line 
1/* $Id: VBoxManageModifyVM.cpp 65652 2017-02-07 11:47:12Z vboxsync $ */
2/** @file
3 * VBoxManage - Implementation of modifyvm command.
4 */
5
6/*
7 * Copyright (C) 2006-2016 Oracle Corporation
8 *
9 * This file is part of VirtualBox Open Source Edition (OSE), as
10 * available from http://www.virtualbox.org. This file is free software;
11 * you can redistribute it and/or modify it under the terms of the GNU
12 * General Public License (GPL) as published by the Free Software
13 * Foundation, in version 2 as it comes in the "COPYING" file of the
14 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16 */
17
18
19/*********************************************************************************************************************************
20* Header Files *
21*********************************************************************************************************************************/
22#ifndef VBOX_ONLY_DOCS
23#include <VBox/com/com.h>
24#include <VBox/com/array.h>
25#include <VBox/com/ErrorInfo.h>
26#include <VBox/com/errorprint.h>
27#include <VBox/com/VirtualBox.h>
28#endif /* !VBOX_ONLY_DOCS */
29
30#include <iprt/cidr.h>
31#include <iprt/ctype.h>
32#include <iprt/file.h>
33#include <iprt/param.h>
34#include <iprt/path.h>
35#include <iprt/stream.h>
36#include <iprt/string.h>
37#include <iprt/getopt.h>
38#include <VBox/log.h>
39#include "VBoxManage.h"
40
41#ifndef VBOX_ONLY_DOCS
42using namespace com;
43/** @todo refine this after HDD changes; MSC 8.0/64 has trouble with handleModifyVM. */
44#if defined(_MSC_VER)
45# pragma optimize("g", off)
46# pragma warning(disable:4748)
47#endif
48
49enum
50{
51 MODIFYVM_NAME = 1000,
52 MODIFYVM_GROUPS,
53 MODIFYVM_DESCRIPTION,
54 MODIFYVM_OSTYPE,
55 MODIFYVM_ICONFILE,
56 MODIFYVM_MEMORY,
57 MODIFYVM_PAGEFUSION,
58 MODIFYVM_VRAM,
59 MODIFYVM_FIRMWARE,
60 MODIFYVM_ACPI,
61 MODIFYVM_IOAPIC,
62 MODIFYVM_PAE,
63 MODIFYVM_LONGMODE,
64 MODIFYVM_CPUID_PORTABILITY,
65 MODIFYVM_TFRESET,
66 MODIFYVM_APIC,
67 MODIFYVM_X2APIC,
68 MODIFYVM_PARAVIRTPROVIDER,
69 MODIFYVM_PARAVIRTDEBUG,
70 MODIFYVM_HWVIRTEX,
71 MODIFYVM_NESTEDPAGING,
72 MODIFYVM_LARGEPAGES,
73 MODIFYVM_VTXVPID,
74 MODIFYVM_VTXUX,
75 MODIFYVM_CPUS,
76 MODIFYVM_CPUHOTPLUG,
77 MODIFYVM_CPU_PROFILE,
78 MODIFYVM_PLUGCPU,
79 MODIFYVM_UNPLUGCPU,
80 MODIFYVM_SETCPUID,
81 MODIFYVM_DELCPUID,
82 MODIFYVM_DELALLCPUID,
83 MODIFYVM_GRAPHICSCONTROLLER,
84 MODIFYVM_MONITORCOUNT,
85 MODIFYVM_ACCELERATE3D,
86#ifdef VBOX_WITH_VIDEOHWACCEL
87 MODIFYVM_ACCELERATE2DVIDEO,
88#endif
89 MODIFYVM_BIOSLOGOFADEIN,
90 MODIFYVM_BIOSLOGOFADEOUT,
91 MODIFYVM_BIOSLOGODISPLAYTIME,
92 MODIFYVM_BIOSLOGOIMAGEPATH,
93 MODIFYVM_BIOSBOOTMENU,
94 MODIFYVM_BIOSAPIC,
95 MODIFYVM_BIOSSYSTEMTIMEOFFSET,
96 MODIFYVM_BIOSPXEDEBUG,
97 MODIFYVM_BOOT,
98 MODIFYVM_HDA, // deprecated
99 MODIFYVM_HDB, // deprecated
100 MODIFYVM_HDD, // deprecated
101 MODIFYVM_IDECONTROLLER, // deprecated
102 MODIFYVM_SATAPORTCOUNT, // deprecated
103 MODIFYVM_SATAPORT, // deprecated
104 MODIFYVM_SATA, // deprecated
105 MODIFYVM_SCSIPORT, // deprecated
106 MODIFYVM_SCSITYPE, // deprecated
107 MODIFYVM_SCSI, // deprecated
108 MODIFYVM_DVDPASSTHROUGH, // deprecated
109 MODIFYVM_DVD, // deprecated
110 MODIFYVM_FLOPPY, // deprecated
111 MODIFYVM_NICTRACEFILE,
112 MODIFYVM_NICTRACE,
113 MODIFYVM_NICPROPERTY,
114 MODIFYVM_NICTYPE,
115 MODIFYVM_NICSPEED,
116 MODIFYVM_NICBOOTPRIO,
117 MODIFYVM_NICPROMISC,
118 MODIFYVM_NICBWGROUP,
119 MODIFYVM_NIC,
120 MODIFYVM_CABLECONNECTED,
121 MODIFYVM_BRIDGEADAPTER,
122 MODIFYVM_HOSTONLYADAPTER,
123 MODIFYVM_INTNET,
124 MODIFYVM_GENERICDRV,
125 MODIFYVM_NATNETWORKNAME,
126 MODIFYVM_NATNET,
127 MODIFYVM_NATBINDIP,
128 MODIFYVM_NATSETTINGS,
129 MODIFYVM_NATPF,
130 MODIFYVM_NATALIASMODE,
131 MODIFYVM_NATTFTPPREFIX,
132 MODIFYVM_NATTFTPFILE,
133 MODIFYVM_NATTFTPSERVER,
134 MODIFYVM_NATDNSPASSDOMAIN,
135 MODIFYVM_NATDNSPROXY,
136 MODIFYVM_NATDNSHOSTRESOLVER,
137 MODIFYVM_MACADDRESS,
138 MODIFYVM_HIDPTR,
139 MODIFYVM_HIDKBD,
140 MODIFYVM_UARTMODE,
141 MODIFYVM_UART,
142#if defined(RT_OS_LINUX) || defined(RT_OS_WINDOWS)
143 MODIFYVM_LPTMODE,
144 MODIFYVM_LPT,
145#endif
146 MODIFYVM_GUESTMEMORYBALLOON,
147 MODIFYVM_AUDIOCONTROLLER,
148 MODIFYVM_AUDIOCODEC,
149 MODIFYVM_AUDIO,
150 MODIFYVM_CLIPBOARD,
151 MODIFYVM_DRAGANDDROP,
152 MODIFYVM_VRDPPORT, /* VRDE: deprecated */
153 MODIFYVM_VRDPADDRESS, /* VRDE: deprecated */
154 MODIFYVM_VRDPAUTHTYPE, /* VRDE: deprecated */
155 MODIFYVM_VRDPMULTICON, /* VRDE: deprecated */
156 MODIFYVM_VRDPREUSECON, /* VRDE: deprecated */
157 MODIFYVM_VRDPVIDEOCHANNEL, /* VRDE: deprecated */
158 MODIFYVM_VRDPVIDEOCHANNELQUALITY, /* VRDE: deprecated */
159 MODIFYVM_VRDP, /* VRDE: deprecated */
160 MODIFYVM_VRDEPROPERTY,
161 MODIFYVM_VRDEPORT,
162 MODIFYVM_VRDEADDRESS,
163 MODIFYVM_VRDEAUTHTYPE,
164 MODIFYVM_VRDEAUTHLIBRARY,
165 MODIFYVM_VRDEMULTICON,
166 MODIFYVM_VRDEREUSECON,
167 MODIFYVM_VRDEVIDEOCHANNEL,
168 MODIFYVM_VRDEVIDEOCHANNELQUALITY,
169 MODIFYVM_VRDE_EXTPACK,
170 MODIFYVM_VRDE,
171 MODIFYVM_RTCUSEUTC,
172 MODIFYVM_USBRENAME,
173 MODIFYVM_USBXHCI,
174 MODIFYVM_USBEHCI,
175 MODIFYVM_USB,
176 MODIFYVM_SNAPSHOTFOLDER,
177 MODIFYVM_TELEPORTER_ENABLED,
178 MODIFYVM_TELEPORTER_PORT,
179 MODIFYVM_TELEPORTER_ADDRESS,
180 MODIFYVM_TELEPORTER_PASSWORD,
181 MODIFYVM_TELEPORTER_PASSWORD_FILE,
182 MODIFYVM_TRACING_ENABLED,
183 MODIFYVM_TRACING_CONFIG,
184 MODIFYVM_TRACING_ALLOW_VM_ACCESS,
185 MODIFYVM_HARDWARE_UUID,
186 MODIFYVM_HPET,
187 MODIFYVM_IOCACHE,
188 MODIFYVM_IOCACHESIZE,
189 MODIFYVM_FAULT_TOLERANCE,
190 MODIFYVM_FAULT_TOLERANCE_ADDRESS,
191 MODIFYVM_FAULT_TOLERANCE_PORT,
192 MODIFYVM_FAULT_TOLERANCE_PASSWORD,
193 MODIFYVM_FAULT_TOLERANCE_SYNC_INTERVAL,
194 MODIFYVM_CPU_EXECTUION_CAP,
195 MODIFYVM_AUTOSTART_ENABLED,
196 MODIFYVM_AUTOSTART_DELAY,
197 MODIFYVM_AUTOSTOP_TYPE,
198#ifdef VBOX_WITH_PCI_PASSTHROUGH
199 MODIFYVM_ATTACH_PCI,
200 MODIFYVM_DETACH_PCI,
201#endif
202#ifdef VBOX_WITH_USB_CARDREADER
203 MODIFYVM_USBCARDREADER,
204#endif
205#ifdef VBOX_WITH_VIDEOREC
206 MODIFYVM_VIDEOCAP,
207 MODIFYVM_VIDEOCAP_SCREENS,
208 MODIFYVM_VIDEOCAP_FILENAME,
209 MODIFYVM_VIDEOCAP_WIDTH,
210 MODIFYVM_VIDEOCAP_HEIGHT,
211 MODIFYVM_VIDEOCAP_RES,
212 MODIFYVM_VIDEOCAP_RATE,
213 MODIFYVM_VIDEOCAP_FPS,
214 MODIFYVM_VIDEOCAP_MAXTIME,
215 MODIFYVM_VIDEOCAP_MAXSIZE,
216 MODIFYVM_VIDEOCAP_OPTIONS,
217#endif
218 MODIFYVM_CHIPSET,
219 MODIFYVM_DEFAULTFRONTEND
220};
221
222static const RTGETOPTDEF g_aModifyVMOptions[] =
223{
224/** @todo Convert to dash separated names like --triple-fault-reset! Please
225 * do that for all new options as we don't need more character soups
226 * around VirtualBox - typedefs more than covers that demand! */
227 { "--name", MODIFYVM_NAME, RTGETOPT_REQ_STRING },
228 { "--groups", MODIFYVM_GROUPS, RTGETOPT_REQ_STRING },
229 { "--description", MODIFYVM_DESCRIPTION, RTGETOPT_REQ_STRING },
230 { "--ostype", MODIFYVM_OSTYPE, RTGETOPT_REQ_STRING },
231 { "--iconfile", MODIFYVM_ICONFILE, RTGETOPT_REQ_STRING },
232 { "--memory", MODIFYVM_MEMORY, RTGETOPT_REQ_UINT32 },
233 { "--pagefusion", MODIFYVM_PAGEFUSION, RTGETOPT_REQ_BOOL_ONOFF },
234 { "--vram", MODIFYVM_VRAM, RTGETOPT_REQ_UINT32 },
235 { "--firmware", MODIFYVM_FIRMWARE, RTGETOPT_REQ_STRING },
236 { "--acpi", MODIFYVM_ACPI, RTGETOPT_REQ_BOOL_ONOFF },
237 { "--ioapic", MODIFYVM_IOAPIC, RTGETOPT_REQ_BOOL_ONOFF },
238 { "--pae", MODIFYVM_PAE, RTGETOPT_REQ_BOOL_ONOFF },
239 { "--longmode", MODIFYVM_LONGMODE, RTGETOPT_REQ_BOOL_ONOFF },
240 { "--cpuid-portability-level", MODIFYVM_CPUID_PORTABILITY, RTGETOPT_REQ_UINT32 },
241 { "--triplefaultreset", MODIFYVM_TFRESET, RTGETOPT_REQ_BOOL_ONOFF },
242 { "--apic", MODIFYVM_APIC, RTGETOPT_REQ_BOOL_ONOFF },
243 { "--x2apic", MODIFYVM_X2APIC, RTGETOPT_REQ_BOOL_ONOFF },
244 { "--paravirtprovider", MODIFYVM_PARAVIRTPROVIDER, RTGETOPT_REQ_STRING },
245 { "--paravirtdebug", MODIFYVM_PARAVIRTDEBUG, RTGETOPT_REQ_STRING },
246 { "--hwvirtex", MODIFYVM_HWVIRTEX, RTGETOPT_REQ_BOOL_ONOFF },
247 { "--nestedpaging", MODIFYVM_NESTEDPAGING, RTGETOPT_REQ_BOOL_ONOFF },
248 { "--largepages", MODIFYVM_LARGEPAGES, RTGETOPT_REQ_BOOL_ONOFF },
249 { "--vtxvpid", MODIFYVM_VTXVPID, RTGETOPT_REQ_BOOL_ONOFF },
250 { "--vtxux", MODIFYVM_VTXUX, RTGETOPT_REQ_BOOL_ONOFF },
251 { "--cpuidset", MODIFYVM_SETCPUID, RTGETOPT_REQ_UINT32 | RTGETOPT_FLAG_HEX},
252 { "--cpuidremove", MODIFYVM_DELCPUID, RTGETOPT_REQ_UINT32 | RTGETOPT_FLAG_HEX},
253 { "--cpuidremoveall", MODIFYVM_DELALLCPUID, RTGETOPT_REQ_NOTHING},
254 { "--cpus", MODIFYVM_CPUS, RTGETOPT_REQ_UINT32 },
255 { "--cpuhotplug", MODIFYVM_CPUHOTPLUG, RTGETOPT_REQ_BOOL_ONOFF },
256 { "--cpu-profile", MODIFYVM_CPU_PROFILE, RTGETOPT_REQ_STRING },
257 { "--plugcpu", MODIFYVM_PLUGCPU, RTGETOPT_REQ_UINT32 },
258 { "--unplugcpu", MODIFYVM_UNPLUGCPU, RTGETOPT_REQ_UINT32 },
259 { "--cpuexecutioncap", MODIFYVM_CPU_EXECTUION_CAP, RTGETOPT_REQ_UINT32 },
260 { "--rtcuseutc", MODIFYVM_RTCUSEUTC, RTGETOPT_REQ_BOOL_ONOFF },
261 { "--graphicscontroller", MODIFYVM_GRAPHICSCONTROLLER, RTGETOPT_REQ_STRING },
262 { "--monitorcount", MODIFYVM_MONITORCOUNT, RTGETOPT_REQ_UINT32 },
263 { "--accelerate3d", MODIFYVM_ACCELERATE3D, RTGETOPT_REQ_BOOL_ONOFF },
264#ifdef VBOX_WITH_VIDEOHWACCEL
265 { "--accelerate2dvideo", MODIFYVM_ACCELERATE2DVIDEO, RTGETOPT_REQ_BOOL_ONOFF },
266#endif
267 { "--bioslogofadein", MODIFYVM_BIOSLOGOFADEIN, RTGETOPT_REQ_BOOL_ONOFF },
268 { "--bioslogofadeout", MODIFYVM_BIOSLOGOFADEOUT, RTGETOPT_REQ_BOOL_ONOFF },
269 { "--bioslogodisplaytime", MODIFYVM_BIOSLOGODISPLAYTIME, RTGETOPT_REQ_UINT32 },
270 { "--bioslogoimagepath", MODIFYVM_BIOSLOGOIMAGEPATH, RTGETOPT_REQ_STRING },
271 { "--biosbootmenu", MODIFYVM_BIOSBOOTMENU, RTGETOPT_REQ_STRING },
272 { "--biossystemtimeoffset", MODIFYVM_BIOSSYSTEMTIMEOFFSET, RTGETOPT_REQ_INT64 },
273 { "--biosapic", MODIFYVM_BIOSAPIC, RTGETOPT_REQ_STRING },
274 { "--biospxedebug", MODIFYVM_BIOSPXEDEBUG, RTGETOPT_REQ_BOOL_ONOFF },
275 { "--boot", MODIFYVM_BOOT, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
276 { "--hda", MODIFYVM_HDA, RTGETOPT_REQ_STRING },
277 { "--hdb", MODIFYVM_HDB, RTGETOPT_REQ_STRING },
278 { "--hdd", MODIFYVM_HDD, RTGETOPT_REQ_STRING },
279 { "--idecontroller", MODIFYVM_IDECONTROLLER, RTGETOPT_REQ_STRING },
280 { "--sataportcount", MODIFYVM_SATAPORTCOUNT, RTGETOPT_REQ_UINT32 },
281 { "--sataport", MODIFYVM_SATAPORT, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
282 { "--sata", MODIFYVM_SATA, RTGETOPT_REQ_STRING },
283 { "--scsiport", MODIFYVM_SCSIPORT, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
284 { "--scsitype", MODIFYVM_SCSITYPE, RTGETOPT_REQ_STRING },
285 { "--scsi", MODIFYVM_SCSI, RTGETOPT_REQ_STRING },
286 { "--dvdpassthrough", MODIFYVM_DVDPASSTHROUGH, RTGETOPT_REQ_STRING },
287 { "--dvd", MODIFYVM_DVD, RTGETOPT_REQ_STRING },
288 { "--floppy", MODIFYVM_FLOPPY, RTGETOPT_REQ_STRING },
289 { "--nictracefile", MODIFYVM_NICTRACEFILE, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
290 { "--nictrace", MODIFYVM_NICTRACE, RTGETOPT_REQ_BOOL_ONOFF | RTGETOPT_FLAG_INDEX },
291 { "--nicproperty", MODIFYVM_NICPROPERTY, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
292 { "--nictype", MODIFYVM_NICTYPE, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
293 { "--nicspeed", MODIFYVM_NICSPEED, RTGETOPT_REQ_UINT32 | RTGETOPT_FLAG_INDEX },
294 { "--nicbootprio", MODIFYVM_NICBOOTPRIO, RTGETOPT_REQ_UINT32 | RTGETOPT_FLAG_INDEX },
295 { "--nicpromisc", MODIFYVM_NICPROMISC, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
296 { "--nicbandwidthgroup", MODIFYVM_NICBWGROUP, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
297 { "--nic", MODIFYVM_NIC, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
298 { "--cableconnected", MODIFYVM_CABLECONNECTED, RTGETOPT_REQ_BOOL_ONOFF | RTGETOPT_FLAG_INDEX },
299 { "--bridgeadapter", MODIFYVM_BRIDGEADAPTER, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
300 { "--hostonlyadapter", MODIFYVM_HOSTONLYADAPTER, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
301 { "--intnet", MODIFYVM_INTNET, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
302 { "--nicgenericdrv", MODIFYVM_GENERICDRV, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
303 { "--nat-network", MODIFYVM_NATNETWORKNAME, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
304 { "--natnetwork", MODIFYVM_NATNETWORKNAME, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
305 { "--natnet", MODIFYVM_NATNET, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
306 { "--natbindip", MODIFYVM_NATBINDIP, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
307 { "--natsettings", MODIFYVM_NATSETTINGS, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
308 { "--natpf", MODIFYVM_NATPF, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
309 { "--nataliasmode", MODIFYVM_NATALIASMODE, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
310 { "--nattftpprefix", MODIFYVM_NATTFTPPREFIX, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
311 { "--nattftpfile", MODIFYVM_NATTFTPFILE, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
312 { "--nattftpserver", MODIFYVM_NATTFTPSERVER, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
313 { "--natdnspassdomain", MODIFYVM_NATDNSPASSDOMAIN, RTGETOPT_REQ_BOOL_ONOFF | RTGETOPT_FLAG_INDEX },
314 { "--natdnsproxy", MODIFYVM_NATDNSPROXY, RTGETOPT_REQ_BOOL_ONOFF | RTGETOPT_FLAG_INDEX },
315 { "--natdnshostresolver", MODIFYVM_NATDNSHOSTRESOLVER, RTGETOPT_REQ_BOOL_ONOFF | RTGETOPT_FLAG_INDEX },
316 { "--macaddress", MODIFYVM_MACADDRESS, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
317 { "--mouse", MODIFYVM_HIDPTR, RTGETOPT_REQ_STRING },
318 { "--keyboard", MODIFYVM_HIDKBD, RTGETOPT_REQ_STRING },
319 { "--uartmode", MODIFYVM_UARTMODE, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
320 { "--uart", MODIFYVM_UART, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
321#if defined(RT_OS_LINUX) || defined(RT_OS_WINDOWS)
322 { "--lptmode", MODIFYVM_LPTMODE, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
323 { "--lpt", MODIFYVM_LPT, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
324#endif
325 { "--guestmemoryballoon", MODIFYVM_GUESTMEMORYBALLOON, RTGETOPT_REQ_UINT32 },
326 { "--audiocontroller", MODIFYVM_AUDIOCONTROLLER, RTGETOPT_REQ_STRING },
327 { "--audiocodec", MODIFYVM_AUDIOCODEC, RTGETOPT_REQ_STRING },
328 { "--audio", MODIFYVM_AUDIO, RTGETOPT_REQ_STRING },
329 { "--clipboard", MODIFYVM_CLIPBOARD, RTGETOPT_REQ_STRING },
330 { "--draganddrop", MODIFYVM_DRAGANDDROP, RTGETOPT_REQ_STRING },
331 { "--vrdpport", MODIFYVM_VRDPPORT, RTGETOPT_REQ_STRING }, /* deprecated */
332 { "--vrdpaddress", MODIFYVM_VRDPADDRESS, RTGETOPT_REQ_STRING }, /* deprecated */
333 { "--vrdpauthtype", MODIFYVM_VRDPAUTHTYPE, RTGETOPT_REQ_STRING }, /* deprecated */
334 { "--vrdpmulticon", MODIFYVM_VRDPMULTICON, RTGETOPT_REQ_BOOL_ONOFF }, /* deprecated */
335 { "--vrdpreusecon", MODIFYVM_VRDPREUSECON, RTGETOPT_REQ_BOOL_ONOFF }, /* deprecated */
336 { "--vrdpvideochannel", MODIFYVM_VRDPVIDEOCHANNEL, RTGETOPT_REQ_BOOL_ONOFF }, /* deprecated */
337 { "--vrdpvideochannelquality", MODIFYVM_VRDPVIDEOCHANNELQUALITY, RTGETOPT_REQ_STRING }, /* deprecated */
338 { "--vrdp", MODIFYVM_VRDP, RTGETOPT_REQ_BOOL_ONOFF }, /* deprecated */
339 { "--vrdeproperty", MODIFYVM_VRDEPROPERTY, RTGETOPT_REQ_STRING },
340 { "--vrdeport", MODIFYVM_VRDEPORT, RTGETOPT_REQ_STRING },
341 { "--vrdeaddress", MODIFYVM_VRDEADDRESS, RTGETOPT_REQ_STRING },
342 { "--vrdeauthtype", MODIFYVM_VRDEAUTHTYPE, RTGETOPT_REQ_STRING },
343 { "--vrdeauthlibrary", MODIFYVM_VRDEAUTHLIBRARY, RTGETOPT_REQ_STRING },
344 { "--vrdemulticon", MODIFYVM_VRDEMULTICON, RTGETOPT_REQ_BOOL_ONOFF },
345 { "--vrdereusecon", MODIFYVM_VRDEREUSECON, RTGETOPT_REQ_BOOL_ONOFF },
346 { "--vrdevideochannel", MODIFYVM_VRDEVIDEOCHANNEL, RTGETOPT_REQ_BOOL_ONOFF },
347 { "--vrdevideochannelquality", MODIFYVM_VRDEVIDEOCHANNELQUALITY, RTGETOPT_REQ_STRING },
348 { "--vrdeextpack", MODIFYVM_VRDE_EXTPACK, RTGETOPT_REQ_STRING },
349 { "--vrde", MODIFYVM_VRDE, RTGETOPT_REQ_BOOL_ONOFF },
350 { "--usbrename", MODIFYVM_USBRENAME, RTGETOPT_REQ_STRING },
351 { "--usbxhci", MODIFYVM_USBXHCI, RTGETOPT_REQ_BOOL_ONOFF },
352 { "--usbehci", MODIFYVM_USBEHCI, RTGETOPT_REQ_BOOL_ONOFF },
353 { "--usb", MODIFYVM_USB, RTGETOPT_REQ_BOOL_ONOFF },
354 { "--snapshotfolder", MODIFYVM_SNAPSHOTFOLDER, RTGETOPT_REQ_STRING },
355 { "--teleporter", MODIFYVM_TELEPORTER_ENABLED, RTGETOPT_REQ_BOOL_ONOFF },
356 { "--teleporterenabled", MODIFYVM_TELEPORTER_ENABLED, RTGETOPT_REQ_BOOL_ONOFF }, /* deprecated */
357 { "--teleporterport", MODIFYVM_TELEPORTER_PORT, RTGETOPT_REQ_UINT32 },
358 { "--teleporteraddress", MODIFYVM_TELEPORTER_ADDRESS, RTGETOPT_REQ_STRING },
359 { "--teleporterpassword", MODIFYVM_TELEPORTER_PASSWORD, RTGETOPT_REQ_STRING },
360 { "--teleporterpasswordfile", MODIFYVM_TELEPORTER_PASSWORD_FILE, RTGETOPT_REQ_STRING },
361 { "--tracing-enabled", MODIFYVM_TRACING_ENABLED, RTGETOPT_REQ_BOOL_ONOFF },
362 { "--tracing-config", MODIFYVM_TRACING_CONFIG, RTGETOPT_REQ_STRING },
363 { "--tracing-allow-vm-access", MODIFYVM_TRACING_ALLOW_VM_ACCESS, RTGETOPT_REQ_BOOL_ONOFF },
364 { "--hardwareuuid", MODIFYVM_HARDWARE_UUID, RTGETOPT_REQ_STRING },
365 { "--hpet", MODIFYVM_HPET, RTGETOPT_REQ_BOOL_ONOFF },
366 { "--iocache", MODIFYVM_IOCACHE, RTGETOPT_REQ_BOOL_ONOFF },
367 { "--iocachesize", MODIFYVM_IOCACHESIZE, RTGETOPT_REQ_UINT32 },
368 { "--faulttolerance", MODIFYVM_FAULT_TOLERANCE, RTGETOPT_REQ_STRING },
369 { "--faulttoleranceaddress", MODIFYVM_FAULT_TOLERANCE_ADDRESS, RTGETOPT_REQ_STRING },
370 { "--faulttoleranceport", MODIFYVM_FAULT_TOLERANCE_PORT, RTGETOPT_REQ_UINT32 },
371 { "--faulttolerancepassword", MODIFYVM_FAULT_TOLERANCE_PASSWORD, RTGETOPT_REQ_STRING },
372 { "--faulttolerancesyncinterval", MODIFYVM_FAULT_TOLERANCE_SYNC_INTERVAL, RTGETOPT_REQ_UINT32 },
373 { "--chipset", MODIFYVM_CHIPSET, RTGETOPT_REQ_STRING },
374#ifdef VBOX_WITH_VIDEOREC
375 { "--videocap", MODIFYVM_VIDEOCAP, RTGETOPT_REQ_BOOL_ONOFF },
376 { "--vcpenabled", MODIFYVM_VIDEOCAP, RTGETOPT_REQ_BOOL_ONOFF }, /* deprecated */
377 { "--videocapscreens", MODIFYVM_VIDEOCAP_SCREENS, RTGETOPT_REQ_STRING },
378 { "--vcpscreens", MODIFYVM_VIDEOCAP_SCREENS, RTGETOPT_REQ_STRING }, /* deprecated */
379 { "--videocapfile", MODIFYVM_VIDEOCAP_FILENAME, RTGETOPT_REQ_STRING },
380 { "--vcpfile", MODIFYVM_VIDEOCAP_FILENAME, RTGETOPT_REQ_STRING }, /* deprecated */
381 { "--videocapres", MODIFYVM_VIDEOCAP_RES, RTGETOPT_REQ_STRING },
382 { "--vcpwidth", MODIFYVM_VIDEOCAP_WIDTH, RTGETOPT_REQ_UINT32 }, /* deprecated */
383 { "--vcpheight", MODIFYVM_VIDEOCAP_HEIGHT, RTGETOPT_REQ_UINT32 }, /* deprecated */
384 { "--videocaprate", MODIFYVM_VIDEOCAP_RATE, RTGETOPT_REQ_UINT32 },
385 { "--vcprate", MODIFYVM_VIDEOCAP_RATE, RTGETOPT_REQ_UINT32 }, /* deprecated */
386 { "--videocapfps", MODIFYVM_VIDEOCAP_FPS, RTGETOPT_REQ_UINT32 },
387 { "--vcpfps", MODIFYVM_VIDEOCAP_FPS, RTGETOPT_REQ_UINT32 }, /* deprecated */
388 { "--videocapmaxtime", MODIFYVM_VIDEOCAP_MAXTIME, RTGETOPT_REQ_INT32 },
389 { "--vcpmaxtime", MODIFYVM_VIDEOCAP_MAXTIME, RTGETOPT_REQ_INT32 }, /* deprecated */
390 { "--videocapmaxsize", MODIFYVM_VIDEOCAP_MAXSIZE, RTGETOPT_REQ_INT32 },
391 { "--vcpmaxsize", MODIFYVM_VIDEOCAP_MAXSIZE, RTGETOPT_REQ_INT32 }, /* deprecated */
392 { "--videocapopts", MODIFYVM_VIDEOCAP_OPTIONS, RTGETOPT_REQ_STRING },
393 { "--vcpoptions", MODIFYVM_VIDEOCAP_OPTIONS, RTGETOPT_REQ_STRING }, /* deprecated */
394#endif
395 { "--autostart-enabled", MODIFYVM_AUTOSTART_ENABLED, RTGETOPT_REQ_BOOL_ONOFF },
396 { "--autostart-delay", MODIFYVM_AUTOSTART_DELAY, RTGETOPT_REQ_UINT32 },
397 { "--autostop-type", MODIFYVM_AUTOSTOP_TYPE, RTGETOPT_REQ_STRING },
398#ifdef VBOX_WITH_PCI_PASSTHROUGH
399 { "--pciattach", MODIFYVM_ATTACH_PCI, RTGETOPT_REQ_STRING },
400 { "--pcidetach", MODIFYVM_DETACH_PCI, RTGETOPT_REQ_STRING },
401#endif
402#ifdef VBOX_WITH_USB_CARDREADER
403 { "--usbcardreader", MODIFYVM_USBCARDREADER, RTGETOPT_REQ_BOOL_ONOFF },
404#endif
405 { "--defaultfrontend", MODIFYVM_DEFAULTFRONTEND, RTGETOPT_REQ_STRING },
406};
407
408static void vrdeWarningDeprecatedOption(const char *pszOption)
409{
410 RTStrmPrintf(g_pStdErr, "Warning: '--vrdp%s' is deprecated. Use '--vrde%s'.\n", pszOption, pszOption);
411}
412
413/** Parse PCI address in format 01:02.03 and convert it to the numeric representation. */
414static int32_t parsePci(const char* szPciAddr)
415{
416 char* pszNext = (char*)szPciAddr;
417 int rc;
418 uint8_t aVals[3] = {0, 0, 0};
419
420 rc = RTStrToUInt8Ex(pszNext, &pszNext, 16, &aVals[0]);
421 if (RT_FAILURE(rc) || pszNext == NULL || *pszNext != ':')
422 return -1;
423
424 rc = RTStrToUInt8Ex(pszNext+1, &pszNext, 16, &aVals[1]);
425 if (RT_FAILURE(rc) || pszNext == NULL || *pszNext != '.')
426 return -1;
427
428 rc = RTStrToUInt8Ex(pszNext+1, &pszNext, 16, &aVals[2]);
429 if (RT_FAILURE(rc) || pszNext == NULL)
430 return -1;
431
432 return (aVals[0] << 8) | (aVals[1] << 3) | (aVals[2] << 0);
433}
434
435void parseGroups(const char *pcszGroups, com::SafeArray<BSTR> *pGroups)
436{
437 while (pcszGroups)
438 {
439 char *pComma = RTStrStr(pcszGroups, ",");
440 if (pComma)
441 {
442 Bstr(pcszGroups, pComma - pcszGroups).detachTo(pGroups->appendedRaw());
443 pcszGroups = pComma + 1;
444 }
445 else
446 {
447 Bstr(pcszGroups).detachTo(pGroups->appendedRaw());
448 pcszGroups = NULL;
449 }
450 }
451}
452
453#ifdef VBOX_WITH_VIDEOREC
454static int parseScreens(const char *pcszScreens, com::SafeArray<BOOL> *pScreens)
455{
456 while (pcszScreens && *pcszScreens)
457 {
458 char *pszNext;
459 uint32_t iScreen;
460 int rc = RTStrToUInt32Ex(pcszScreens, &pszNext, 0, &iScreen);
461 if (RT_FAILURE(rc))
462 return 1;
463 if (iScreen >= pScreens->size())
464 return 1;
465 if (pszNext && *pszNext)
466 {
467 pszNext = RTStrStripL(pszNext);
468 if (*pszNext != ',')
469 return 1;
470 pszNext++;
471 }
472 (*pScreens)[iScreen] = true;
473 pcszScreens = pszNext;
474 }
475 return 0;
476}
477#endif
478
479static int parseNum(uint32_t uIndex, unsigned cMaxIndex, const char *pszName)
480{
481 if ( uIndex >= 1
482 && uIndex <= cMaxIndex)
483 return uIndex;
484 errorArgument("Invalid %s number %u", pszName, uIndex);
485 return 0;
486}
487
488RTEXITCODE handleModifyVM(HandlerArg *a)
489{
490 int c;
491 HRESULT rc;
492 Bstr name;
493
494 /* VM ID + at least one parameter. Parameter arguments are checked
495 * individually. */
496 if (a->argc < 2)
497 return errorSyntax(USAGE_MODIFYVM, "Not enough parameters");
498
499 /* try to find the given sessionMachine */
500 ComPtr<IMachine> machine;
501 CHECK_ERROR_RET(a->virtualBox, FindMachine(Bstr(a->argv[0]).raw(),
502 machine.asOutParam()), RTEXITCODE_FAILURE);
503
504
505 /* Get the number of network adapters */
506 ULONG NetworkAdapterCount = getMaxNics(a->virtualBox, machine);
507
508 /* open a session for the VM */
509 CHECK_ERROR_RET(machine, LockMachine(a->session, LockType_Write), RTEXITCODE_FAILURE);
510
511 /* get the mutable session sessionMachine */
512 ComPtr<IMachine> sessionMachine;
513 CHECK_ERROR_RET(a->session, COMGETTER(Machine)(sessionMachine.asOutParam()), RTEXITCODE_FAILURE);
514
515 ComPtr<IBIOSSettings> biosSettings;
516 sessionMachine->COMGETTER(BIOSSettings)(biosSettings.asOutParam());
517
518 RTGETOPTSTATE GetOptState;
519 RTGetOptInit(&GetOptState, a->argc, a->argv, g_aModifyVMOptions,
520 RT_ELEMENTS(g_aModifyVMOptions), 1, RTGETOPTINIT_FLAGS_NO_STD_OPTS);
521
522 RTGETOPTUNION ValueUnion;
523 while ( SUCCEEDED (rc)
524 && (c = RTGetOpt(&GetOptState, &ValueUnion)))
525 {
526 switch (c)
527 {
528 case MODIFYVM_NAME:
529 {
530 CHECK_ERROR(sessionMachine, COMSETTER(Name)(Bstr(ValueUnion.psz).raw()));
531 break;
532 }
533 case MODIFYVM_GROUPS:
534 {
535 com::SafeArray<BSTR> groups;
536 parseGroups(ValueUnion.psz, &groups);
537 CHECK_ERROR(sessionMachine, COMSETTER(Groups)(ComSafeArrayAsInParam(groups)));
538 break;
539 }
540 case MODIFYVM_DESCRIPTION:
541 {
542 CHECK_ERROR(sessionMachine, COMSETTER(Description)(Bstr(ValueUnion.psz).raw()));
543 break;
544 }
545 case MODIFYVM_OSTYPE:
546 {
547 ComPtr<IGuestOSType> guestOSType;
548 CHECK_ERROR(a->virtualBox, GetGuestOSType(Bstr(ValueUnion.psz).raw(),
549 guestOSType.asOutParam()));
550 if (SUCCEEDED(rc) && guestOSType)
551 {
552 CHECK_ERROR(sessionMachine, COMSETTER(OSTypeId)(Bstr(ValueUnion.psz).raw()));
553 }
554 else
555 {
556 errorArgument("Invalid guest OS type '%s'", ValueUnion.psz);
557 rc = E_FAIL;
558 }
559 break;
560 }
561
562 case MODIFYVM_ICONFILE:
563 {
564 RTFILE iconFile;
565 int vrc = RTFileOpen(&iconFile, ValueUnion.psz, RTFILE_O_READ | RTFILE_O_OPEN | RTFILE_O_DENY_WRITE);
566 if (RT_FAILURE(vrc))
567 {
568 RTMsgError("Cannot open file \"%s\": %Rrc", ValueUnion.psz, vrc);
569 rc = E_FAIL;
570 break;
571 }
572 uint64_t cbSize;
573 vrc = RTFileGetSize(iconFile, &cbSize);
574 if (RT_FAILURE(vrc))
575 {
576 RTMsgError("Cannot get size of file \"%s\": %Rrc", ValueUnion.psz, vrc);
577 rc = E_FAIL;
578 break;
579 }
580 if (cbSize > _256K)
581 {
582 RTMsgError("File \"%s\" is bigger than 256KByte", ValueUnion.psz);
583 rc = E_FAIL;
584 break;
585 }
586 SafeArray<BYTE> icon((size_t)cbSize);
587 rc = RTFileRead(iconFile, icon.raw(), (size_t)cbSize, NULL);
588 if (RT_FAILURE(vrc))
589 {
590 RTMsgError("Cannot read contents of file \"%s\": %Rrc", ValueUnion.psz, vrc);
591 rc = E_FAIL;
592 break;
593 }
594 RTFileClose(iconFile);
595 CHECK_ERROR(sessionMachine, COMSETTER(Icon)(ComSafeArrayAsInParam(icon)));
596 break;
597 }
598
599 case MODIFYVM_MEMORY:
600 {
601 CHECK_ERROR(sessionMachine, COMSETTER(MemorySize)(ValueUnion.u32));
602 break;
603 }
604
605 case MODIFYVM_PAGEFUSION:
606 {
607 CHECK_ERROR(sessionMachine, COMSETTER(PageFusionEnabled)(ValueUnion.f));
608 break;
609 }
610
611 case MODIFYVM_VRAM:
612 {
613 CHECK_ERROR(sessionMachine, COMSETTER(VRAMSize)(ValueUnion.u32));
614 break;
615 }
616
617 case MODIFYVM_FIRMWARE:
618 {
619 if (!RTStrICmp(ValueUnion.psz, "efi"))
620 {
621 CHECK_ERROR(sessionMachine, COMSETTER(FirmwareType)(FirmwareType_EFI));
622 }
623 else if (!RTStrICmp(ValueUnion.psz, "efi32"))
624 {
625 CHECK_ERROR(sessionMachine, COMSETTER(FirmwareType)(FirmwareType_EFI32));
626 }
627 else if (!RTStrICmp(ValueUnion.psz, "efi64"))
628 {
629 CHECK_ERROR(sessionMachine, COMSETTER(FirmwareType)(FirmwareType_EFI64));
630 }
631 else if (!RTStrICmp(ValueUnion.psz, "efidual"))
632 {
633 CHECK_ERROR(sessionMachine, COMSETTER(FirmwareType)(FirmwareType_EFIDUAL));
634 }
635 else if (!RTStrICmp(ValueUnion.psz, "bios"))
636 {
637 CHECK_ERROR(sessionMachine, COMSETTER(FirmwareType)(FirmwareType_BIOS));
638 }
639 else
640 {
641 errorArgument("Invalid --firmware argument '%s'", ValueUnion.psz);
642 rc = E_FAIL;
643 }
644 break;
645 }
646
647 case MODIFYVM_ACPI:
648 {
649 CHECK_ERROR(biosSettings, COMSETTER(ACPIEnabled)(ValueUnion.f));
650 break;
651 }
652
653 case MODIFYVM_IOAPIC:
654 {
655 CHECK_ERROR(biosSettings, COMSETTER(IOAPICEnabled)(ValueUnion.f));
656 break;
657 }
658
659 case MODIFYVM_PAE:
660 {
661 CHECK_ERROR(sessionMachine, SetCPUProperty(CPUPropertyType_PAE, ValueUnion.f));
662 break;
663 }
664
665 case MODIFYVM_LONGMODE:
666 {
667 CHECK_ERROR(sessionMachine, SetCPUProperty(CPUPropertyType_LongMode, ValueUnion.f));
668 break;
669 }
670
671 case MODIFYVM_CPUID_PORTABILITY:
672 {
673 CHECK_ERROR(sessionMachine, COMSETTER(CPUIDPortabilityLevel)(ValueUnion.u32));
674 break;
675 }
676
677 case MODIFYVM_TFRESET:
678 {
679 CHECK_ERROR(sessionMachine, SetCPUProperty(CPUPropertyType_TripleFaultReset, ValueUnion.f));
680 break;
681 }
682
683 case MODIFYVM_APIC:
684 {
685 CHECK_ERROR(sessionMachine, SetCPUProperty(CPUPropertyType_APIC, ValueUnion.f));
686 break;
687 }
688
689 case MODIFYVM_X2APIC:
690 {
691 CHECK_ERROR(sessionMachine, SetCPUProperty(CPUPropertyType_X2APIC, ValueUnion.f));
692 break;
693 }
694
695 case MODIFYVM_PARAVIRTPROVIDER:
696 {
697 if ( !RTStrICmp(ValueUnion.psz, "none")
698 || !RTStrICmp(ValueUnion.psz, "disabled"))
699 CHECK_ERROR(sessionMachine, COMSETTER(ParavirtProvider)(ParavirtProvider_None));
700 else if (!RTStrICmp(ValueUnion.psz, "default"))
701 CHECK_ERROR(sessionMachine, COMSETTER(ParavirtProvider)(ParavirtProvider_Default));
702 else if (!RTStrICmp(ValueUnion.psz, "legacy"))
703 CHECK_ERROR(sessionMachine, COMSETTER(ParavirtProvider)(ParavirtProvider_Legacy));
704 else if (!RTStrICmp(ValueUnion.psz, "minimal"))
705 CHECK_ERROR(sessionMachine, COMSETTER(ParavirtProvider)(ParavirtProvider_Minimal));
706 else if (!RTStrICmp(ValueUnion.psz, "hyperv"))
707 CHECK_ERROR(sessionMachine, COMSETTER(ParavirtProvider)(ParavirtProvider_HyperV));
708 else if (!RTStrICmp(ValueUnion.psz, "kvm"))
709 CHECK_ERROR(sessionMachine, COMSETTER(ParavirtProvider)(ParavirtProvider_KVM));
710 else
711 {
712 errorArgument("Invalid --paravirtprovider argument '%s'", ValueUnion.psz);
713 rc = E_FAIL;
714 }
715 break;
716 }
717
718 case MODIFYVM_PARAVIRTDEBUG:
719 {
720 CHECK_ERROR(sessionMachine, COMSETTER(ParavirtDebug)(Bstr(ValueUnion.psz).raw()));
721 break;
722 }
723
724 case MODIFYVM_HWVIRTEX:
725 {
726 CHECK_ERROR(sessionMachine, SetHWVirtExProperty(HWVirtExPropertyType_Enabled, ValueUnion.f));
727 break;
728 }
729
730 case MODIFYVM_SETCPUID:
731 {
732 uint32_t id = ValueUnion.u32;
733 uint32_t aValue[4];
734
735 for (unsigned i = 0; i < 4; i++)
736 {
737 int vrc = RTGetOptFetchValue(&GetOptState, &ValueUnion, RTGETOPT_REQ_UINT32 | RTGETOPT_FLAG_HEX);
738 if (RT_FAILURE(vrc))
739 return errorSyntax(USAGE_MODIFYVM,
740 "Missing or Invalid argument to '%s'",
741 GetOptState.pDef->pszLong);
742 aValue[i] = ValueUnion.u32;
743 }
744 CHECK_ERROR(sessionMachine, SetCPUIDLeaf(id, aValue[0], aValue[1], aValue[2], aValue[3]));
745 break;
746 }
747
748 case MODIFYVM_DELCPUID:
749 {
750 CHECK_ERROR(sessionMachine, RemoveCPUIDLeaf(ValueUnion.u32));
751 break;
752 }
753
754 case MODIFYVM_DELALLCPUID:
755 {
756 CHECK_ERROR(sessionMachine, RemoveAllCPUIDLeaves());
757 break;
758 }
759
760 case MODIFYVM_NESTEDPAGING:
761 {
762 CHECK_ERROR(sessionMachine, SetHWVirtExProperty(HWVirtExPropertyType_NestedPaging, ValueUnion.f));
763 break;
764 }
765
766 case MODIFYVM_LARGEPAGES:
767 {
768 CHECK_ERROR(sessionMachine, SetHWVirtExProperty(HWVirtExPropertyType_LargePages, ValueUnion.f));
769 break;
770 }
771
772 case MODIFYVM_VTXVPID:
773 {
774 CHECK_ERROR(sessionMachine, SetHWVirtExProperty(HWVirtExPropertyType_VPID, ValueUnion.f));
775 break;
776 }
777
778 case MODIFYVM_VTXUX:
779 {
780 CHECK_ERROR(sessionMachine, SetHWVirtExProperty(HWVirtExPropertyType_UnrestrictedExecution, ValueUnion.f));
781 break;
782 }
783
784 case MODIFYVM_CPUS:
785 {
786 CHECK_ERROR(sessionMachine, COMSETTER(CPUCount)(ValueUnion.u32));
787 break;
788 }
789
790 case MODIFYVM_RTCUSEUTC:
791 {
792 CHECK_ERROR(sessionMachine, COMSETTER(RTCUseUTC)(ValueUnion.f));
793 break;
794 }
795
796 case MODIFYVM_CPUHOTPLUG:
797 {
798 CHECK_ERROR(sessionMachine, COMSETTER(CPUHotPlugEnabled)(ValueUnion.f));
799 break;
800 }
801
802 case MODIFYVM_CPU_PROFILE:
803 {
804 CHECK_ERROR(sessionMachine, COMSETTER(CPUProfile)(Bstr(ValueUnion.psz).raw()));
805 break;
806 }
807
808 case MODIFYVM_PLUGCPU:
809 {
810 CHECK_ERROR(sessionMachine, HotPlugCPU(ValueUnion.u32));
811 break;
812 }
813
814 case MODIFYVM_UNPLUGCPU:
815 {
816 CHECK_ERROR(sessionMachine, HotUnplugCPU(ValueUnion.u32));
817 break;
818 }
819
820 case MODIFYVM_CPU_EXECTUION_CAP:
821 {
822 CHECK_ERROR(sessionMachine, COMSETTER(CPUExecutionCap)(ValueUnion.u32));
823 break;
824 }
825
826 case MODIFYVM_GRAPHICSCONTROLLER:
827 {
828 if ( !RTStrICmp(ValueUnion.psz, "none")
829 || !RTStrICmp(ValueUnion.psz, "disabled"))
830 CHECK_ERROR(sessionMachine, COMSETTER(GraphicsControllerType)(GraphicsControllerType_Null));
831 else if ( !RTStrICmp(ValueUnion.psz, "vboxvga")
832 || !RTStrICmp(ValueUnion.psz, "vbox")
833 || !RTStrICmp(ValueUnion.psz, "vga")
834 || !RTStrICmp(ValueUnion.psz, "vesa"))
835 CHECK_ERROR(sessionMachine, COMSETTER(GraphicsControllerType)(GraphicsControllerType_VBoxVGA));
836#ifdef VBOX_WITH_VMSVGA
837 else if ( !RTStrICmp(ValueUnion.psz, "vmsvga")
838 || !RTStrICmp(ValueUnion.psz, "vmware"))
839 CHECK_ERROR(sessionMachine, COMSETTER(GraphicsControllerType)(GraphicsControllerType_VMSVGA));
840#endif
841 else
842 {
843 errorArgument("Invalid --graphicscontroller argument '%s'", ValueUnion.psz);
844 rc = E_FAIL;
845 }
846 break;
847 }
848
849 case MODIFYVM_MONITORCOUNT:
850 {
851 CHECK_ERROR(sessionMachine, COMSETTER(MonitorCount)(ValueUnion.u32));
852 break;
853 }
854
855 case MODIFYVM_ACCELERATE3D:
856 {
857 CHECK_ERROR(sessionMachine, COMSETTER(Accelerate3DEnabled)(ValueUnion.f));
858 break;
859 }
860
861#ifdef VBOX_WITH_VIDEOHWACCEL
862 case MODIFYVM_ACCELERATE2DVIDEO:
863 {
864 CHECK_ERROR(sessionMachine, COMSETTER(Accelerate2DVideoEnabled)(ValueUnion.f));
865 break;
866 }
867#endif
868
869 case MODIFYVM_BIOSLOGOFADEIN:
870 {
871 CHECK_ERROR(biosSettings, COMSETTER(LogoFadeIn)(ValueUnion.f));
872 break;
873 }
874
875 case MODIFYVM_BIOSLOGOFADEOUT:
876 {
877 CHECK_ERROR(biosSettings, COMSETTER(LogoFadeOut)(ValueUnion.f));
878 break;
879 }
880
881 case MODIFYVM_BIOSLOGODISPLAYTIME:
882 {
883 CHECK_ERROR(biosSettings, COMSETTER(LogoDisplayTime)(ValueUnion.u32));
884 break;
885 }
886
887 case MODIFYVM_BIOSLOGOIMAGEPATH:
888 {
889 CHECK_ERROR(biosSettings, COMSETTER(LogoImagePath)(Bstr(ValueUnion.psz).raw()));
890 break;
891 }
892
893 case MODIFYVM_BIOSBOOTMENU:
894 {
895 if (!RTStrICmp(ValueUnion.psz, "disabled"))
896 {
897 CHECK_ERROR(biosSettings, COMSETTER(BootMenuMode)(BIOSBootMenuMode_Disabled));
898 }
899 else if (!RTStrICmp(ValueUnion.psz, "menuonly"))
900 {
901 CHECK_ERROR(biosSettings, COMSETTER(BootMenuMode)(BIOSBootMenuMode_MenuOnly));
902 }
903 else if (!RTStrICmp(ValueUnion.psz, "messageandmenu"))
904 {
905 CHECK_ERROR(biosSettings, COMSETTER(BootMenuMode)(BIOSBootMenuMode_MessageAndMenu));
906 }
907 else
908 {
909 errorArgument("Invalid --biosbootmenu argument '%s'", ValueUnion.psz);
910 rc = E_FAIL;
911 }
912 break;
913 }
914
915 case MODIFYVM_BIOSAPIC:
916 {
917 if (!RTStrICmp(ValueUnion.psz, "disabled"))
918 {
919 CHECK_ERROR(biosSettings, COMSETTER(APICMode)(APICMode_Disabled));
920 }
921 else if ( !RTStrICmp(ValueUnion.psz, "apic")
922 || !RTStrICmp(ValueUnion.psz, "lapic")
923 || !RTStrICmp(ValueUnion.psz, "xapic"))
924 {
925 CHECK_ERROR(biosSettings, COMSETTER(APICMode)(APICMode_APIC));
926 }
927 else if (!RTStrICmp(ValueUnion.psz, "x2apic"))
928 {
929 CHECK_ERROR(biosSettings, COMSETTER(APICMode)(APICMode_X2APIC));
930 }
931 else
932 {
933 errorArgument("Invalid --biosapic argument '%s'", ValueUnion.psz);
934 rc = E_FAIL;
935 }
936 break;
937 }
938
939 case MODIFYVM_BIOSSYSTEMTIMEOFFSET:
940 {
941 CHECK_ERROR(biosSettings, COMSETTER(TimeOffset)(ValueUnion.i64));
942 break;
943 }
944
945 case MODIFYVM_BIOSPXEDEBUG:
946 {
947 CHECK_ERROR(biosSettings, COMSETTER(PXEDebugEnabled)(ValueUnion.f));
948 break;
949 }
950
951 case MODIFYVM_BOOT:
952 {
953 if (!RTStrICmp(ValueUnion.psz, "none"))
954 {
955 CHECK_ERROR(sessionMachine, SetBootOrder(GetOptState.uIndex, DeviceType_Null));
956 }
957 else if (!RTStrICmp(ValueUnion.psz, "floppy"))
958 {
959 CHECK_ERROR(sessionMachine, SetBootOrder(GetOptState.uIndex, DeviceType_Floppy));
960 }
961 else if (!RTStrICmp(ValueUnion.psz, "dvd"))
962 {
963 CHECK_ERROR(sessionMachine, SetBootOrder(GetOptState.uIndex, DeviceType_DVD));
964 }
965 else if (!RTStrICmp(ValueUnion.psz, "disk"))
966 {
967 CHECK_ERROR(sessionMachine, SetBootOrder(GetOptState.uIndex, DeviceType_HardDisk));
968 }
969 else if (!RTStrICmp(ValueUnion.psz, "net"))
970 {
971 CHECK_ERROR(sessionMachine, SetBootOrder(GetOptState.uIndex, DeviceType_Network));
972 }
973 else
974 return errorArgument("Invalid boot device '%s'", ValueUnion.psz);
975 break;
976 }
977
978 case MODIFYVM_HDA: // deprecated
979 case MODIFYVM_HDB: // deprecated
980 case MODIFYVM_HDD: // deprecated
981 case MODIFYVM_SATAPORT: // deprecated
982 {
983 uint32_t u1 = 0, u2 = 0;
984 Bstr bstrController = L"IDE Controller";
985
986 switch (c)
987 {
988 case MODIFYVM_HDA: // deprecated
989 u1 = 0;
990 break;
991
992 case MODIFYVM_HDB: // deprecated
993 u1 = 0;
994 u2 = 1;
995 break;
996
997 case MODIFYVM_HDD: // deprecated
998 u1 = 1;
999 u2 = 1;
1000 break;
1001
1002 case MODIFYVM_SATAPORT: // deprecated
1003 u1 = GetOptState.uIndex;
1004 bstrController = L"SATA";
1005 break;
1006 }
1007
1008 if (!RTStrICmp(ValueUnion.psz, "none"))
1009 {
1010 sessionMachine->DetachDevice(bstrController.raw(), u1, u2);
1011 }
1012 else
1013 {
1014 ComPtr<IMedium> hardDisk;
1015 rc = openMedium(a, ValueUnion.psz, DeviceType_HardDisk,
1016 AccessMode_ReadWrite, hardDisk,
1017 false /* fForceNewUuidOnOpen */,
1018 false /* fSilent */);
1019 if (FAILED(rc))
1020 break;
1021 if (hardDisk)
1022 {
1023 CHECK_ERROR(sessionMachine, AttachDevice(bstrController.raw(),
1024 u1, u2,
1025 DeviceType_HardDisk,
1026 hardDisk));
1027 }
1028 else
1029 rc = E_FAIL;
1030 }
1031 break;
1032 }
1033
1034 case MODIFYVM_IDECONTROLLER: // deprecated
1035 {
1036 ComPtr<IStorageController> storageController;
1037 CHECK_ERROR(sessionMachine, GetStorageControllerByName(Bstr("IDE Controller").raw(),
1038 storageController.asOutParam()));
1039
1040 if (!RTStrICmp(ValueUnion.psz, "PIIX3"))
1041 {
1042 CHECK_ERROR(storageController, COMSETTER(ControllerType)(StorageControllerType_PIIX3));
1043 }
1044 else if (!RTStrICmp(ValueUnion.psz, "PIIX4"))
1045 {
1046 CHECK_ERROR(storageController, COMSETTER(ControllerType)(StorageControllerType_PIIX4));
1047 }
1048 else if (!RTStrICmp(ValueUnion.psz, "ICH6"))
1049 {
1050 CHECK_ERROR(storageController, COMSETTER(ControllerType)(StorageControllerType_ICH6));
1051 }
1052 else
1053 {
1054 errorArgument("Invalid --idecontroller argument '%s'", ValueUnion.psz);
1055 rc = E_FAIL;
1056 }
1057 break;
1058 }
1059
1060 case MODIFYVM_SATAPORTCOUNT: // deprecated
1061 {
1062 ComPtr<IStorageController> SataCtl;
1063 CHECK_ERROR(sessionMachine, GetStorageControllerByName(Bstr("SATA").raw(),
1064 SataCtl.asOutParam()));
1065
1066 if (SUCCEEDED(rc) && ValueUnion.u32 > 0)
1067 CHECK_ERROR(SataCtl, COMSETTER(PortCount)(ValueUnion.u32));
1068 break;
1069 }
1070
1071 case MODIFYVM_SATA: // deprecated
1072 {
1073 if (!RTStrICmp(ValueUnion.psz, "on") || !RTStrICmp(ValueUnion.psz, "enable"))
1074 {
1075 ComPtr<IStorageController> ctl;
1076 CHECK_ERROR(sessionMachine, AddStorageController(Bstr("SATA").raw(),
1077 StorageBus_SATA,
1078 ctl.asOutParam()));
1079 CHECK_ERROR(ctl, COMSETTER(ControllerType)(StorageControllerType_IntelAhci));
1080 }
1081 else if (!RTStrICmp(ValueUnion.psz, "off") || !RTStrICmp(ValueUnion.psz, "disable"))
1082 CHECK_ERROR(sessionMachine, RemoveStorageController(Bstr("SATA").raw()));
1083 else
1084 return errorArgument("Invalid --usb argument '%s'", ValueUnion.psz);
1085 break;
1086 }
1087
1088 case MODIFYVM_SCSIPORT: // deprecated
1089 {
1090 if (!RTStrICmp(ValueUnion.psz, "none"))
1091 {
1092 rc = sessionMachine->DetachDevice(Bstr("LsiLogic").raw(),
1093 GetOptState.uIndex, 0);
1094 if (FAILED(rc))
1095 CHECK_ERROR(sessionMachine, DetachDevice(Bstr("BusLogic").raw(),
1096 GetOptState.uIndex, 0));
1097 }
1098 else
1099 {
1100 ComPtr<IMedium> hardDisk;
1101 rc = openMedium(a, ValueUnion.psz, DeviceType_HardDisk,
1102 AccessMode_ReadWrite, hardDisk,
1103 false /* fForceNewUuidOnOpen */,
1104 false /* fSilent */);
1105 if (FAILED(rc))
1106 break;
1107 if (hardDisk)
1108 {
1109 rc = sessionMachine->AttachDevice(Bstr("LsiLogic").raw(),
1110 GetOptState.uIndex, 0,
1111 DeviceType_HardDisk,
1112 hardDisk);
1113 if (FAILED(rc))
1114 CHECK_ERROR(sessionMachine,
1115 AttachDevice(Bstr("BusLogic").raw(),
1116 GetOptState.uIndex, 0,
1117 DeviceType_HardDisk,
1118 hardDisk));
1119 }
1120 else
1121 rc = E_FAIL;
1122 }
1123 break;
1124 }
1125
1126 case MODIFYVM_SCSITYPE: // deprecated
1127 {
1128 ComPtr<IStorageController> ctl;
1129
1130 if (!RTStrICmp(ValueUnion.psz, "LsiLogic"))
1131 {
1132 rc = sessionMachine->RemoveStorageController(Bstr("BusLogic").raw());
1133 if (FAILED(rc))
1134 CHECK_ERROR(sessionMachine, RemoveStorageController(Bstr("LsiLogic").raw()));
1135
1136 CHECK_ERROR(sessionMachine,
1137 AddStorageController(Bstr("LsiLogic").raw(),
1138 StorageBus_SCSI,
1139 ctl.asOutParam()));
1140
1141 if (SUCCEEDED(rc))
1142 CHECK_ERROR(ctl, COMSETTER(ControllerType)(StorageControllerType_LsiLogic));
1143 }
1144 else if (!RTStrICmp(ValueUnion.psz, "BusLogic"))
1145 {
1146 rc = sessionMachine->RemoveStorageController(Bstr("LsiLogic").raw());
1147 if (FAILED(rc))
1148 CHECK_ERROR(sessionMachine, RemoveStorageController(Bstr("BusLogic").raw()));
1149
1150 CHECK_ERROR(sessionMachine,
1151 AddStorageController(Bstr("BusLogic").raw(),
1152 StorageBus_SCSI,
1153 ctl.asOutParam()));
1154
1155 if (SUCCEEDED(rc))
1156 CHECK_ERROR(ctl, COMSETTER(ControllerType)(StorageControllerType_BusLogic));
1157 }
1158 else
1159 return errorArgument("Invalid --scsitype argument '%s'", ValueUnion.psz);
1160 break;
1161 }
1162
1163 case MODIFYVM_SCSI: // deprecated
1164 {
1165 if (!RTStrICmp(ValueUnion.psz, "on") || !RTStrICmp(ValueUnion.psz, "enable"))
1166 {
1167 ComPtr<IStorageController> ctl;
1168
1169 CHECK_ERROR(sessionMachine, AddStorageController(Bstr("BusLogic").raw(),
1170 StorageBus_SCSI,
1171 ctl.asOutParam()));
1172 if (SUCCEEDED(rc))
1173 CHECK_ERROR(ctl, COMSETTER(ControllerType)(StorageControllerType_BusLogic));
1174 }
1175 else if (!RTStrICmp(ValueUnion.psz, "off") || !RTStrICmp(ValueUnion.psz, "disable"))
1176 {
1177 rc = sessionMachine->RemoveStorageController(Bstr("BusLogic").raw());
1178 if (FAILED(rc))
1179 CHECK_ERROR(sessionMachine, RemoveStorageController(Bstr("LsiLogic").raw()));
1180 }
1181 break;
1182 }
1183
1184 case MODIFYVM_DVDPASSTHROUGH: // deprecated
1185 {
1186 CHECK_ERROR(sessionMachine, PassthroughDevice(Bstr("IDE Controller").raw(),
1187 1, 0,
1188 !RTStrICmp(ValueUnion.psz, "on")));
1189 break;
1190 }
1191
1192 case MODIFYVM_DVD: // deprecated
1193 {
1194 ComPtr<IMedium> dvdMedium;
1195
1196 /* unmount? */
1197 if (!RTStrICmp(ValueUnion.psz, "none"))
1198 {
1199 /* nothing to do, NULL object will cause unmount */
1200 }
1201 /* host drive? */
1202 else if (!RTStrNICmp(ValueUnion.psz, RT_STR_TUPLE("host:")))
1203 {
1204 ComPtr<IHost> host;
1205 CHECK_ERROR(a->virtualBox, COMGETTER(Host)(host.asOutParam()));
1206 rc = host->FindHostDVDDrive(Bstr(ValueUnion.psz + 5).raw(),
1207 dvdMedium.asOutParam());
1208 if (!dvdMedium)
1209 {
1210 /* 2nd try: try with the real name, important on Linux+libhal */
1211 char szPathReal[RTPATH_MAX];
1212 if (RT_FAILURE(RTPathReal(ValueUnion.psz + 5, szPathReal, sizeof(szPathReal))))
1213 {
1214 errorArgument("Invalid host DVD drive name \"%s\"", ValueUnion.psz + 5);
1215 rc = E_FAIL;
1216 break;
1217 }
1218 rc = host->FindHostDVDDrive(Bstr(szPathReal).raw(),
1219 dvdMedium.asOutParam());
1220 if (!dvdMedium)
1221 {
1222 errorArgument("Invalid host DVD drive name \"%s\"", ValueUnion.psz + 5);
1223 rc = E_FAIL;
1224 break;
1225 }
1226 }
1227 }
1228 else
1229 {
1230 rc = openMedium(a, ValueUnion.psz, DeviceType_DVD,
1231 AccessMode_ReadOnly, dvdMedium,
1232 false /* fForceNewUuidOnOpen */,
1233 false /* fSilent */);
1234 if (FAILED(rc))
1235 break;
1236 if (!dvdMedium)
1237 {
1238 rc = E_FAIL;
1239 break;
1240 }
1241 }
1242
1243 CHECK_ERROR(sessionMachine, MountMedium(Bstr("IDE Controller").raw(),
1244 1, 0,
1245 dvdMedium,
1246 FALSE /* aForce */));
1247 break;
1248 }
1249
1250 case MODIFYVM_FLOPPY: // deprecated
1251 {
1252 ComPtr<IMedium> floppyMedium;
1253 ComPtr<IMediumAttachment> floppyAttachment;
1254 sessionMachine->GetMediumAttachment(Bstr("Floppy Controller").raw(),
1255 0, 0, floppyAttachment.asOutParam());
1256
1257 /* disable? */
1258 if (!RTStrICmp(ValueUnion.psz, "disabled"))
1259 {
1260 /* disable the controller */
1261 if (floppyAttachment)
1262 CHECK_ERROR(sessionMachine, DetachDevice(Bstr("Floppy Controller").raw(),
1263 0, 0));
1264 }
1265 else
1266 {
1267 /* enable the controller */
1268 if (!floppyAttachment)
1269 CHECK_ERROR(sessionMachine, AttachDeviceWithoutMedium(Bstr("Floppy Controller").raw(),
1270 0, 0,
1271 DeviceType_Floppy));
1272
1273 /* unmount? */
1274 if ( !RTStrICmp(ValueUnion.psz, "none")
1275 || !RTStrICmp(ValueUnion.psz, "empty")) // deprecated
1276 {
1277 /* nothing to do, NULL object will cause unmount */
1278 }
1279 /* host drive? */
1280 else if (!RTStrNICmp(ValueUnion.psz, RT_STR_TUPLE("host:")))
1281 {
1282 ComPtr<IHost> host;
1283 CHECK_ERROR(a->virtualBox, COMGETTER(Host)(host.asOutParam()));
1284 rc = host->FindHostFloppyDrive(Bstr(ValueUnion.psz + 5).raw(),
1285 floppyMedium.asOutParam());
1286 if (!floppyMedium)
1287 {
1288 errorArgument("Invalid host floppy drive name \"%s\"", ValueUnion.psz + 5);
1289 rc = E_FAIL;
1290 break;
1291 }
1292 }
1293 else
1294 {
1295 rc = openMedium(a, ValueUnion.psz, DeviceType_Floppy,
1296 AccessMode_ReadWrite, floppyMedium,
1297 false /* fForceNewUuidOnOpen */,
1298 false /* fSilent */);
1299 if (FAILED(rc))
1300 break;
1301 if (!floppyMedium)
1302 {
1303 rc = E_FAIL;
1304 break;
1305 }
1306 }
1307 CHECK_ERROR(sessionMachine, MountMedium(Bstr("Floppy Controller").raw(),
1308 0, 0,
1309 floppyMedium,
1310 FALSE /* aForce */));
1311 }
1312 break;
1313 }
1314
1315 case MODIFYVM_NICTRACEFILE:
1316 {
1317
1318 if (!parseNum(GetOptState.uIndex, NetworkAdapterCount, "NIC"))
1319 break;
1320
1321 ComPtr<INetworkAdapter> nic;
1322 CHECK_ERROR_BREAK(sessionMachine, GetNetworkAdapter(GetOptState.uIndex - 1, nic.asOutParam()));
1323 ASSERT(nic);
1324
1325 CHECK_ERROR(nic, COMSETTER(TraceFile)(Bstr(ValueUnion.psz).raw()));
1326 break;
1327 }
1328
1329 case MODIFYVM_NICTRACE:
1330 {
1331 if (!parseNum(GetOptState.uIndex, NetworkAdapterCount, "NIC"))
1332 break;
1333
1334 ComPtr<INetworkAdapter> nic;
1335 CHECK_ERROR_BREAK(sessionMachine, GetNetworkAdapter(GetOptState.uIndex - 1, nic.asOutParam()));
1336 ASSERT(nic);
1337
1338 CHECK_ERROR(nic, COMSETTER(TraceEnabled)(ValueUnion.f));
1339 break;
1340 }
1341
1342 case MODIFYVM_NICPROPERTY:
1343 {
1344 if (!parseNum(GetOptState.uIndex, NetworkAdapterCount, "NIC"))
1345 break;
1346
1347 ComPtr<INetworkAdapter> nic;
1348 CHECK_ERROR_BREAK(sessionMachine, GetNetworkAdapter(GetOptState.uIndex - 1, nic.asOutParam()));
1349 ASSERT(nic);
1350
1351 if (nic)
1352 {
1353 /* Parse 'name=value' */
1354 char *pszProperty = RTStrDup(ValueUnion.psz);
1355 if (pszProperty)
1356 {
1357 char *pDelimiter = strchr(pszProperty, '=');
1358 if (pDelimiter)
1359 {
1360 *pDelimiter = '\0';
1361
1362 Bstr bstrName = pszProperty;
1363 Bstr bstrValue = &pDelimiter[1];
1364 CHECK_ERROR(nic, SetProperty(bstrName.raw(), bstrValue.raw()));
1365 }
1366 else
1367 {
1368 errorArgument("Invalid --nicproperty%d argument '%s'", GetOptState.uIndex, ValueUnion.psz);
1369 rc = E_FAIL;
1370 }
1371 RTStrFree(pszProperty);
1372 }
1373 else
1374 {
1375 RTStrmPrintf(g_pStdErr, "Error: Failed to allocate memory for --nicproperty%d '%s'\n", GetOptState.uIndex, ValueUnion.psz);
1376 rc = E_FAIL;
1377 }
1378 }
1379 break;
1380 }
1381 case MODIFYVM_NICTYPE:
1382 {
1383 if (!parseNum(GetOptState.uIndex, NetworkAdapterCount, "NIC"))
1384 break;
1385
1386 ComPtr<INetworkAdapter> nic;
1387 CHECK_ERROR_BREAK(sessionMachine, GetNetworkAdapter(GetOptState.uIndex - 1, nic.asOutParam()));
1388 ASSERT(nic);
1389
1390 if (!RTStrICmp(ValueUnion.psz, "Am79C970A"))
1391 {
1392 CHECK_ERROR(nic, COMSETTER(AdapterType)(NetworkAdapterType_Am79C970A));
1393 }
1394 else if (!RTStrICmp(ValueUnion.psz, "Am79C973"))
1395 {
1396 CHECK_ERROR(nic, COMSETTER(AdapterType)(NetworkAdapterType_Am79C973));
1397 }
1398#ifdef VBOX_WITH_E1000
1399 else if (!RTStrICmp(ValueUnion.psz, "82540EM"))
1400 {
1401 CHECK_ERROR(nic, COMSETTER(AdapterType)(NetworkAdapterType_I82540EM));
1402 }
1403 else if (!RTStrICmp(ValueUnion.psz, "82543GC"))
1404 {
1405 CHECK_ERROR(nic, COMSETTER(AdapterType)(NetworkAdapterType_I82543GC));
1406 }
1407 else if (!RTStrICmp(ValueUnion.psz, "82545EM"))
1408 {
1409 CHECK_ERROR(nic, COMSETTER(AdapterType)(NetworkAdapterType_I82545EM));
1410 }
1411#endif
1412#ifdef VBOX_WITH_VIRTIO
1413 else if (!RTStrICmp(ValueUnion.psz, "virtio"))
1414 {
1415 CHECK_ERROR(nic, COMSETTER(AdapterType)(NetworkAdapterType_Virtio));
1416 }
1417#endif /* VBOX_WITH_VIRTIO */
1418 else
1419 {
1420 errorArgument("Invalid NIC type '%s' specified for NIC %u", ValueUnion.psz, GetOptState.uIndex);
1421 rc = E_FAIL;
1422 }
1423 break;
1424 }
1425
1426 case MODIFYVM_NICSPEED:
1427 {
1428 if (!parseNum(GetOptState.uIndex, NetworkAdapterCount, "NIC"))
1429 break;
1430
1431 ComPtr<INetworkAdapter> nic;
1432 CHECK_ERROR_BREAK(sessionMachine, GetNetworkAdapter(GetOptState.uIndex - 1, nic.asOutParam()));
1433 ASSERT(nic);
1434
1435 CHECK_ERROR(nic, COMSETTER(LineSpeed)(ValueUnion.u32));
1436 break;
1437 }
1438
1439 case MODIFYVM_NICBOOTPRIO:
1440 {
1441 if (!parseNum(GetOptState.uIndex, NetworkAdapterCount, "NIC"))
1442 break;
1443
1444 ComPtr<INetworkAdapter> nic;
1445 CHECK_ERROR_BREAK(sessionMachine, GetNetworkAdapter(GetOptState.uIndex - 1, nic.asOutParam()));
1446 ASSERT(nic);
1447
1448 /* Somewhat arbitrary limitation - we can pass a list of up to 4 PCI devices
1449 * to the PXE ROM, hence only boot priorities 1-4 are allowed (in addition to
1450 * 0 for the default lowest priority).
1451 */
1452 if (ValueUnion.u32 > 4)
1453 {
1454 errorArgument("Invalid boot priority '%u' specfied for NIC %u", ValueUnion.u32, GetOptState.uIndex);
1455 rc = E_FAIL;
1456 }
1457 else
1458 {
1459 CHECK_ERROR(nic, COMSETTER(BootPriority)(ValueUnion.u32));
1460 }
1461 break;
1462 }
1463
1464 case MODIFYVM_NICPROMISC:
1465 {
1466 NetworkAdapterPromiscModePolicy_T enmPromiscModePolicy;
1467 if (!RTStrICmp(ValueUnion.psz, "deny"))
1468 enmPromiscModePolicy = NetworkAdapterPromiscModePolicy_Deny;
1469 else if ( !RTStrICmp(ValueUnion.psz, "allow-vms")
1470 || !RTStrICmp(ValueUnion.psz, "allow-network"))
1471 enmPromiscModePolicy = NetworkAdapterPromiscModePolicy_AllowNetwork;
1472 else if (!RTStrICmp(ValueUnion.psz, "allow-all"))
1473 enmPromiscModePolicy = NetworkAdapterPromiscModePolicy_AllowAll;
1474 else
1475 {
1476 errorArgument("Unknown promiscuous mode policy '%s'", ValueUnion.psz);
1477 rc = E_INVALIDARG;
1478 break;
1479 }
1480
1481 if (!parseNum(GetOptState.uIndex, NetworkAdapterCount, "NIC"))
1482 break;
1483
1484 ComPtr<INetworkAdapter> nic;
1485 CHECK_ERROR_BREAK(sessionMachine, GetNetworkAdapter(GetOptState.uIndex - 1, nic.asOutParam()));
1486 ASSERT(nic);
1487
1488 CHECK_ERROR(nic, COMSETTER(PromiscModePolicy)(enmPromiscModePolicy));
1489 break;
1490 }
1491
1492 case MODIFYVM_NICBWGROUP:
1493 {
1494 if (!parseNum(GetOptState.uIndex, NetworkAdapterCount, "NIC"))
1495 break;
1496
1497 ComPtr<INetworkAdapter> nic;
1498 CHECK_ERROR_BREAK(sessionMachine, GetNetworkAdapter(GetOptState.uIndex - 1, nic.asOutParam()));
1499 ASSERT(nic);
1500
1501 if (!RTStrICmp(ValueUnion.psz, "none"))
1502 {
1503 /* Just remove the bandwidth group. */
1504 CHECK_ERROR(nic, COMSETTER(BandwidthGroup)(NULL));
1505 }
1506 else
1507 {
1508 ComPtr<IBandwidthControl> bwCtrl;
1509 ComPtr<IBandwidthGroup> bwGroup;
1510
1511 CHECK_ERROR(sessionMachine, COMGETTER(BandwidthControl)(bwCtrl.asOutParam()));
1512
1513 if (SUCCEEDED(rc))
1514 {
1515 CHECK_ERROR(bwCtrl, GetBandwidthGroup(Bstr(ValueUnion.psz).raw(), bwGroup.asOutParam()));
1516 if (SUCCEEDED(rc))
1517 {
1518 CHECK_ERROR(nic, COMSETTER(BandwidthGroup)(bwGroup));
1519 }
1520 }
1521 }
1522 break;
1523 }
1524
1525 case MODIFYVM_NIC:
1526 {
1527 if (!parseNum(GetOptState.uIndex, NetworkAdapterCount, "NIC"))
1528 break;
1529
1530 ComPtr<INetworkAdapter> nic;
1531 CHECK_ERROR_BREAK(sessionMachine, GetNetworkAdapter(GetOptState.uIndex - 1, nic.asOutParam()));
1532 ASSERT(nic);
1533
1534 if (!RTStrICmp(ValueUnion.psz, "none"))
1535 {
1536 CHECK_ERROR(nic, COMSETTER(Enabled)(FALSE));
1537 }
1538 else if (!RTStrICmp(ValueUnion.psz, "null"))
1539 {
1540 CHECK_ERROR(nic, COMSETTER(Enabled)(TRUE));
1541 CHECK_ERROR(nic, COMSETTER(AttachmentType)(NetworkAttachmentType_Null));
1542 }
1543 else if (!RTStrICmp(ValueUnion.psz, "nat"))
1544 {
1545 CHECK_ERROR(nic, COMSETTER(Enabled)(TRUE));
1546 CHECK_ERROR(nic, COMSETTER(AttachmentType)(NetworkAttachmentType_NAT));
1547 }
1548 else if ( !RTStrICmp(ValueUnion.psz, "bridged")
1549 || !RTStrICmp(ValueUnion.psz, "hostif")) /* backward compatibility */
1550 {
1551 CHECK_ERROR(nic, COMSETTER(Enabled)(TRUE));
1552 CHECK_ERROR(nic, COMSETTER(AttachmentType)(NetworkAttachmentType_Bridged));
1553 }
1554 else if (!RTStrICmp(ValueUnion.psz, "intnet"))
1555 {
1556 CHECK_ERROR(nic, COMSETTER(Enabled)(TRUE));
1557 CHECK_ERROR(nic, COMSETTER(AttachmentType)(NetworkAttachmentType_Internal));
1558 }
1559 else if (!RTStrICmp(ValueUnion.psz, "hostonly"))
1560 {
1561
1562 CHECK_ERROR(nic, COMSETTER(Enabled)(TRUE));
1563 CHECK_ERROR(nic, COMSETTER(AttachmentType)(NetworkAttachmentType_HostOnly));
1564 }
1565 else if (!RTStrICmp(ValueUnion.psz, "generic"))
1566 {
1567
1568 CHECK_ERROR(nic, COMSETTER(Enabled)(TRUE));
1569 CHECK_ERROR(nic, COMSETTER(AttachmentType)(NetworkAttachmentType_Generic));
1570 }
1571 else if (!RTStrICmp(ValueUnion.psz, "natnetwork"))
1572 {
1573
1574 CHECK_ERROR(nic, COMSETTER(Enabled)(TRUE));
1575 CHECK_ERROR(nic, COMSETTER(AttachmentType)(NetworkAttachmentType_NATNetwork));
1576 }
1577 else
1578 {
1579 errorArgument("Invalid type '%s' specfied for NIC %u", ValueUnion.psz, GetOptState.uIndex);
1580 rc = E_FAIL;
1581 }
1582 break;
1583 }
1584
1585 case MODIFYVM_CABLECONNECTED:
1586 {
1587 if (!parseNum(GetOptState.uIndex, NetworkAdapterCount, "NIC"))
1588 break;
1589
1590 ComPtr<INetworkAdapter> nic;
1591 CHECK_ERROR_BREAK(sessionMachine, GetNetworkAdapter(GetOptState.uIndex - 1, nic.asOutParam()));
1592 ASSERT(nic);
1593
1594 CHECK_ERROR(nic, COMSETTER(CableConnected)(ValueUnion.f));
1595 break;
1596 }
1597
1598 case MODIFYVM_BRIDGEADAPTER:
1599 {
1600 if (!parseNum(GetOptState.uIndex, NetworkAdapterCount, "NIC"))
1601 break;
1602
1603 ComPtr<INetworkAdapter> nic;
1604 CHECK_ERROR_BREAK(sessionMachine, GetNetworkAdapter(GetOptState.uIndex - 1, nic.asOutParam()));
1605 ASSERT(nic);
1606
1607 /* remove it? */
1608 if (!RTStrICmp(ValueUnion.psz, "none"))
1609 {
1610 CHECK_ERROR(nic, COMSETTER(BridgedInterface)(Bstr().raw()));
1611 }
1612 else
1613 {
1614 CHECK_ERROR(nic, COMSETTER(BridgedInterface)(Bstr(ValueUnion.psz).raw()));
1615 }
1616 break;
1617 }
1618
1619 case MODIFYVM_HOSTONLYADAPTER:
1620 {
1621 if (!parseNum(GetOptState.uIndex, NetworkAdapterCount, "NIC"))
1622 break;
1623
1624 ComPtr<INetworkAdapter> nic;
1625 CHECK_ERROR_BREAK(sessionMachine, GetNetworkAdapter(GetOptState.uIndex - 1, nic.asOutParam()));
1626 ASSERT(nic);
1627
1628 /* remove it? */
1629 if (!RTStrICmp(ValueUnion.psz, "none"))
1630 {
1631 CHECK_ERROR(nic, COMSETTER(HostOnlyInterface)(Bstr().raw()));
1632 }
1633 else
1634 {
1635 CHECK_ERROR(nic, COMSETTER(HostOnlyInterface)(Bstr(ValueUnion.psz).raw()));
1636 }
1637 break;
1638 }
1639
1640 case MODIFYVM_INTNET:
1641 {
1642 if (!parseNum(GetOptState.uIndex, NetworkAdapterCount, "NIC"))
1643 break;
1644
1645 ComPtr<INetworkAdapter> nic;
1646 CHECK_ERROR_BREAK(sessionMachine, GetNetworkAdapter(GetOptState.uIndex - 1, nic.asOutParam()));
1647 ASSERT(nic);
1648
1649 /* remove it? */
1650 if (!RTStrICmp(ValueUnion.psz, "none"))
1651 {
1652 CHECK_ERROR(nic, COMSETTER(InternalNetwork)(Bstr().raw()));
1653 }
1654 else
1655 {
1656 CHECK_ERROR(nic, COMSETTER(InternalNetwork)(Bstr(ValueUnion.psz).raw()));
1657 }
1658 break;
1659 }
1660
1661 case MODIFYVM_GENERICDRV:
1662 {
1663 if (!parseNum(GetOptState.uIndex, NetworkAdapterCount, "NIC"))
1664 break;
1665
1666 ComPtr<INetworkAdapter> nic;
1667 CHECK_ERROR_BREAK(sessionMachine, GetNetworkAdapter(GetOptState.uIndex - 1, nic.asOutParam()));
1668 ASSERT(nic);
1669
1670 CHECK_ERROR(nic, COMSETTER(GenericDriver)(Bstr(ValueUnion.psz).raw()));
1671 break;
1672 }
1673
1674 case MODIFYVM_NATNETWORKNAME:
1675 {
1676 if (!parseNum(GetOptState.uIndex, NetworkAdapterCount, "NIC"))
1677 break;
1678
1679 ComPtr<INetworkAdapter> nic;
1680 CHECK_ERROR_BREAK(sessionMachine, GetNetworkAdapter(GetOptState.uIndex - 1, nic.asOutParam()));
1681 ASSERT(nic);
1682
1683 CHECK_ERROR(nic, COMSETTER(NATNetwork)(Bstr(ValueUnion.psz).raw()));
1684 break;
1685 }
1686
1687 case MODIFYVM_NATNET:
1688 {
1689 if (!parseNum(GetOptState.uIndex, NetworkAdapterCount, "NIC"))
1690 break;
1691
1692 ComPtr<INetworkAdapter> nic;
1693 CHECK_ERROR_BREAK(sessionMachine, GetNetworkAdapter(GetOptState.uIndex - 1, nic.asOutParam()));
1694 ASSERT(nic);
1695
1696 ComPtr<INATEngine> engine;
1697 CHECK_ERROR(nic, COMGETTER(NATEngine)(engine.asOutParam()));
1698
1699 const char *psz = ValueUnion.psz;
1700 if (!RTStrICmp("default", psz))
1701 psz = "";
1702
1703 CHECK_ERROR(engine, COMSETTER(Network)(Bstr(psz).raw()));
1704 break;
1705 }
1706
1707 case MODIFYVM_NATBINDIP:
1708 {
1709 if (!parseNum(GetOptState.uIndex, NetworkAdapterCount, "NIC"))
1710 break;
1711
1712 ComPtr<INetworkAdapter> nic;
1713 CHECK_ERROR_BREAK(sessionMachine, GetNetworkAdapter(GetOptState.uIndex - 1, nic.asOutParam()));
1714 ASSERT(nic);
1715
1716 ComPtr<INATEngine> engine;
1717 CHECK_ERROR(nic, COMGETTER(NATEngine)(engine.asOutParam()));
1718
1719 CHECK_ERROR(engine, COMSETTER(HostIP)(Bstr(ValueUnion.psz).raw()));
1720 break;
1721 }
1722
1723#define ITERATE_TO_NEXT_TERM(ch) \
1724 do { \
1725 while (*ch != ',') \
1726 { \
1727 if (*ch == 0) \
1728 { \
1729 return errorSyntax(USAGE_MODIFYVM, \
1730 "Missing or Invalid argument to '%s'", \
1731 GetOptState.pDef->pszLong); \
1732 } \
1733 ch++; \
1734 } \
1735 *ch = '\0'; \
1736 ch++; \
1737 } while(0)
1738
1739 case MODIFYVM_NATSETTINGS:
1740 {
1741 ComPtr<INetworkAdapter> nic;
1742 ComPtr<INATEngine> engine;
1743 char *strMtu;
1744 char *strSockSnd;
1745 char *strSockRcv;
1746 char *strTcpSnd;
1747 char *strTcpRcv;
1748 char *strRaw = RTStrDup(ValueUnion.psz);
1749 char *ch = strRaw;
1750 strMtu = RTStrStrip(ch);
1751 ITERATE_TO_NEXT_TERM(ch);
1752 strSockSnd = RTStrStrip(ch);
1753 ITERATE_TO_NEXT_TERM(ch);
1754 strSockRcv = RTStrStrip(ch);
1755 ITERATE_TO_NEXT_TERM(ch);
1756 strTcpSnd = RTStrStrip(ch);
1757 ITERATE_TO_NEXT_TERM(ch);
1758 strTcpRcv = RTStrStrip(ch);
1759
1760 if (!parseNum(GetOptState.uIndex, NetworkAdapterCount, "NIC"))
1761 break;
1762
1763 CHECK_ERROR_BREAK(sessionMachine, GetNetworkAdapter(GetOptState.uIndex - 1, nic.asOutParam()));
1764 ASSERT(nic);
1765
1766 CHECK_ERROR(nic, COMGETTER(NATEngine)(engine.asOutParam()));
1767 CHECK_ERROR(engine, SetNetworkSettings(RTStrToUInt32(strMtu), RTStrToUInt32(strSockSnd), RTStrToUInt32(strSockRcv),
1768 RTStrToUInt32(strTcpSnd), RTStrToUInt32(strTcpRcv)));
1769 break;
1770 }
1771
1772
1773 case MODIFYVM_NATPF:
1774 {
1775 if (!parseNum(GetOptState.uIndex, NetworkAdapterCount, "NIC"))
1776 break;
1777
1778 ComPtr<INetworkAdapter> nic;
1779 CHECK_ERROR_BREAK(sessionMachine, GetNetworkAdapter(GetOptState.uIndex - 1, nic.asOutParam()));
1780 ASSERT(nic);
1781
1782 ComPtr<INATEngine> engine;
1783 CHECK_ERROR(nic, COMGETTER(NATEngine)(engine.asOutParam()));
1784
1785 /* format name:proto:hostip:hostport:guestip:guestport*/
1786 if (RTStrCmp(ValueUnion.psz, "delete") != 0)
1787 {
1788 char *strName;
1789 char *strProto;
1790 char *strHostIp;
1791 char *strHostPort;
1792 char *strGuestIp;
1793 char *strGuestPort;
1794 char *strRaw = RTStrDup(ValueUnion.psz);
1795 char *ch = strRaw;
1796 strName = RTStrStrip(ch);
1797 ITERATE_TO_NEXT_TERM(ch);
1798 strProto = RTStrStrip(ch);
1799 ITERATE_TO_NEXT_TERM(ch);
1800 strHostIp = RTStrStrip(ch);
1801 ITERATE_TO_NEXT_TERM(ch);
1802 strHostPort = RTStrStrip(ch);
1803 ITERATE_TO_NEXT_TERM(ch);
1804 strGuestIp = RTStrStrip(ch);
1805 ITERATE_TO_NEXT_TERM(ch);
1806 strGuestPort = RTStrStrip(ch);
1807 NATProtocol_T proto;
1808 if (RTStrICmp(strProto, "udp") == 0)
1809 proto = NATProtocol_UDP;
1810 else if (RTStrICmp(strProto, "tcp") == 0)
1811 proto = NATProtocol_TCP;
1812 else
1813 {
1814 errorArgument("Invalid proto '%s' specfied for NIC %u", ValueUnion.psz, GetOptState.uIndex);
1815 rc = E_FAIL;
1816 break;
1817 }
1818 CHECK_ERROR(engine, AddRedirect(Bstr(strName).raw(), proto,
1819 Bstr(strHostIp).raw(),
1820 RTStrToUInt16(strHostPort),
1821 Bstr(strGuestIp).raw(),
1822 RTStrToUInt16(strGuestPort)));
1823 }
1824 else
1825 {
1826 /* delete NAT Rule operation */
1827 int vrc;
1828 vrc = RTGetOptFetchValue(&GetOptState, &ValueUnion, RTGETOPT_REQ_STRING);
1829 if (RT_FAILURE(vrc))
1830 return errorSyntax(USAGE_MODIFYVM, "Not enough parameters");
1831 CHECK_ERROR(engine, RemoveRedirect(Bstr(ValueUnion.psz).raw()));
1832 }
1833 break;
1834 }
1835 #undef ITERATE_TO_NEXT_TERM
1836 case MODIFYVM_NATALIASMODE:
1837 {
1838 ComPtr<INetworkAdapter> nic;
1839 ComPtr<INATEngine> engine;
1840 uint32_t aliasMode = 0;
1841
1842 CHECK_ERROR_BREAK(sessionMachine, GetNetworkAdapter(GetOptState.uIndex - 1, nic.asOutParam()));
1843 ASSERT(nic);
1844
1845 CHECK_ERROR(nic, COMGETTER(NATEngine)(engine.asOutParam()));
1846 if (RTStrCmp(ValueUnion.psz, "default") == 0)
1847 aliasMode = 0;
1848 else
1849 {
1850 char *token = (char *)ValueUnion.psz;
1851 while (token)
1852 {
1853 if (RTStrNCmp(token, RT_STR_TUPLE("log")) == 0)
1854 aliasMode |= NATAliasMode_AliasLog;
1855 else if (RTStrNCmp(token, RT_STR_TUPLE("proxyonly")) == 0)
1856 aliasMode |= NATAliasMode_AliasProxyOnly;
1857 else if (RTStrNCmp(token, RT_STR_TUPLE("sameports")) == 0)
1858 aliasMode |= NATAliasMode_AliasUseSamePorts;
1859 token = RTStrStr(token, ",");
1860 if (token == NULL)
1861 break;
1862 token++;
1863 }
1864 }
1865 CHECK_ERROR(engine, COMSETTER(AliasMode)(aliasMode));
1866 break;
1867 }
1868
1869 case MODIFYVM_NATTFTPPREFIX:
1870 {
1871 if (!parseNum(GetOptState.uIndex, NetworkAdapterCount, "NIC"))
1872 break;
1873
1874 ComPtr<INetworkAdapter> nic;
1875 CHECK_ERROR_BREAK(sessionMachine, GetNetworkAdapter(GetOptState.uIndex - 1, nic.asOutParam()));
1876 ASSERT(nic);
1877
1878 ComPtr<INATEngine> engine;
1879 CHECK_ERROR(nic, COMGETTER(NATEngine)(engine.asOutParam()));
1880
1881 CHECK_ERROR(engine, COMSETTER(TFTPPrefix)(Bstr(ValueUnion.psz).raw()));
1882 break;
1883 }
1884
1885 case MODIFYVM_NATTFTPFILE:
1886 {
1887 if (!parseNum(GetOptState.uIndex, NetworkAdapterCount, "NIC"))
1888 break;
1889
1890 ComPtr<INetworkAdapter> nic;
1891 CHECK_ERROR_BREAK(sessionMachine, GetNetworkAdapter(GetOptState.uIndex - 1, nic.asOutParam()));
1892 ASSERT(nic);
1893
1894 ComPtr<INATEngine> engine;
1895 CHECK_ERROR(nic, COMGETTER(NATEngine)(engine.asOutParam()));
1896
1897 CHECK_ERROR(engine, COMSETTER(TFTPBootFile)(Bstr(ValueUnion.psz).raw()));
1898 break;
1899 }
1900
1901 case MODIFYVM_NATTFTPSERVER:
1902 {
1903 if (!parseNum(GetOptState.uIndex, NetworkAdapterCount, "NIC"))
1904 break;
1905
1906 ComPtr<INetworkAdapter> nic;
1907 CHECK_ERROR_BREAK(sessionMachine, GetNetworkAdapter(GetOptState.uIndex - 1, nic.asOutParam()));
1908 ASSERT(nic);
1909
1910 ComPtr<INATEngine> engine;
1911 CHECK_ERROR(nic, COMGETTER(NATEngine)(engine.asOutParam()));
1912
1913 CHECK_ERROR(engine, COMSETTER(TFTPNextServer)(Bstr(ValueUnion.psz).raw()));
1914 break;
1915 }
1916 case MODIFYVM_NATDNSPASSDOMAIN:
1917 {
1918 if (!parseNum(GetOptState.uIndex, NetworkAdapterCount, "NIC"))
1919 break;
1920
1921 ComPtr<INetworkAdapter> nic;
1922 CHECK_ERROR_BREAK(sessionMachine, GetNetworkAdapter(GetOptState.uIndex - 1, nic.asOutParam()));
1923 ASSERT(nic);
1924
1925 ComPtr<INATEngine> engine;
1926 CHECK_ERROR(nic, COMGETTER(NATEngine)(engine.asOutParam()));
1927
1928 CHECK_ERROR(engine, COMSETTER(DNSPassDomain)(ValueUnion.f));
1929 break;
1930 }
1931
1932 case MODIFYVM_NATDNSPROXY:
1933 {
1934 if (!parseNum(GetOptState.uIndex, NetworkAdapterCount, "NIC"))
1935 break;
1936
1937 ComPtr<INetworkAdapter> nic;
1938 CHECK_ERROR_BREAK(sessionMachine, GetNetworkAdapter(GetOptState.uIndex - 1, nic.asOutParam()));
1939 ASSERT(nic);
1940
1941 ComPtr<INATEngine> engine;
1942 CHECK_ERROR(nic, COMGETTER(NATEngine)(engine.asOutParam()));
1943
1944 CHECK_ERROR(engine, COMSETTER(DNSProxy)(ValueUnion.f));
1945 break;
1946 }
1947
1948 case MODIFYVM_NATDNSHOSTRESOLVER:
1949 {
1950 if (!parseNum(GetOptState.uIndex, NetworkAdapterCount, "NIC"))
1951 break;
1952
1953 ComPtr<INetworkAdapter> nic;
1954 CHECK_ERROR_BREAK(sessionMachine, GetNetworkAdapter(GetOptState.uIndex - 1, nic.asOutParam()));
1955 ASSERT(nic);
1956
1957 ComPtr<INATEngine> engine;
1958 CHECK_ERROR(nic, COMGETTER(NATEngine)(engine.asOutParam()));
1959
1960 CHECK_ERROR(engine, COMSETTER(DNSUseHostResolver)(ValueUnion.f));
1961 break;
1962 }
1963 case MODIFYVM_MACADDRESS:
1964 {
1965 if (!parseNum(GetOptState.uIndex, NetworkAdapterCount, "NIC"))
1966 break;
1967
1968 ComPtr<INetworkAdapter> nic;
1969 CHECK_ERROR_BREAK(sessionMachine, GetNetworkAdapter(GetOptState.uIndex - 1, nic.asOutParam()));
1970 ASSERT(nic);
1971
1972 /* generate one? */
1973 if (!RTStrICmp(ValueUnion.psz, "auto"))
1974 {
1975 CHECK_ERROR(nic, COMSETTER(MACAddress)(Bstr().raw()));
1976 }
1977 else
1978 {
1979 CHECK_ERROR(nic, COMSETTER(MACAddress)(Bstr(ValueUnion.psz).raw()));
1980 }
1981 break;
1982 }
1983
1984 case MODIFYVM_HIDPTR:
1985 {
1986 bool fEnableUsb = false;
1987 if (!RTStrICmp(ValueUnion.psz, "ps2"))
1988 {
1989 CHECK_ERROR(sessionMachine, COMSETTER(PointingHIDType)(PointingHIDType_PS2Mouse));
1990 }
1991 else if (!RTStrICmp(ValueUnion.psz, "usb"))
1992 {
1993 CHECK_ERROR(sessionMachine, COMSETTER(PointingHIDType)(PointingHIDType_USBMouse));
1994 if (SUCCEEDED(rc))
1995 fEnableUsb = true;
1996 }
1997 else if (!RTStrICmp(ValueUnion.psz, "usbtablet"))
1998 {
1999 CHECK_ERROR(sessionMachine, COMSETTER(PointingHIDType)(PointingHIDType_USBTablet));
2000 if (SUCCEEDED(rc))
2001 fEnableUsb = true;
2002 }
2003 else if (!RTStrICmp(ValueUnion.psz, "usbmultitouch"))
2004 {
2005 CHECK_ERROR(sessionMachine, COMSETTER(PointingHIDType)(PointingHIDType_USBMultiTouch));
2006 if (SUCCEEDED(rc))
2007 fEnableUsb = true;
2008 }
2009 else
2010 {
2011 errorArgument("Invalid type '%s' specfied for pointing device", ValueUnion.psz);
2012 rc = E_FAIL;
2013 }
2014 if (fEnableUsb)
2015 {
2016 /* Make sure either the OHCI or xHCI controller is enabled. */
2017 ULONG cOhciCtrls = 0;
2018 ULONG cXhciCtrls = 0;
2019 rc = sessionMachine->GetUSBControllerCountByType(USBControllerType_OHCI, &cOhciCtrls);
2020 if (SUCCEEDED(rc)) {
2021 rc = sessionMachine->GetUSBControllerCountByType(USBControllerType_XHCI, &cXhciCtrls);
2022 if ( SUCCEEDED(rc)
2023 && cOhciCtrls + cXhciCtrls == 0)
2024 {
2025 /* If there's nothing, enable OHCI (always available). */
2026 ComPtr<IUSBController> UsbCtl;
2027 CHECK_ERROR(sessionMachine, AddUSBController(Bstr("OHCI").raw(), USBControllerType_OHCI,
2028 UsbCtl.asOutParam()));
2029 }
2030 }
2031 }
2032 break;
2033 }
2034
2035 case MODIFYVM_HIDKBD:
2036 {
2037 bool fEnableUsb = false;
2038 if (!RTStrICmp(ValueUnion.psz, "ps2"))
2039 {
2040 CHECK_ERROR(sessionMachine, COMSETTER(KeyboardHIDType)(KeyboardHIDType_PS2Keyboard));
2041 }
2042 else if (!RTStrICmp(ValueUnion.psz, "usb"))
2043 {
2044 CHECK_ERROR(sessionMachine, COMSETTER(KeyboardHIDType)(KeyboardHIDType_USBKeyboard));
2045 if (SUCCEEDED(rc))
2046 fEnableUsb = true;
2047 }
2048 else
2049 {
2050 errorArgument("Invalid type '%s' specfied for keyboard", ValueUnion.psz);
2051 rc = E_FAIL;
2052 }
2053 if (fEnableUsb)
2054 {
2055 /* Make sure either the OHCI or xHCI controller is enabled. */
2056 ULONG cOhciCtrls = 0;
2057 ULONG cXhciCtrls = 0;
2058 rc = sessionMachine->GetUSBControllerCountByType(USBControllerType_OHCI, &cOhciCtrls);
2059 if (SUCCEEDED(rc)) {
2060 rc = sessionMachine->GetUSBControllerCountByType(USBControllerType_XHCI, &cXhciCtrls);
2061 if ( SUCCEEDED(rc)
2062 && cOhciCtrls + cXhciCtrls == 0)
2063 {
2064 /* If there's nothing, enable OHCI (always available). */
2065 ComPtr<IUSBController> UsbCtl;
2066 CHECK_ERROR(sessionMachine, AddUSBController(Bstr("OHCI").raw(), USBControllerType_OHCI,
2067 UsbCtl.asOutParam()));
2068 }
2069 }
2070 }
2071 break;
2072 }
2073
2074 case MODIFYVM_UARTMODE:
2075 {
2076 ComPtr<ISerialPort> uart;
2077
2078 CHECK_ERROR_BREAK(sessionMachine, GetSerialPort(GetOptState.uIndex - 1, uart.asOutParam()));
2079 ASSERT(uart);
2080
2081 if (!RTStrICmp(ValueUnion.psz, "disconnected"))
2082 {
2083 CHECK_ERROR(uart, COMSETTER(HostMode)(PortMode_Disconnected));
2084 }
2085 else if ( !RTStrICmp(ValueUnion.psz, "server")
2086 || !RTStrICmp(ValueUnion.psz, "client")
2087 || !RTStrICmp(ValueUnion.psz, "tcpserver")
2088 || !RTStrICmp(ValueUnion.psz, "tcpclient")
2089 || !RTStrICmp(ValueUnion.psz, "file"))
2090 {
2091 const char *pszMode = ValueUnion.psz;
2092
2093 int vrc = RTGetOptFetchValue(&GetOptState, &ValueUnion, RTGETOPT_REQ_STRING);
2094 if (RT_FAILURE(vrc))
2095 return errorSyntax(USAGE_MODIFYVM,
2096 "Missing or Invalid argument to '%s'",
2097 GetOptState.pDef->pszLong);
2098
2099 CHECK_ERROR(uart, COMSETTER(Path)(Bstr(ValueUnion.psz).raw()));
2100
2101 if (!RTStrICmp(pszMode, "server"))
2102 {
2103 CHECK_ERROR(uart, COMSETTER(HostMode)(PortMode_HostPipe));
2104 CHECK_ERROR(uart, COMSETTER(Server)(TRUE));
2105 }
2106 else if (!RTStrICmp(pszMode, "client"))
2107 {
2108 CHECK_ERROR(uart, COMSETTER(HostMode)(PortMode_HostPipe));
2109 CHECK_ERROR(uart, COMSETTER(Server)(FALSE));
2110 }
2111 else if (!RTStrICmp(pszMode, "tcpserver"))
2112 {
2113 CHECK_ERROR(uart, COMSETTER(HostMode)(PortMode_TCP));
2114 CHECK_ERROR(uart, COMSETTER(Server)(TRUE));
2115 }
2116 else if (!RTStrICmp(pszMode, "tcpclient"))
2117 {
2118 CHECK_ERROR(uart, COMSETTER(HostMode)(PortMode_TCP));
2119 CHECK_ERROR(uart, COMSETTER(Server)(FALSE));
2120 }
2121 else if (!RTStrICmp(pszMode, "file"))
2122 {
2123 CHECK_ERROR(uart, COMSETTER(HostMode)(PortMode_RawFile));
2124 }
2125 }
2126 else
2127 {
2128 CHECK_ERROR(uart, COMSETTER(Path)(Bstr(ValueUnion.psz).raw()));
2129 CHECK_ERROR(uart, COMSETTER(HostMode)(PortMode_HostDevice));
2130 }
2131 break;
2132 }
2133
2134 case MODIFYVM_UART:
2135 {
2136 ComPtr<ISerialPort> uart;
2137
2138 CHECK_ERROR_BREAK(sessionMachine, GetSerialPort(GetOptState.uIndex - 1, uart.asOutParam()));
2139 ASSERT(uart);
2140
2141 if (!RTStrICmp(ValueUnion.psz, "off") || !RTStrICmp(ValueUnion.psz, "disable"))
2142 CHECK_ERROR(uart, COMSETTER(Enabled)(FALSE));
2143 else
2144 {
2145 const char *pszIOBase = ValueUnion.psz;
2146 uint32_t uVal = 0;
2147
2148 int vrc = RTGetOptFetchValue(&GetOptState, &ValueUnion, RTGETOPT_REQ_UINT32) != MODIFYVM_UART;
2149 if (RT_FAILURE(vrc))
2150 return errorSyntax(USAGE_MODIFYVM,
2151 "Missing or Invalid argument to '%s'",
2152 GetOptState.pDef->pszLong);
2153
2154 CHECK_ERROR(uart, COMSETTER(IRQ)(ValueUnion.u32));
2155
2156 vrc = RTStrToUInt32Ex(pszIOBase, NULL, 0, &uVal);
2157 if (vrc != VINF_SUCCESS || uVal == 0)
2158 return errorArgument("Error parsing UART I/O base '%s'", pszIOBase);
2159 CHECK_ERROR(uart, COMSETTER(IOBase)(uVal));
2160
2161 CHECK_ERROR(uart, COMSETTER(Enabled)(TRUE));
2162 }
2163 break;
2164 }
2165
2166#if defined(RT_OS_LINUX) || defined(RT_OS_WINDOWS)
2167 case MODIFYVM_LPTMODE:
2168 {
2169 ComPtr<IParallelPort> lpt;
2170
2171 CHECK_ERROR_BREAK(sessionMachine, GetParallelPort(GetOptState.uIndex - 1, lpt.asOutParam()));
2172 ASSERT(lpt);
2173
2174 CHECK_ERROR(lpt, COMSETTER(Path)(Bstr(ValueUnion.psz).raw()));
2175 break;
2176 }
2177
2178 case MODIFYVM_LPT:
2179 {
2180 ComPtr<IParallelPort> lpt;
2181
2182 CHECK_ERROR_BREAK(sessionMachine, GetParallelPort(GetOptState.uIndex - 1, lpt.asOutParam()));
2183 ASSERT(lpt);
2184
2185 if (!RTStrICmp(ValueUnion.psz, "off") || !RTStrICmp(ValueUnion.psz, "disable"))
2186 CHECK_ERROR(lpt, COMSETTER(Enabled)(FALSE));
2187 else
2188 {
2189 const char *pszIOBase = ValueUnion.psz;
2190 uint32_t uVal = 0;
2191
2192 int vrc = RTGetOptFetchValue(&GetOptState, &ValueUnion, RTGETOPT_REQ_UINT32) != MODIFYVM_LPT;
2193 if (RT_FAILURE(vrc))
2194 return errorSyntax(USAGE_MODIFYVM,
2195 "Missing or Invalid argument to '%s'",
2196 GetOptState.pDef->pszLong);
2197
2198 CHECK_ERROR(lpt, COMSETTER(IRQ)(ValueUnion.u32));
2199
2200 vrc = RTStrToUInt32Ex(pszIOBase, NULL, 0, &uVal);
2201 if (vrc != VINF_SUCCESS || uVal == 0)
2202 return errorArgument("Error parsing LPT I/O base '%s'", pszIOBase);
2203 CHECK_ERROR(lpt, COMSETTER(IOBase)(uVal));
2204
2205 CHECK_ERROR(lpt, COMSETTER(Enabled)(TRUE));
2206 }
2207 break;
2208 }
2209#endif
2210
2211 case MODIFYVM_GUESTMEMORYBALLOON:
2212 {
2213 CHECK_ERROR(sessionMachine, COMSETTER(MemoryBalloonSize)(ValueUnion.u32));
2214 break;
2215 }
2216
2217 case MODIFYVM_AUDIOCONTROLLER:
2218 {
2219 ComPtr<IAudioAdapter> audioAdapter;
2220 sessionMachine->COMGETTER(AudioAdapter)(audioAdapter.asOutParam());
2221 ASSERT(audioAdapter);
2222
2223 if (!RTStrICmp(ValueUnion.psz, "sb16"))
2224 CHECK_ERROR(audioAdapter, COMSETTER(AudioController)(AudioControllerType_SB16));
2225 else if (!RTStrICmp(ValueUnion.psz, "ac97"))
2226 CHECK_ERROR(audioAdapter, COMSETTER(AudioController)(AudioControllerType_AC97));
2227 else if (!RTStrICmp(ValueUnion.psz, "hda"))
2228 CHECK_ERROR(audioAdapter, COMSETTER(AudioController)(AudioControllerType_HDA));
2229 else
2230 {
2231 errorArgument("Invalid --audiocontroller argument '%s'", ValueUnion.psz);
2232 rc = E_FAIL;
2233 }
2234 break;
2235 }
2236
2237 case MODIFYVM_AUDIOCODEC:
2238 {
2239 ComPtr<IAudioAdapter> audioAdapter;
2240 sessionMachine->COMGETTER(AudioAdapter)(audioAdapter.asOutParam());
2241 ASSERT(audioAdapter);
2242
2243 if (!RTStrICmp(ValueUnion.psz, "sb16"))
2244 CHECK_ERROR(audioAdapter, COMSETTER(AudioCodec)(AudioCodecType_SB16));
2245 else if (!RTStrICmp(ValueUnion.psz, "stac9700"))
2246 CHECK_ERROR(audioAdapter, COMSETTER(AudioCodec)(AudioCodecType_STAC9700));
2247 else if (!RTStrICmp(ValueUnion.psz, "ad1980"))
2248 CHECK_ERROR(audioAdapter, COMSETTER(AudioCodec)(AudioCodecType_AD1980));
2249 else if (!RTStrICmp(ValueUnion.psz, "stac9221"))
2250 CHECK_ERROR(audioAdapter, COMSETTER(AudioCodec)(AudioCodecType_STAC9221));
2251 else
2252 {
2253 errorArgument("Invalid --audiocodec argument '%s'", ValueUnion.psz);
2254 rc = E_FAIL;
2255 }
2256 break;
2257 }
2258
2259 case MODIFYVM_AUDIO:
2260 {
2261 ComPtr<IAudioAdapter> audioAdapter;
2262 sessionMachine->COMGETTER(AudioAdapter)(audioAdapter.asOutParam());
2263 ASSERT(audioAdapter);
2264
2265 /* disable? */
2266 if (!RTStrICmp(ValueUnion.psz, "none"))
2267 {
2268 CHECK_ERROR(audioAdapter, COMSETTER(Enabled)(false));
2269 }
2270 else if (!RTStrICmp(ValueUnion.psz, "null"))
2271 {
2272 CHECK_ERROR(audioAdapter, COMSETTER(AudioDriver)(AudioDriverType_Null));
2273 CHECK_ERROR(audioAdapter, COMSETTER(Enabled)(true));
2274 }
2275#ifdef RT_OS_WINDOWS
2276#ifdef VBOX_WITH_WINMM
2277 else if (!RTStrICmp(ValueUnion.psz, "winmm"))
2278 {
2279 CHECK_ERROR(audioAdapter, COMSETTER(AudioDriver)(AudioDriverType_WinMM));
2280 CHECK_ERROR(audioAdapter, COMSETTER(Enabled)(true));
2281 }
2282#endif
2283 else if (!RTStrICmp(ValueUnion.psz, "dsound"))
2284 {
2285 CHECK_ERROR(audioAdapter, COMSETTER(AudioDriver)(AudioDriverType_DirectSound));
2286 CHECK_ERROR(audioAdapter, COMSETTER(Enabled)(true));
2287 }
2288#endif /* RT_OS_WINDOWS */
2289#ifdef VBOX_WITH_AUDIO_OSS
2290 else if (!RTStrICmp(ValueUnion.psz, "oss"))
2291 {
2292 CHECK_ERROR(audioAdapter, COMSETTER(AudioDriver)(AudioDriverType_OSS));
2293 CHECK_ERROR(audioAdapter, COMSETTER(Enabled)(true));
2294 }
2295#endif
2296#ifdef VBOX_WITH_AUDIO_ALSA
2297 else if (!RTStrICmp(ValueUnion.psz, "alsa"))
2298 {
2299 CHECK_ERROR(audioAdapter, COMSETTER(AudioDriver)(AudioDriverType_ALSA));
2300 CHECK_ERROR(audioAdapter, COMSETTER(Enabled)(true));
2301 }
2302#endif
2303#ifdef VBOX_WITH_AUDIO_PULSE
2304 else if (!RTStrICmp(ValueUnion.psz, "pulse"))
2305 {
2306 CHECK_ERROR(audioAdapter, COMSETTER(AudioDriver)(AudioDriverType_Pulse));
2307 CHECK_ERROR(audioAdapter, COMSETTER(Enabled)(true));
2308 }
2309#endif
2310#ifdef RT_OS_DARWIN
2311 else if (!RTStrICmp(ValueUnion.psz, "coreaudio"))
2312 {
2313 CHECK_ERROR(audioAdapter, COMSETTER(AudioDriver)(AudioDriverType_CoreAudio));
2314 CHECK_ERROR(audioAdapter, COMSETTER(Enabled)(true));
2315 }
2316#endif /* !RT_OS_DARWIN */
2317 else
2318 {
2319 errorArgument("Invalid --audio argument '%s'", ValueUnion.psz);
2320 rc = E_FAIL;
2321 }
2322 break;
2323 }
2324
2325 case MODIFYVM_CLIPBOARD:
2326 {
2327 ClipboardMode_T mode = ClipboardMode_Disabled; /* Shut up MSC */
2328 if (!RTStrICmp(ValueUnion.psz, "disabled"))
2329 mode = ClipboardMode_Disabled;
2330 else if (!RTStrICmp(ValueUnion.psz, "hosttoguest"))
2331 mode = ClipboardMode_HostToGuest;
2332 else if (!RTStrICmp(ValueUnion.psz, "guesttohost"))
2333 mode = ClipboardMode_GuestToHost;
2334 else if (!RTStrICmp(ValueUnion.psz, "bidirectional"))
2335 mode = ClipboardMode_Bidirectional;
2336 else
2337 {
2338 errorArgument("Invalid --clipboard argument '%s'", ValueUnion.psz);
2339 rc = E_FAIL;
2340 }
2341 if (SUCCEEDED(rc))
2342 {
2343 CHECK_ERROR(sessionMachine, COMSETTER(ClipboardMode)(mode));
2344 }
2345 break;
2346 }
2347
2348 case MODIFYVM_DRAGANDDROP:
2349 {
2350 DnDMode_T mode = DnDMode_Disabled; /* Shut up MSC */
2351 if (!RTStrICmp(ValueUnion.psz, "disabled"))
2352 mode = DnDMode_Disabled;
2353 else if (!RTStrICmp(ValueUnion.psz, "hosttoguest"))
2354 mode = DnDMode_HostToGuest;
2355 else if (!RTStrICmp(ValueUnion.psz, "guesttohost"))
2356 mode = DnDMode_GuestToHost;
2357 else if (!RTStrICmp(ValueUnion.psz, "bidirectional"))
2358 mode = DnDMode_Bidirectional;
2359 else
2360 {
2361 errorArgument("Invalid --draganddrop argument '%s'", ValueUnion.psz);
2362 rc = E_FAIL;
2363 }
2364 if (SUCCEEDED(rc))
2365 {
2366 CHECK_ERROR(sessionMachine, COMSETTER(DnDMode)(mode));
2367 }
2368 break;
2369 }
2370
2371 case MODIFYVM_VRDE_EXTPACK:
2372 {
2373 ComPtr<IVRDEServer> vrdeServer;
2374 sessionMachine->COMGETTER(VRDEServer)(vrdeServer.asOutParam());
2375 ASSERT(vrdeServer);
2376
2377 if (vrdeServer)
2378 {
2379 if (RTStrICmp(ValueUnion.psz, "default") != 0)
2380 {
2381 Bstr bstr(ValueUnion.psz);
2382 CHECK_ERROR(vrdeServer, COMSETTER(VRDEExtPack)(bstr.raw()));
2383 }
2384 else
2385 CHECK_ERROR(vrdeServer, COMSETTER(VRDEExtPack)(Bstr().raw()));
2386 }
2387 break;
2388 }
2389
2390 case MODIFYVM_VRDEPROPERTY:
2391 {
2392 ComPtr<IVRDEServer> vrdeServer;
2393 sessionMachine->COMGETTER(VRDEServer)(vrdeServer.asOutParam());
2394 ASSERT(vrdeServer);
2395
2396 if (vrdeServer)
2397 {
2398 /* Parse 'name=value' */
2399 char *pszProperty = RTStrDup(ValueUnion.psz);
2400 if (pszProperty)
2401 {
2402 char *pDelimiter = strchr(pszProperty, '=');
2403 if (pDelimiter)
2404 {
2405 *pDelimiter = '\0';
2406
2407 Bstr bstrName = pszProperty;
2408 Bstr bstrValue = &pDelimiter[1];
2409 CHECK_ERROR(vrdeServer, SetVRDEProperty(bstrName.raw(), bstrValue.raw()));
2410 }
2411 else
2412 {
2413 RTStrFree(pszProperty);
2414
2415 errorArgument("Invalid --vrdeproperty argument '%s'", ValueUnion.psz);
2416 rc = E_FAIL;
2417 break;
2418 }
2419 RTStrFree(pszProperty);
2420 }
2421 else
2422 {
2423 RTStrmPrintf(g_pStdErr, "Error: Failed to allocate memory for VRDE property '%s'\n", ValueUnion.psz);
2424 rc = E_FAIL;
2425 }
2426 }
2427 break;
2428 }
2429
2430 case MODIFYVM_VRDPPORT:
2431 vrdeWarningDeprecatedOption("port");
2432 /* fall thru */
2433
2434 case MODIFYVM_VRDEPORT:
2435 {
2436 ComPtr<IVRDEServer> vrdeServer;
2437 sessionMachine->COMGETTER(VRDEServer)(vrdeServer.asOutParam());
2438 ASSERT(vrdeServer);
2439
2440 if (!RTStrICmp(ValueUnion.psz, "default"))
2441 CHECK_ERROR(vrdeServer, SetVRDEProperty(Bstr("TCP/Ports").raw(), Bstr("0").raw()));
2442 else
2443 CHECK_ERROR(vrdeServer, SetVRDEProperty(Bstr("TCP/Ports").raw(), Bstr(ValueUnion.psz).raw()));
2444 break;
2445 }
2446
2447 case MODIFYVM_VRDPADDRESS:
2448 vrdeWarningDeprecatedOption("address");
2449 /* fall thru */
2450
2451 case MODIFYVM_VRDEADDRESS:
2452 {
2453 ComPtr<IVRDEServer> vrdeServer;
2454 sessionMachine->COMGETTER(VRDEServer)(vrdeServer.asOutParam());
2455 ASSERT(vrdeServer);
2456
2457 CHECK_ERROR(vrdeServer, SetVRDEProperty(Bstr("TCP/Address").raw(), Bstr(ValueUnion.psz).raw()));
2458 break;
2459 }
2460
2461 case MODIFYVM_VRDPAUTHTYPE:
2462 vrdeWarningDeprecatedOption("authtype");
2463 /* fall thru */
2464 case MODIFYVM_VRDEAUTHTYPE:
2465 {
2466 ComPtr<IVRDEServer> vrdeServer;
2467 sessionMachine->COMGETTER(VRDEServer)(vrdeServer.asOutParam());
2468 ASSERT(vrdeServer);
2469
2470 if (!RTStrICmp(ValueUnion.psz, "null"))
2471 {
2472 CHECK_ERROR(vrdeServer, COMSETTER(AuthType)(AuthType_Null));
2473 }
2474 else if (!RTStrICmp(ValueUnion.psz, "external"))
2475 {
2476 CHECK_ERROR(vrdeServer, COMSETTER(AuthType)(AuthType_External));
2477 }
2478 else if (!RTStrICmp(ValueUnion.psz, "guest"))
2479 {
2480 CHECK_ERROR(vrdeServer, COMSETTER(AuthType)(AuthType_Guest));
2481 }
2482 else
2483 {
2484 errorArgument("Invalid --vrdeauthtype argument '%s'", ValueUnion.psz);
2485 rc = E_FAIL;
2486 }
2487 break;
2488 }
2489
2490 case MODIFYVM_VRDEAUTHLIBRARY:
2491 {
2492 ComPtr<IVRDEServer> vrdeServer;
2493 sessionMachine->COMGETTER(VRDEServer)(vrdeServer.asOutParam());
2494 ASSERT(vrdeServer);
2495
2496 if (vrdeServer)
2497 {
2498 if (RTStrICmp(ValueUnion.psz, "default") != 0)
2499 {
2500 Bstr bstr(ValueUnion.psz);
2501 CHECK_ERROR(vrdeServer, COMSETTER(AuthLibrary)(bstr.raw()));
2502 }
2503 else
2504 CHECK_ERROR(vrdeServer, COMSETTER(AuthLibrary)(Bstr().raw()));
2505 }
2506 break;
2507 }
2508
2509 case MODIFYVM_VRDPMULTICON:
2510 vrdeWarningDeprecatedOption("multicon");
2511 /* fall thru */
2512 case MODIFYVM_VRDEMULTICON:
2513 {
2514 ComPtr<IVRDEServer> vrdeServer;
2515 sessionMachine->COMGETTER(VRDEServer)(vrdeServer.asOutParam());
2516 ASSERT(vrdeServer);
2517
2518 CHECK_ERROR(vrdeServer, COMSETTER(AllowMultiConnection)(ValueUnion.f));
2519 break;
2520 }
2521
2522 case MODIFYVM_VRDPREUSECON:
2523 vrdeWarningDeprecatedOption("reusecon");
2524 /* fall thru */
2525 case MODIFYVM_VRDEREUSECON:
2526 {
2527 ComPtr<IVRDEServer> vrdeServer;
2528 sessionMachine->COMGETTER(VRDEServer)(vrdeServer.asOutParam());
2529 ASSERT(vrdeServer);
2530
2531 CHECK_ERROR(vrdeServer, COMSETTER(ReuseSingleConnection)(ValueUnion.f));
2532 break;
2533 }
2534
2535 case MODIFYVM_VRDPVIDEOCHANNEL:
2536 vrdeWarningDeprecatedOption("videochannel");
2537 /* fall thru */
2538 case MODIFYVM_VRDEVIDEOCHANNEL:
2539 {
2540 ComPtr<IVRDEServer> vrdeServer;
2541 sessionMachine->COMGETTER(VRDEServer)(vrdeServer.asOutParam());
2542 ASSERT(vrdeServer);
2543
2544 CHECK_ERROR(vrdeServer, SetVRDEProperty(Bstr("VideoChannel/Enabled").raw(),
2545 ValueUnion.f? Bstr("true").raw(): Bstr("false").raw()));
2546 break;
2547 }
2548
2549 case MODIFYVM_VRDPVIDEOCHANNELQUALITY:
2550 vrdeWarningDeprecatedOption("videochannelquality");
2551 /* fall thru */
2552 case MODIFYVM_VRDEVIDEOCHANNELQUALITY:
2553 {
2554 ComPtr<IVRDEServer> vrdeServer;
2555 sessionMachine->COMGETTER(VRDEServer)(vrdeServer.asOutParam());
2556 ASSERT(vrdeServer);
2557
2558 CHECK_ERROR(vrdeServer, SetVRDEProperty(Bstr("VideoChannel/Quality").raw(),
2559 Bstr(ValueUnion.psz).raw()));
2560 break;
2561 }
2562
2563 case MODIFYVM_VRDP:
2564 vrdeWarningDeprecatedOption("");
2565 /* fall thru */
2566 case MODIFYVM_VRDE:
2567 {
2568 ComPtr<IVRDEServer> vrdeServer;
2569 sessionMachine->COMGETTER(VRDEServer)(vrdeServer.asOutParam());
2570 ASSERT(vrdeServer);
2571
2572 CHECK_ERROR(vrdeServer, COMSETTER(Enabled)(ValueUnion.f));
2573 break;
2574 }
2575
2576 case MODIFYVM_USBRENAME:
2577 {
2578 const char *pszName = ValueUnion.psz;
2579 int vrc = RTGetOptFetchValue(&GetOptState, &ValueUnion, RTGETOPT_REQ_STRING);
2580 if (RT_FAILURE(vrc))
2581 return errorSyntax(USAGE_MODIFYVM,
2582 "Missing or Invalid argument to '%s'",
2583 GetOptState.pDef->pszLong);
2584 const char *pszNewName = ValueUnion.psz;
2585
2586 SafeIfaceArray<IUSBController> ctrls;
2587 CHECK_ERROR(sessionMachine, COMGETTER(USBControllers)(ComSafeArrayAsOutParam(ctrls)));
2588 bool fRenamed = false;
2589 for (size_t i = 0; i < ctrls.size(); i++)
2590 {
2591 ComPtr<IUSBController> pCtrl = ctrls[i];
2592 Bstr bstrName;
2593 CHECK_ERROR(pCtrl, COMGETTER(Name)(bstrName.asOutParam()));
2594 if (bstrName == pszName)
2595 {
2596 bstrName = pszNewName;
2597 CHECK_ERROR(pCtrl, COMSETTER(Name)(bstrName.raw()));
2598 fRenamed = true;
2599 }
2600 }
2601 if (!fRenamed)
2602 {
2603 errorArgument("Invalid --usbrename parameters, nothing renamed");
2604 rc = E_FAIL;
2605 }
2606 break;
2607 }
2608
2609 case MODIFYVM_USBXHCI:
2610 {
2611 ULONG cXhciCtrls = 0;
2612 rc = sessionMachine->GetUSBControllerCountByType(USBControllerType_XHCI, &cXhciCtrls);
2613 if (SUCCEEDED(rc))
2614 {
2615 if (!cXhciCtrls && ValueUnion.f)
2616 {
2617 ComPtr<IUSBController> UsbCtl;
2618 CHECK_ERROR(sessionMachine, AddUSBController(Bstr("xHCI").raw(), USBControllerType_XHCI,
2619 UsbCtl.asOutParam()));
2620 }
2621 else if (cXhciCtrls && !ValueUnion.f)
2622 {
2623 SafeIfaceArray<IUSBController> ctrls;
2624 CHECK_ERROR(sessionMachine, COMGETTER(USBControllers)(ComSafeArrayAsOutParam(ctrls)));
2625 for (size_t i = 0; i < ctrls.size(); i++)
2626 {
2627 ComPtr<IUSBController> pCtrl = ctrls[i];
2628 USBControllerType_T enmType;
2629 CHECK_ERROR(pCtrl, COMGETTER(Type)(&enmType));
2630 if (enmType == USBControllerType_XHCI)
2631 {
2632 Bstr ctrlName;
2633 CHECK_ERROR(pCtrl, COMGETTER(Name)(ctrlName.asOutParam()));
2634 CHECK_ERROR(sessionMachine, RemoveUSBController(ctrlName.raw()));
2635 }
2636 }
2637 }
2638 }
2639 break;
2640 }
2641
2642 case MODIFYVM_USBEHCI:
2643 {
2644 ULONG cEhciCtrls = 0;
2645 rc = sessionMachine->GetUSBControllerCountByType(USBControllerType_EHCI, &cEhciCtrls);
2646 if (SUCCEEDED(rc))
2647 {
2648 if (!cEhciCtrls && ValueUnion.f)
2649 {
2650 ComPtr<IUSBController> UsbCtl;
2651 CHECK_ERROR(sessionMachine, AddUSBController(Bstr("EHCI").raw(), USBControllerType_EHCI,
2652 UsbCtl.asOutParam()));
2653 }
2654 else if (cEhciCtrls && !ValueUnion.f)
2655 {
2656 SafeIfaceArray<IUSBController> ctrls;
2657 CHECK_ERROR(sessionMachine, COMGETTER(USBControllers)(ComSafeArrayAsOutParam(ctrls)));
2658 for (size_t i = 0; i < ctrls.size(); i++)
2659 {
2660 ComPtr<IUSBController> pCtrl = ctrls[i];
2661 USBControllerType_T enmType;
2662 CHECK_ERROR(pCtrl, COMGETTER(Type)(&enmType));
2663 if (enmType == USBControllerType_EHCI)
2664 {
2665 Bstr ctrlName;
2666 CHECK_ERROR(pCtrl, COMGETTER(Name)(ctrlName.asOutParam()));
2667 CHECK_ERROR(sessionMachine, RemoveUSBController(ctrlName.raw()));
2668 }
2669 }
2670 }
2671 }
2672 break;
2673 }
2674
2675 case MODIFYVM_USB:
2676 {
2677 ULONG cOhciCtrls = 0;
2678 rc = sessionMachine->GetUSBControllerCountByType(USBControllerType_OHCI, &cOhciCtrls);
2679 if (SUCCEEDED(rc))
2680 {
2681 if (!cOhciCtrls && ValueUnion.f)
2682 {
2683 ComPtr<IUSBController> UsbCtl;
2684 CHECK_ERROR(sessionMachine, AddUSBController(Bstr("OHCI").raw(), USBControllerType_OHCI,
2685 UsbCtl.asOutParam()));
2686 }
2687 else if (cOhciCtrls && !ValueUnion.f)
2688 {
2689 SafeIfaceArray<IUSBController> ctrls;
2690 CHECK_ERROR(sessionMachine, COMGETTER(USBControllers)(ComSafeArrayAsOutParam(ctrls)));
2691 for (size_t i = 0; i < ctrls.size(); i++)
2692 {
2693 ComPtr<IUSBController> pCtrl = ctrls[i];
2694 USBControllerType_T enmType;
2695 CHECK_ERROR(pCtrl, COMGETTER(Type)(&enmType));
2696 if (enmType == USBControllerType_OHCI)
2697 {
2698 Bstr ctrlName;
2699 CHECK_ERROR(pCtrl, COMGETTER(Name)(ctrlName.asOutParam()));
2700 CHECK_ERROR(sessionMachine, RemoveUSBController(ctrlName.raw()));
2701 }
2702 }
2703 }
2704 }
2705 break;
2706 }
2707
2708 case MODIFYVM_SNAPSHOTFOLDER:
2709 {
2710 if (!RTStrICmp(ValueUnion.psz, "default"))
2711 CHECK_ERROR(sessionMachine, COMSETTER(SnapshotFolder)(Bstr().raw()));
2712 else
2713 CHECK_ERROR(sessionMachine, COMSETTER(SnapshotFolder)(Bstr(ValueUnion.psz).raw()));
2714 break;
2715 }
2716
2717 case MODIFYVM_TELEPORTER_ENABLED:
2718 {
2719 CHECK_ERROR(sessionMachine, COMSETTER(TeleporterEnabled)(ValueUnion.f));
2720 break;
2721 }
2722
2723 case MODIFYVM_TELEPORTER_PORT:
2724 {
2725 CHECK_ERROR(sessionMachine, COMSETTER(TeleporterPort)(ValueUnion.u32));
2726 break;
2727 }
2728
2729 case MODIFYVM_TELEPORTER_ADDRESS:
2730 {
2731 CHECK_ERROR(sessionMachine, COMSETTER(TeleporterAddress)(Bstr(ValueUnion.psz).raw()));
2732 break;
2733 }
2734
2735 case MODIFYVM_TELEPORTER_PASSWORD:
2736 {
2737 CHECK_ERROR(sessionMachine, COMSETTER(TeleporterPassword)(Bstr(ValueUnion.psz).raw()));
2738 break;
2739 }
2740
2741 case MODIFYVM_TELEPORTER_PASSWORD_FILE:
2742 {
2743 Utf8Str password;
2744 RTEXITCODE rcExit = readPasswordFile(ValueUnion.psz, &password);
2745 if (rcExit != RTEXITCODE_SUCCESS)
2746 rc = E_FAIL;
2747 else
2748 CHECK_ERROR(sessionMachine, COMSETTER(TeleporterPassword)(Bstr(password).raw()));
2749 break;
2750 }
2751
2752 case MODIFYVM_TRACING_ENABLED:
2753 {
2754 CHECK_ERROR(sessionMachine, COMSETTER(TracingEnabled)(ValueUnion.f));
2755 break;
2756 }
2757
2758 case MODIFYVM_TRACING_CONFIG:
2759 {
2760 CHECK_ERROR(sessionMachine, COMSETTER(TracingConfig)(Bstr(ValueUnion.psz).raw()));
2761 break;
2762 }
2763
2764 case MODIFYVM_TRACING_ALLOW_VM_ACCESS:
2765 {
2766 CHECK_ERROR(sessionMachine, COMSETTER(AllowTracingToAccessVM)(ValueUnion.f));
2767 break;
2768 }
2769
2770 case MODIFYVM_FAULT_TOLERANCE:
2771 {
2772 if (!RTStrICmp(ValueUnion.psz, "master"))
2773 {
2774 CHECK_ERROR(sessionMachine, COMSETTER(FaultToleranceState(FaultToleranceState_Master)));
2775 }
2776 else
2777 if (!RTStrICmp(ValueUnion.psz, "standby"))
2778 {
2779 CHECK_ERROR(sessionMachine, COMSETTER(FaultToleranceState(FaultToleranceState_Standby)));
2780 }
2781 else
2782 {
2783 errorArgument("Invalid --faulttolerance argument '%s'", ValueUnion.psz);
2784 rc = E_FAIL;
2785 }
2786 break;
2787 }
2788
2789 case MODIFYVM_FAULT_TOLERANCE_ADDRESS:
2790 {
2791 CHECK_ERROR(sessionMachine, COMSETTER(FaultToleranceAddress)(Bstr(ValueUnion.psz).raw()));
2792 break;
2793 }
2794
2795 case MODIFYVM_FAULT_TOLERANCE_PORT:
2796 {
2797 CHECK_ERROR(sessionMachine, COMSETTER(FaultTolerancePort)(ValueUnion.u32));
2798 break;
2799 }
2800
2801 case MODIFYVM_FAULT_TOLERANCE_PASSWORD:
2802 {
2803 CHECK_ERROR(sessionMachine, COMSETTER(FaultTolerancePassword)(Bstr(ValueUnion.psz).raw()));
2804 break;
2805 }
2806
2807 case MODIFYVM_FAULT_TOLERANCE_SYNC_INTERVAL:
2808 {
2809 CHECK_ERROR(sessionMachine, COMSETTER(FaultToleranceSyncInterval)(ValueUnion.u32));
2810 break;
2811 }
2812
2813 case MODIFYVM_HARDWARE_UUID:
2814 {
2815 CHECK_ERROR(sessionMachine, COMSETTER(HardwareUUID)(Bstr(ValueUnion.psz).raw()));
2816 break;
2817 }
2818
2819 case MODIFYVM_HPET:
2820 {
2821 CHECK_ERROR(sessionMachine, COMSETTER(HPETEnabled)(ValueUnion.f));
2822 break;
2823 }
2824
2825 case MODIFYVM_IOCACHE:
2826 {
2827 CHECK_ERROR(sessionMachine, COMSETTER(IOCacheEnabled)(ValueUnion.f));
2828 break;
2829 }
2830
2831 case MODIFYVM_IOCACHESIZE:
2832 {
2833 CHECK_ERROR(sessionMachine, COMSETTER(IOCacheSize)(ValueUnion.u32));
2834 break;
2835 }
2836
2837 case MODIFYVM_CHIPSET:
2838 {
2839 if (!RTStrICmp(ValueUnion.psz, "piix3"))
2840 {
2841 CHECK_ERROR(sessionMachine, COMSETTER(ChipsetType)(ChipsetType_PIIX3));
2842 }
2843 else if (!RTStrICmp(ValueUnion.psz, "ich9"))
2844 {
2845 CHECK_ERROR(sessionMachine, COMSETTER(ChipsetType)(ChipsetType_ICH9));
2846 BOOL fIoApic = FALSE;
2847 CHECK_ERROR(biosSettings, COMGETTER(IOAPICEnabled)(&fIoApic));
2848 if (!fIoApic)
2849 {
2850 RTStrmPrintf(g_pStdErr, "*** I/O APIC must be enabled for ICH9, enabling. ***\n");
2851 CHECK_ERROR(biosSettings, COMSETTER(IOAPICEnabled)(TRUE));
2852 }
2853 }
2854 else
2855 {
2856 errorArgument("Invalid --chipset argument '%s' (valid: piix3,ich9)", ValueUnion.psz);
2857 rc = E_FAIL;
2858 }
2859 break;
2860 }
2861#ifdef VBOX_WITH_VIDEOREC
2862 case MODIFYVM_VIDEOCAP:
2863 {
2864 CHECK_ERROR(sessionMachine, COMSETTER(VideoCaptureEnabled)(ValueUnion.f));
2865 break;
2866 }
2867 case MODIFYVM_VIDEOCAP_SCREENS:
2868 {
2869 ULONG cMonitors = 64;
2870 CHECK_ERROR(sessionMachine, COMGETTER(MonitorCount)(&cMonitors));
2871 com::SafeArray<BOOL> screens(cMonitors);
2872 if (parseScreens(ValueUnion.psz, &screens))
2873 {
2874 errorArgument("Invalid list of screens specified\n");
2875 rc = E_FAIL;
2876 break;
2877 }
2878 CHECK_ERROR(sessionMachine, COMSETTER(VideoCaptureScreens)(ComSafeArrayAsInParam(screens)));
2879 break;
2880 }
2881 case MODIFYVM_VIDEOCAP_FILENAME:
2882 {
2883 Bstr bstr;
2884 /* empty string will fall through, leaving bstr empty */
2885 if (*ValueUnion.psz)
2886 {
2887 char szVCFileAbs[RTPATH_MAX] = "";
2888 int vrc = RTPathAbs(ValueUnion.psz, szVCFileAbs, sizeof(szVCFileAbs));
2889 if (RT_FAILURE(vrc))
2890 {
2891 errorArgument("Cannot convert filename \"%s\" to absolute path\n", ValueUnion.psz);
2892 rc = E_FAIL;
2893 break;
2894 }
2895 bstr = szVCFileAbs;
2896 }
2897 CHECK_ERROR(sessionMachine, COMSETTER(VideoCaptureFile)(bstr.raw()));
2898 break;
2899 }
2900 case MODIFYVM_VIDEOCAP_WIDTH:
2901 {
2902 CHECK_ERROR(sessionMachine, COMSETTER(VideoCaptureWidth)(ValueUnion.u32));
2903 break;
2904 }
2905 case MODIFYVM_VIDEOCAP_HEIGHT:
2906 {
2907 CHECK_ERROR(sessionMachine, COMSETTER(VideoCaptureHeight)(ValueUnion.u32));
2908 break;
2909 }
2910 case MODIFYVM_VIDEOCAP_RES:
2911 {
2912 uint32_t uWidth = 0;
2913 char *pszNext;
2914 int vrc = RTStrToUInt32Ex(ValueUnion.psz, &pszNext, 0, &uWidth);
2915 if (RT_FAILURE(vrc) || vrc != VWRN_TRAILING_CHARS || !pszNext || *pszNext != 'x')
2916 {
2917 errorArgument("Error parsing geomtry '%s' (expected <width>x<height>)", ValueUnion.psz);
2918 rc = E_FAIL;
2919 break;
2920 }
2921 uint32_t uHeight = 0;
2922 vrc = RTStrToUInt32Ex(pszNext+1, NULL, 0, &uHeight);
2923 if (vrc != VINF_SUCCESS)
2924 {
2925 errorArgument("Error parsing geomtry '%s' (expected <width>x<height>)", ValueUnion.psz);
2926 rc = E_FAIL;
2927 break;
2928 }
2929 CHECK_ERROR(sessionMachine, COMSETTER(VideoCaptureWidth)(uWidth));
2930 CHECK_ERROR(sessionMachine, COMSETTER(VideoCaptureHeight)(uHeight));
2931 break;
2932 }
2933 case MODIFYVM_VIDEOCAP_RATE:
2934 {
2935 CHECK_ERROR(sessionMachine, COMSETTER(VideoCaptureRate)(ValueUnion.u32));
2936 break;
2937 }
2938 case MODIFYVM_VIDEOCAP_FPS:
2939 {
2940 CHECK_ERROR(sessionMachine, COMSETTER(VideoCaptureFPS)(ValueUnion.u32));
2941 break;
2942 }
2943 case MODIFYVM_VIDEOCAP_MAXTIME:
2944 {
2945 CHECK_ERROR(sessionMachine, COMSETTER(VideoCaptureMaxTime)(ValueUnion.u32));
2946 break;
2947 }
2948 case MODIFYVM_VIDEOCAP_MAXSIZE:
2949 {
2950 CHECK_ERROR(sessionMachine, COMSETTER(VideoCaptureMaxFileSize)(ValueUnion.u32));
2951 break;
2952 }
2953 case MODIFYVM_VIDEOCAP_OPTIONS:
2954 {
2955 Bstr bstr(ValueUnion.psz);
2956 CHECK_ERROR(sessionMachine, COMSETTER(VideoCaptureOptions)(bstr.raw()));
2957 break;
2958 }
2959#endif
2960 case MODIFYVM_AUTOSTART_ENABLED:
2961 {
2962 CHECK_ERROR(sessionMachine, COMSETTER(AutostartEnabled)(ValueUnion.f));
2963 break;
2964 }
2965
2966 case MODIFYVM_AUTOSTART_DELAY:
2967 {
2968 CHECK_ERROR(sessionMachine, COMSETTER(AutostartDelay)(ValueUnion.u32));
2969 break;
2970 }
2971
2972 case MODIFYVM_AUTOSTOP_TYPE:
2973 {
2974 AutostopType_T enmAutostopType = AutostopType_Disabled;
2975
2976 if (!RTStrICmp(ValueUnion.psz, "disabled"))
2977 enmAutostopType = AutostopType_Disabled;
2978 else if (!RTStrICmp(ValueUnion.psz, "savestate"))
2979 enmAutostopType = AutostopType_SaveState;
2980 else if (!RTStrICmp(ValueUnion.psz, "poweroff"))
2981 enmAutostopType = AutostopType_PowerOff;
2982 else if (!RTStrICmp(ValueUnion.psz, "acpishutdown"))
2983 enmAutostopType = AutostopType_AcpiShutdown;
2984 else
2985 {
2986 errorArgument("Invalid --autostop-type argument '%s' (valid: disabled, savestate, poweroff, acpishutdown)", ValueUnion.psz);
2987 rc = E_FAIL;
2988 }
2989
2990 if (SUCCEEDED(rc))
2991 CHECK_ERROR(sessionMachine, COMSETTER(AutostopType)(enmAutostopType));
2992 break;
2993 }
2994#ifdef VBOX_WITH_PCI_PASSTHROUGH
2995 case MODIFYVM_ATTACH_PCI:
2996 {
2997 const char* pAt = strchr(ValueUnion.psz, '@');
2998 int32_t iHostAddr, iGuestAddr;
2999
3000 iHostAddr = parsePci(ValueUnion.psz);
3001 iGuestAddr = pAt != NULL ? parsePci(pAt + 1) : iHostAddr;
3002
3003 if (iHostAddr == -1 || iGuestAddr == -1)
3004 {
3005 errorArgument("Invalid --pciattach argument '%s' (valid: 'HB:HD.HF@GB:GD.GF' or just 'HB:HD.HF')", ValueUnion.psz);
3006 rc = E_FAIL;
3007 }
3008 else
3009 {
3010 CHECK_ERROR(sessionMachine, AttachHostPCIDevice(iHostAddr, iGuestAddr, TRUE));
3011 }
3012
3013 break;
3014 }
3015 case MODIFYVM_DETACH_PCI:
3016 {
3017 int32_t iHostAddr;
3018
3019 iHostAddr = parsePci(ValueUnion.psz);
3020 if (iHostAddr == -1)
3021 {
3022 errorArgument("Invalid --pcidetach argument '%s' (valid: 'HB:HD.HF')", ValueUnion.psz);
3023 rc = E_FAIL;
3024 }
3025 else
3026 {
3027 CHECK_ERROR(sessionMachine, DetachHostPCIDevice(iHostAddr));
3028 }
3029
3030 break;
3031 }
3032#endif
3033
3034#ifdef VBOX_WITH_USB_CARDREADER
3035 case MODIFYVM_USBCARDREADER:
3036 {
3037 CHECK_ERROR(sessionMachine, COMSETTER(EmulatedUSBCardReaderEnabled)(ValueUnion.f));
3038 break;
3039 }
3040#endif /* VBOX_WITH_USB_CARDREADER */
3041
3042 case MODIFYVM_DEFAULTFRONTEND:
3043 {
3044 Bstr bstr(ValueUnion.psz);
3045 if (bstr == "default")
3046 bstr = Bstr::Empty;
3047 CHECK_ERROR(sessionMachine, COMSETTER(DefaultFrontend)(bstr.raw()));
3048 break;
3049 }
3050
3051 default:
3052 {
3053 errorGetOpt(USAGE_MODIFYVM, c, &ValueUnion);
3054 rc = E_FAIL;
3055 break;
3056 }
3057 }
3058 }
3059
3060 /* commit changes */
3061 if (SUCCEEDED(rc))
3062 CHECK_ERROR(sessionMachine, SaveSettings());
3063
3064 /* it's important to always close sessions */
3065 a->session->UnlockMachine();
3066
3067 return SUCCEEDED(rc) ? RTEXITCODE_SUCCESS : RTEXITCODE_FAILURE;
3068}
3069
3070#endif /* !VBOX_ONLY_DOCS */
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette