VirtualBox

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

Last change on this file since 71679 was 71108, checked in by vboxsync, 7 years ago

Added speculation control settings to API, refined implementation.

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