VirtualBox

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

Last change on this file since 26517 was 26517, checked in by vboxsync, 15 years ago

*: RTGetOpt cleanup related to --help and --version (now standard option). Use RTGetOptPrintError.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 63.8 KB
Line 
1/* $Id: VBoxManageModifyVM.cpp 26517 2010-02-14 21:39:00Z vboxsync $ */
2/** @file
3 * VBoxManage - Implementation of modifyvm command.
4 */
5
6/*
7 * Copyright (C) 2006-2009 Sun Microsystems, Inc.
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 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
18 * Clara, CA 95054 USA or visit http://www.sun.com if you need
19 * additional information or have any questions.
20 */
21
22/*******************************************************************************
23* Header Files *
24*******************************************************************************/
25#ifndef VBOX_ONLY_DOCS
26#include <VBox/com/com.h>
27#include <VBox/com/array.h>
28#include <VBox/com/ErrorInfo.h>
29#include <VBox/com/errorprint.h>
30#include <VBox/com/EventQueue.h>
31
32#include <VBox/com/VirtualBox.h>
33
34#include <vector>
35#include <list>
36#endif /* !VBOX_ONLY_DOCS */
37
38#include <iprt/cidr.h>
39#include <iprt/param.h>
40#include <iprt/path.h>
41#include <iprt/stream.h>
42#include <iprt/string.h>
43#include <iprt/getopt.h>
44#include <VBox/log.h>
45
46#include "VBoxManage.h"
47
48#ifndef VBOX_ONLY_DOCS
49using namespace com;
50
51
52/** @todo refine this after HDD changes; MSC 8.0/64 has trouble with handleModifyVM. */
53#if defined(_MSC_VER)
54# pragma optimize("g", off)
55#endif
56
57enum
58{
59 MODIFYVM_NAME = 1000,
60 MODIFYVM_OSTYPE,
61 MODIFYVM_MEMORY,
62 MODIFYVM_VRAM,
63 MODIFYVM_FIRMWARE,
64 MODIFYVM_ACPI,
65 MODIFYVM_IOAPIC,
66 MODIFYVM_PAE,
67 MODIFYVM_SYNTHCPU,
68 MODIFYVM_HWVIRTEX,
69 MODIFYVM_HWVIRTEXEXCLUSIVE,
70 MODIFYVM_NESTEDPAGING,
71 MODIFYVM_VTXVPID,
72 MODIFYVM_CPUS,
73 MODIFYVM_CPUHOTPLUG,
74 MODIFYVM_PLUGCPU,
75 MODIFYVM_UNPLUGCPU,
76 MODIFYVM_SETCPUID,
77 MODIFYVM_DELCPUID,
78 MODIFYVM_DELALLCPUID,
79 MODIFYVM_MONITORCOUNT,
80 MODIFYVM_ACCELERATE3D,
81 MODIFYVM_ACCELERATE2DVIDEO,
82 MODIFYVM_BIOSLOGOFADEIN,
83 MODIFYVM_BIOSLOGOFADEOUT,
84 MODIFYVM_BIOSLOGODISPLAYTIME,
85 MODIFYVM_BIOSLOGOIMAGEPATH,
86 MODIFYVM_BIOSBOOTMENU,
87 MODIFYVM_BIOSSYSTEMTIMEOFFSET,
88 MODIFYVM_BIOSPXEDEBUG,
89 MODIFYVM_BOOT,
90 MODIFYVM_HDA, // deprecated
91 MODIFYVM_HDB, // deprecated
92 MODIFYVM_HDD, // deprecated
93 MODIFYVM_IDECONTROLLER, // deprecated
94 MODIFYVM_SATAIDEEMULATION, // deprecated
95 MODIFYVM_SATAPORTCOUNT, // deprecated
96 MODIFYVM_SATAPORT, // deprecated
97 MODIFYVM_SATA, // deprecated
98 MODIFYVM_SCSIPORT, // deprecated
99 MODIFYVM_SCSITYPE, // deprecated
100 MODIFYVM_SCSI, // deprecated
101 MODIFYVM_DVDPASSTHROUGH, // deprecated
102 MODIFYVM_DVD, // deprecated
103 MODIFYVM_FLOPPY, // deprecated
104 MODIFYVM_NICTRACEFILE,
105 MODIFYVM_NICTRACE,
106 MODIFYVM_NICTYPE,
107 MODIFYVM_NICSPEED,
108 MODIFYVM_NIC,
109 MODIFYVM_CABLECONNECTED,
110 MODIFYVM_BRIDGEADAPTER,
111 MODIFYVM_HOSTONLYADAPTER,
112 MODIFYVM_INTNET,
113 MODIFYVM_NATNET,
114 MODIFYVM_MACADDRESS,
115 MODIFYVM_UARTMODE,
116 MODIFYVM_UART,
117 MODIFYVM_GUESTSTATISTICSINTERVAL,
118 MODIFYVM_GUESTMEMORYBALLOON,
119 MODIFYVM_AUDIOCONTROLLER,
120 MODIFYVM_AUDIO,
121 MODIFYVM_CLIPBOARD,
122 MODIFYVM_VRDPPORT,
123 MODIFYVM_VRDPADDRESS,
124 MODIFYVM_VRDPAUTHTYPE,
125 MODIFYVM_VRDPMULTICON,
126 MODIFYVM_VRDPREUSECON,
127 MODIFYVM_VRDP,
128 MODIFYVM_RTCUSEUTC,
129 MODIFYVM_USBEHCI,
130 MODIFYVM_USB,
131 MODIFYVM_SNAPSHOTFOLDER,
132 MODIFYVM_TELEPORTER_ENABLED,
133 MODIFYVM_TELEPORTER_PORT,
134 MODIFYVM_TELEPORTER_ADDRESS,
135 MODIFYVM_TELEPORTER_PASSWORD,
136 MODIFYVM_HARDWARE_UUID
137};
138
139static const RTGETOPTDEF g_aModifyVMOptions[] =
140{
141 { "--name", MODIFYVM_NAME, RTGETOPT_REQ_STRING },
142 { "--ostype", MODIFYVM_OSTYPE, RTGETOPT_REQ_STRING },
143 { "--memory", MODIFYVM_MEMORY, RTGETOPT_REQ_UINT32 },
144 { "--vram", MODIFYVM_VRAM, RTGETOPT_REQ_UINT32 },
145 { "--firmware", MODIFYVM_FIRMWARE, RTGETOPT_REQ_STRING },
146 { "--acpi", MODIFYVM_ACPI, RTGETOPT_REQ_BOOL_ONOFF },
147 { "--ioapic", MODIFYVM_IOAPIC, RTGETOPT_REQ_BOOL_ONOFF },
148 { "--pae", MODIFYVM_PAE, RTGETOPT_REQ_BOOL_ONOFF },
149 { "--synthcpu", MODIFYVM_SYNTHCPU, RTGETOPT_REQ_BOOL_ONOFF },
150 { "--hwvirtex", MODIFYVM_HWVIRTEX, RTGETOPT_REQ_BOOL_ONOFF },
151 { "--hwvirtexexcl", MODIFYVM_HWVIRTEXEXCLUSIVE, RTGETOPT_REQ_BOOL_ONOFF },
152 { "--nestedpaging", MODIFYVM_NESTEDPAGING, RTGETOPT_REQ_BOOL_ONOFF },
153 { "--vtxvpid", MODIFYVM_VTXVPID, RTGETOPT_REQ_BOOL_ONOFF },
154 { "--cpuidset", MODIFYVM_SETCPUID, RTGETOPT_REQ_UINT32 | RTGETOPT_FLAG_HEX},
155 { "--cpuidremove", MODIFYVM_DELCPUID, RTGETOPT_REQ_UINT32 | RTGETOPT_FLAG_HEX},
156 { "--cpuidremoveall", MODIFYVM_DELALLCPUID, RTGETOPT_REQ_NOTHING},
157 { "--cpus", MODIFYVM_CPUS, RTGETOPT_REQ_UINT32 },
158 { "--cpuhotplug", MODIFYVM_CPUHOTPLUG, RTGETOPT_REQ_BOOL_ONOFF },
159 { "--plugcpu", MODIFYVM_PLUGCPU, RTGETOPT_REQ_UINT32 },
160 { "--unplugcpu", MODIFYVM_UNPLUGCPU, RTGETOPT_REQ_UINT32 },
161 { "--rtcuseutc", MODIFYVM_RTCUSEUTC, RTGETOPT_REQ_BOOL_ONOFF },
162 { "--monitorcount", MODIFYVM_MONITORCOUNT, RTGETOPT_REQ_UINT32 },
163 { "--accelerate3d", MODIFYVM_ACCELERATE3D, RTGETOPT_REQ_BOOL_ONOFF },
164 { "--accelerate2dvideo", MODIFYVM_ACCELERATE2DVIDEO, RTGETOPT_REQ_BOOL_ONOFF },
165 { "--bioslogofadein", MODIFYVM_BIOSLOGOFADEIN, RTGETOPT_REQ_BOOL_ONOFF },
166 { "--bioslogofadeout", MODIFYVM_BIOSLOGOFADEOUT, RTGETOPT_REQ_BOOL_ONOFF },
167 { "--bioslogodisplaytime", MODIFYVM_BIOSLOGODISPLAYTIME, RTGETOPT_REQ_UINT32 },
168 { "--bioslogoimagepath", MODIFYVM_BIOSLOGOIMAGEPATH, RTGETOPT_REQ_STRING },
169 { "--biosbootmenu", MODIFYVM_BIOSBOOTMENU, RTGETOPT_REQ_STRING },
170 { "--biossystemtimeoffset", MODIFYVM_BIOSSYSTEMTIMEOFFSET, RTGETOPT_REQ_INT64 },
171 { "--biospxedebug", MODIFYVM_BIOSPXEDEBUG, RTGETOPT_REQ_BOOL_ONOFF },
172 { "--boot", MODIFYVM_BOOT, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
173 { "--hda", MODIFYVM_HDA, RTGETOPT_REQ_STRING },
174 { "--hdb", MODIFYVM_HDB, RTGETOPT_REQ_STRING },
175 { "--hdd", MODIFYVM_HDD, RTGETOPT_REQ_STRING },
176 { "--idecontroller", MODIFYVM_IDECONTROLLER, RTGETOPT_REQ_STRING },
177 { "--sataideemulation", MODIFYVM_SATAIDEEMULATION, RTGETOPT_REQ_UINT32 | RTGETOPT_FLAG_INDEX },
178 { "--sataportcount", MODIFYVM_SATAPORTCOUNT, RTGETOPT_REQ_UINT32 },
179 { "--sataport", MODIFYVM_SATAPORT, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
180 { "--sata", MODIFYVM_SATA, RTGETOPT_REQ_STRING },
181 { "--scsiport", MODIFYVM_SCSIPORT, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
182 { "--scsitype", MODIFYVM_SCSITYPE, RTGETOPT_REQ_STRING },
183 { "--scsi", MODIFYVM_SCSI, RTGETOPT_REQ_STRING },
184 { "--dvdpassthrough", MODIFYVM_DVDPASSTHROUGH, RTGETOPT_REQ_STRING },
185 { "--dvd", MODIFYVM_DVD, RTGETOPT_REQ_STRING },
186 { "--floppy", MODIFYVM_FLOPPY, RTGETOPT_REQ_STRING },
187 { "--nictracefile", MODIFYVM_NICTRACEFILE, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
188 { "--nictrace", MODIFYVM_NICTRACE, RTGETOPT_REQ_BOOL_ONOFF | RTGETOPT_FLAG_INDEX },
189 { "--nictype", MODIFYVM_NICTYPE, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
190 { "--nicspeed", MODIFYVM_NICSPEED, RTGETOPT_REQ_UINT32 | RTGETOPT_FLAG_INDEX },
191 { "--nic", MODIFYVM_NIC, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
192 { "--cableconnected", MODIFYVM_CABLECONNECTED, RTGETOPT_REQ_BOOL_ONOFF | RTGETOPT_FLAG_INDEX },
193 { "--bridgeadapter", MODIFYVM_BRIDGEADAPTER, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
194 { "--hostonlyadapter", MODIFYVM_HOSTONLYADAPTER, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
195 { "--intnet", MODIFYVM_INTNET, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
196 { "--natnet", MODIFYVM_NATNET, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
197 { "--macaddress", MODIFYVM_MACADDRESS, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
198 { "--uartmode", MODIFYVM_UARTMODE, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
199 { "--uart", MODIFYVM_UART, RTGETOPT_REQ_STRING | RTGETOPT_FLAG_INDEX },
200 { "--gueststatisticsinterval", MODIFYVM_GUESTSTATISTICSINTERVAL, RTGETOPT_REQ_UINT32 },
201 { "--guestmemoryballoon", MODIFYVM_GUESTMEMORYBALLOON, RTGETOPT_REQ_UINT32 },
202 { "--audiocontroller", MODIFYVM_AUDIOCONTROLLER, RTGETOPT_REQ_STRING },
203 { "--audio", MODIFYVM_AUDIO, RTGETOPT_REQ_STRING },
204 { "--clipboard", MODIFYVM_CLIPBOARD, RTGETOPT_REQ_STRING },
205 { "--vrdpport", MODIFYVM_VRDPPORT, RTGETOPT_REQ_STRING },
206 { "--vrdpaddress", MODIFYVM_VRDPADDRESS, RTGETOPT_REQ_STRING },
207 { "--vrdpauthtype", MODIFYVM_VRDPAUTHTYPE, RTGETOPT_REQ_STRING },
208 { "--vrdpmulticon", MODIFYVM_VRDPMULTICON, RTGETOPT_REQ_BOOL_ONOFF },
209 { "--vrdpreusecon", MODIFYVM_VRDPREUSECON, RTGETOPT_REQ_BOOL_ONOFF },
210 { "--vrdp", MODIFYVM_VRDP, RTGETOPT_REQ_BOOL_ONOFF },
211 { "--usbehci", MODIFYVM_USBEHCI, RTGETOPT_REQ_BOOL_ONOFF },
212 { "--usb", MODIFYVM_USB, RTGETOPT_REQ_BOOL_ONOFF },
213 { "--snapshotfolder", MODIFYVM_SNAPSHOTFOLDER, RTGETOPT_REQ_STRING },
214 { "--teleporter", MODIFYVM_TELEPORTER_ENABLED, RTGETOPT_REQ_BOOL_ONOFF },
215 { "--teleporterenabled", MODIFYVM_TELEPORTER_ENABLED, RTGETOPT_REQ_BOOL_ONOFF }, /* deprecated */
216 { "--teleporterport", MODIFYVM_TELEPORTER_PORT, RTGETOPT_REQ_UINT32 },
217 { "--teleporteraddress", MODIFYVM_TELEPORTER_ADDRESS, RTGETOPT_REQ_STRING },
218 { "--teleporterpassword", MODIFYVM_TELEPORTER_PASSWORD, RTGETOPT_REQ_STRING },
219 { "--hardwareuuid", MODIFYVM_HARDWARE_UUID, RTGETOPT_REQ_STRING },
220};
221
222int handleModifyVM(HandlerArg *a)
223{
224 int c;
225 HRESULT rc;
226 Bstr name;
227 Bstr machineuuid (a->argv[0]);
228 RTGETOPTUNION ValueUnion;
229 RTGETOPTSTATE GetOptState;
230 ComPtr <IMachine> machine;
231 ComPtr <IBIOSSettings> biosSettings;
232
233 /* VM ID + at least one parameter. Parameter arguments are checked
234 * individually. */
235 if (a->argc < 2)
236 return errorSyntax(USAGE_MODIFYVM, "Not enough parameters");
237
238 /* Get the number of network adapters */
239 ULONG NetworkAdapterCount = 0;
240 {
241 ComPtr <ISystemProperties> info;
242 CHECK_ERROR_RET(a->virtualBox, COMGETTER(SystemProperties)(info.asOutParam()), 1);
243 CHECK_ERROR_RET(info, COMGETTER(NetworkAdapterCount)(&NetworkAdapterCount), 1);
244 }
245 ULONG SerialPortCount = 0;
246 {
247 ComPtr <ISystemProperties> info;
248 CHECK_ERROR_RET(a->virtualBox, COMGETTER(SystemProperties)(info.asOutParam()), 1);
249 CHECK_ERROR_RET(info, COMGETTER(SerialPortCount)(&SerialPortCount), 1);
250 }
251
252 /* try to find the given machine */
253 if (!Guid(machineuuid).isEmpty())
254 {
255 CHECK_ERROR_RET(a->virtualBox, GetMachine(machineuuid, machine.asOutParam()), 1);
256 }
257 else
258 {
259 CHECK_ERROR_RET(a->virtualBox, FindMachine(Bstr(a->argv[0]), machine.asOutParam()), 1);
260 machine->COMGETTER(Id)(machineuuid.asOutParam());
261 }
262
263 /* open a session for the VM */
264 CHECK_ERROR_RET(a->virtualBox, OpenSession(a->session, machineuuid), 1);
265
266 /* get the mutable session machine */
267 a->session->COMGETTER(Machine)(machine.asOutParam());
268 machine->COMGETTER(BIOSSettings)(biosSettings.asOutParam());
269
270 RTGetOptInit(&GetOptState, a->argc, a->argv, g_aModifyVMOptions,
271 RT_ELEMENTS(g_aModifyVMOptions), 1, RTGETOPTINIT_FLAGS_NO_STD_OPTS);
272
273 while ( SUCCEEDED (rc)
274 && (c = RTGetOpt(&GetOptState, &ValueUnion)))
275 {
276 switch (c)
277 {
278 case MODIFYVM_NAME:
279 {
280 CHECK_ERROR(machine, COMSETTER(Name)(Bstr(ValueUnion.psz)));
281 break;
282 }
283 case MODIFYVM_OSTYPE:
284 {
285 ComPtr<IGuestOSType> guestOSType;
286 CHECK_ERROR(a->virtualBox, GetGuestOSType(Bstr(ValueUnion.psz), guestOSType.asOutParam()));
287 if (SUCCEEDED(rc) && guestOSType)
288 {
289 CHECK_ERROR(machine, COMSETTER(OSTypeId)(Bstr(ValueUnion.psz)));
290 }
291 else
292 {
293 errorArgument("Invalid guest OS type '%s'", Utf8Str(ValueUnion.psz).raw());
294 rc = E_FAIL;
295 }
296 break;
297 }
298
299 case MODIFYVM_MEMORY:
300 {
301 CHECK_ERROR(machine, COMSETTER(MemorySize)(ValueUnion.u32));
302 break;
303 }
304
305 case MODIFYVM_VRAM:
306 {
307 CHECK_ERROR(machine, COMSETTER(VRAMSize)(ValueUnion.u32));
308 break;
309 }
310
311 case MODIFYVM_FIRMWARE:
312 {
313 if (!strcmp(ValueUnion.psz, "efi"))
314 {
315 CHECK_ERROR(machine, COMSETTER(FirmwareType)(FirmwareType_EFI));
316 }
317 else if (!strcmp(ValueUnion.psz, "efi32"))
318 {
319 CHECK_ERROR(machine, COMSETTER(FirmwareType)(FirmwareType_EFI32));
320 }
321 else if (!strcmp(ValueUnion.psz, "efi64"))
322 {
323 CHECK_ERROR(machine, COMSETTER(FirmwareType)(FirmwareType_EFI64));
324 }
325 else if (!strcmp(ValueUnion.psz, "efidual"))
326 {
327 CHECK_ERROR(machine, COMSETTER(FirmwareType)(FirmwareType_EFIDUAL));
328 }
329 else if (!strcmp(ValueUnion.psz, "bios"))
330 {
331 CHECK_ERROR(machine, COMSETTER(FirmwareType)(FirmwareType_BIOS));
332 }
333 else
334 {
335 errorArgument("Invalid --firmware argument '%s'", ValueUnion.psz);
336 rc = E_FAIL;
337 }
338 break;
339 }
340
341 case MODIFYVM_ACPI:
342 {
343 CHECK_ERROR(biosSettings, COMSETTER(ACPIEnabled)(ValueUnion.f));
344 break;
345 }
346
347 case MODIFYVM_IOAPIC:
348 {
349 CHECK_ERROR(biosSettings, COMSETTER(IOAPICEnabled)(ValueUnion.f));
350 break;
351 }
352
353 case MODIFYVM_PAE:
354 {
355 CHECK_ERROR(machine, SetCpuProperty(CpuPropertyType_PAE, ValueUnion.f));
356 break;
357 }
358
359 case MODIFYVM_SYNTHCPU:
360 {
361 CHECK_ERROR(machine, SetCpuProperty(CpuPropertyType_Synthetic, ValueUnion.f));
362 break;
363 }
364
365 case MODIFYVM_HWVIRTEX:
366 {
367 CHECK_ERROR(machine, SetHWVirtExProperty(HWVirtExPropertyType_Enabled, ValueUnion.f));
368 break;
369 }
370
371 case MODIFYVM_HWVIRTEXEXCLUSIVE:
372 {
373 CHECK_ERROR(machine, SetHWVirtExProperty(HWVirtExPropertyType_Exclusive, ValueUnion.f));
374 break;
375 }
376
377 case MODIFYVM_SETCPUID:
378 {
379 uint32_t id = ValueUnion.u32;
380 uint32_t aValue[4];
381
382 for (unsigned i = 0 ; i < 4 ; i++)
383 {
384 int vrc = RTGetOptFetchValue(&GetOptState, &ValueUnion, RTGETOPT_REQ_UINT32 | RTGETOPT_FLAG_HEX);
385 if (RT_FAILURE(vrc))
386 return errorSyntax(USAGE_MODIFYVM,
387 "Missing or Invalid argument to '%s'",
388 GetOptState.pDef->pszLong);
389 aValue[i] = ValueUnion.u32;
390 }
391 CHECK_ERROR(machine, SetCpuIdLeaf(id, aValue[0], aValue[1], aValue[2], aValue[3]));
392 break;
393 }
394
395 case MODIFYVM_DELCPUID:
396 {
397 CHECK_ERROR(machine, RemoveCpuIdLeaf(ValueUnion.u32));
398 break;
399 }
400
401 case MODIFYVM_DELALLCPUID:
402 {
403 CHECK_ERROR(machine, RemoveAllCpuIdLeafs());
404 break;
405 }
406
407 case MODIFYVM_NESTEDPAGING:
408 {
409 CHECK_ERROR(machine, SetHWVirtExProperty(HWVirtExPropertyType_NestedPaging, ValueUnion.f));
410 break;
411 }
412
413 case MODIFYVM_VTXVPID:
414 {
415 CHECK_ERROR(machine, SetHWVirtExProperty(HWVirtExPropertyType_VPID, ValueUnion.f));
416 break;
417 }
418
419 case MODIFYVM_CPUS:
420 {
421 CHECK_ERROR(machine, COMSETTER(CPUCount)(ValueUnion.u32));
422 break;
423 }
424
425 case MODIFYVM_RTCUSEUTC:
426 {
427 CHECK_ERROR(machine, COMSETTER(RTCUseUTC)(ValueUnion.f));
428 break;
429 }
430
431 case MODIFYVM_CPUHOTPLUG:
432 {
433 CHECK_ERROR(machine, COMSETTER(CPUHotPlugEnabled)(ValueUnion.f));
434 break;
435 }
436
437 case MODIFYVM_PLUGCPU:
438 {
439 CHECK_ERROR(machine, HotPlugCPU(ValueUnion.u32));
440 break;
441 }
442
443 case MODIFYVM_UNPLUGCPU:
444 {
445 CHECK_ERROR(machine, HotUnplugCPU(ValueUnion.u32));
446 break;
447 }
448
449 case MODIFYVM_MONITORCOUNT:
450 {
451 CHECK_ERROR(machine, COMSETTER(MonitorCount)(ValueUnion.u32));
452 break;
453 }
454
455 case MODIFYVM_ACCELERATE3D:
456 {
457 CHECK_ERROR(machine, COMSETTER(Accelerate3DEnabled)(ValueUnion.f));
458 break;
459 }
460
461#ifdef VBOX_WITH_VIDEOHWACCEL
462 case MODIFYVM_ACCELERATE2DVIDEO:
463 {
464 CHECK_ERROR(machine, COMSETTER(Accelerate2DVideoEnabled)(ValueUnion.f));
465 break;
466 }
467#endif
468
469 case MODIFYVM_BIOSLOGOFADEIN:
470 {
471 CHECK_ERROR(biosSettings, COMSETTER(LogoFadeIn)(ValueUnion.f));
472 break;
473 }
474
475 case MODIFYVM_BIOSLOGOFADEOUT:
476 {
477 CHECK_ERROR(biosSettings, COMSETTER(LogoFadeOut)(ValueUnion.f));
478 break;
479 }
480
481 case MODIFYVM_BIOSLOGODISPLAYTIME:
482 {
483 CHECK_ERROR(biosSettings, COMSETTER(LogoDisplayTime)(ValueUnion.u32));
484 break;
485 }
486
487 case MODIFYVM_BIOSLOGOIMAGEPATH:
488 {
489 CHECK_ERROR(biosSettings, COMSETTER(LogoImagePath)(Bstr(ValueUnion.psz)));
490 break;
491 }
492
493 case MODIFYVM_BIOSBOOTMENU:
494 {
495 if (!strcmp(ValueUnion.psz, "disabled"))
496 {
497 CHECK_ERROR(biosSettings, COMSETTER(BootMenuMode)(BIOSBootMenuMode_Disabled));
498 }
499 else if (!strcmp(ValueUnion.psz, "menuonly"))
500 {
501 CHECK_ERROR(biosSettings, COMSETTER(BootMenuMode)(BIOSBootMenuMode_MenuOnly));
502 }
503 else if (!strcmp(ValueUnion.psz, "messageandmenu"))
504 {
505 CHECK_ERROR(biosSettings, COMSETTER(BootMenuMode)(BIOSBootMenuMode_MessageAndMenu));
506 }
507 else
508 {
509 errorArgument("Invalid --biosbootmenu argument '%s'", ValueUnion.psz);
510 rc = E_FAIL;
511 }
512 break;
513 }
514
515 case MODIFYVM_BIOSSYSTEMTIMEOFFSET:
516 {
517 CHECK_ERROR(biosSettings, COMSETTER(TimeOffset)(ValueUnion.i64));
518 break;
519 }
520
521 case MODIFYVM_BIOSPXEDEBUG:
522 {
523 CHECK_ERROR(biosSettings, COMSETTER(PXEDebugEnabled)(ValueUnion.f));
524 break;
525 }
526
527 case MODIFYVM_BOOT:
528 {
529 if (!strcmp(ValueUnion.psz, "none"))
530 {
531 CHECK_ERROR(machine, SetBootOrder(GetOptState.uIndex, DeviceType_Null));
532 }
533 else if (!strcmp(ValueUnion.psz, "floppy"))
534 {
535 CHECK_ERROR(machine, SetBootOrder(GetOptState.uIndex, DeviceType_Floppy));
536 }
537 else if (!strcmp(ValueUnion.psz, "dvd"))
538 {
539 CHECK_ERROR(machine, SetBootOrder(GetOptState.uIndex, DeviceType_DVD));
540 }
541 else if (!strcmp(ValueUnion.psz, "disk"))
542 {
543 CHECK_ERROR(machine, SetBootOrder(GetOptState.uIndex, DeviceType_HardDisk));
544 }
545 else if (!strcmp(ValueUnion.psz, "net"))
546 {
547 CHECK_ERROR(machine, SetBootOrder(GetOptState.uIndex, DeviceType_Network));
548 }
549 else
550 return errorArgument("Invalid boot device '%s'", ValueUnion.psz);
551 break;
552 }
553
554 case MODIFYVM_HDA: // deprecated
555 {
556 if (!strcmp(ValueUnion.psz, "none"))
557 {
558 machine->DetachDevice(Bstr("IDE Controller"), 0, 0);
559 }
560 else
561 {
562 /* first guess is that it's a UUID */
563 Bstr uuid(ValueUnion.psz);
564 ComPtr<IMedium> hardDisk;
565 rc = a->virtualBox->GetHardDisk(uuid, hardDisk.asOutParam());
566 /* not successful? Then it must be a filename */
567 if (!hardDisk)
568 {
569 rc = a->virtualBox->FindHardDisk(Bstr(ValueUnion.psz), hardDisk.asOutParam());
570 if (FAILED(rc))
571 {
572 /* open the new hard disk object */
573 CHECK_ERROR(a->virtualBox,
574 OpenHardDisk(Bstr(ValueUnion.psz),
575 AccessMode_ReadWrite, false, Bstr(""),
576 false, Bstr(""), hardDisk.asOutParam()));
577 }
578 }
579 if (hardDisk)
580 {
581 hardDisk->COMGETTER(Id)(uuid.asOutParam());
582 CHECK_ERROR(machine, AttachDevice(Bstr("IDE Controller"), 0, 0, DeviceType_HardDisk, uuid));
583 }
584 else
585 rc = E_FAIL;
586 }
587 break;
588 }
589
590 case MODIFYVM_HDB: // deprecated
591 {
592 if (!strcmp(ValueUnion.psz, "none"))
593 {
594 machine->DetachDevice(Bstr("IDE Controller"), 0, 1);
595 }
596 else
597 {
598 /* first guess is that it's a UUID */
599 Bstr uuid(ValueUnion.psz);
600 ComPtr<IMedium> hardDisk;
601 rc = a->virtualBox->GetHardDisk(uuid, hardDisk.asOutParam());
602 /* not successful? Then it must be a filename */
603 if (!hardDisk)
604 {
605 rc = a->virtualBox->FindHardDisk(Bstr(ValueUnion.psz), hardDisk.asOutParam());
606 if (FAILED(rc))
607 {
608 /* open the new hard disk object */
609 CHECK_ERROR(a->virtualBox,
610 OpenHardDisk(Bstr(ValueUnion.psz),
611 AccessMode_ReadWrite, false, Bstr(""),
612 false, Bstr(""), hardDisk.asOutParam()));
613 }
614 }
615 if (hardDisk)
616 {
617 hardDisk->COMGETTER(Id)(uuid.asOutParam());
618 CHECK_ERROR(machine, AttachDevice(Bstr("IDE Controller"), 0, 1, DeviceType_HardDisk, uuid));
619 }
620 else
621 rc = E_FAIL;
622 }
623 break;
624 }
625
626 case MODIFYVM_HDD: // deprecated
627 {
628 if (!strcmp(ValueUnion.psz, "none"))
629 {
630 machine->DetachDevice(Bstr("IDE Controller"), 1, 1);
631 }
632 else
633 {
634 /* first guess is that it's a UUID */
635 Bstr uuid(ValueUnion.psz);
636 ComPtr<IMedium> hardDisk;
637 rc = a->virtualBox->GetHardDisk(uuid, hardDisk.asOutParam());
638 /* not successful? Then it must be a filename */
639 if (!hardDisk)
640 {
641 rc = a->virtualBox->FindHardDisk(Bstr(ValueUnion.psz), hardDisk.asOutParam());
642 if (FAILED(rc))
643 {
644 /* open the new hard disk object */
645 CHECK_ERROR(a->virtualBox,
646 OpenHardDisk(Bstr(ValueUnion.psz),
647 AccessMode_ReadWrite, false, Bstr(""),
648 false, Bstr(""), hardDisk.asOutParam()));
649 }
650 }
651 if (hardDisk)
652 {
653 hardDisk->COMGETTER(Id)(uuid.asOutParam());
654 CHECK_ERROR(machine, AttachDevice(Bstr("IDE Controller"), 1, 1, DeviceType_HardDisk, uuid));
655 }
656 else
657 rc = E_FAIL;
658 }
659 break;
660 }
661
662 case MODIFYVM_IDECONTROLLER: // deprecated
663 {
664 ComPtr<IStorageController> storageController;
665 CHECK_ERROR(machine, GetStorageControllerByName(Bstr("IDE Controller"),
666 storageController.asOutParam()));
667
668 if (!RTStrICmp(ValueUnion.psz, "PIIX3"))
669 {
670 CHECK_ERROR(storageController, COMSETTER(ControllerType)(StorageControllerType_PIIX3));
671 }
672 else if (!RTStrICmp(ValueUnion.psz, "PIIX4"))
673 {
674 CHECK_ERROR(storageController, COMSETTER(ControllerType)(StorageControllerType_PIIX4));
675 }
676 else if (!RTStrICmp(ValueUnion.psz, "ICH6"))
677 {
678 CHECK_ERROR(storageController, COMSETTER(ControllerType)(StorageControllerType_ICH6));
679 }
680 else
681 {
682 errorArgument("Invalid --idecontroller argument '%s'", ValueUnion.psz);
683 rc = E_FAIL;
684 }
685 break;
686 }
687
688 case MODIFYVM_SATAIDEEMULATION: // deprecated
689 {
690 ComPtr<IStorageController> SataCtl;
691 CHECK_ERROR(machine, GetStorageControllerByName(Bstr("SATA"), SataCtl.asOutParam()));
692
693 if (SUCCEEDED(rc))
694 CHECK_ERROR(SataCtl, SetIDEEmulationPort(GetOptState.uIndex, ValueUnion.u32));
695 break;
696 }
697
698 case MODIFYVM_SATAPORTCOUNT: // deprecated
699 {
700 ComPtr<IStorageController> SataCtl;
701 CHECK_ERROR(machine, GetStorageControllerByName(Bstr("SATA"), SataCtl.asOutParam()));
702
703 if (SUCCEEDED(rc) && ValueUnion.u32 > 0)
704 CHECK_ERROR(SataCtl, COMSETTER(PortCount)(ValueUnion.u32));
705 break;
706 }
707
708 case MODIFYVM_SATAPORT: // deprecated
709 {
710 if (!strcmp(ValueUnion.psz, "none"))
711 {
712 machine->DetachDevice(Bstr("SATA"), GetOptState.uIndex, 0);
713 }
714 else
715 {
716 /* first guess is that it's a UUID */
717 Bstr uuid(ValueUnion.psz);
718 ComPtr<IMedium> hardDisk;
719 rc = a->virtualBox->GetHardDisk(uuid, hardDisk.asOutParam());
720 /* not successful? Then it must be a filename */
721 if (!hardDisk)
722 {
723 rc = a->virtualBox->FindHardDisk(Bstr(ValueUnion.psz), hardDisk.asOutParam());
724 if (FAILED(rc))
725 {
726 /* open the new hard disk object */
727 CHECK_ERROR(a->virtualBox,
728 OpenHardDisk(Bstr(ValueUnion.psz), AccessMode_ReadWrite,
729 false, Bstr(""), false,
730 Bstr(""), hardDisk.asOutParam()));
731 }
732 }
733 if (hardDisk)
734 {
735 hardDisk->COMGETTER(Id)(uuid.asOutParam());
736 CHECK_ERROR(machine,
737 AttachDevice(Bstr("SATA"), GetOptState.uIndex,
738 0, DeviceType_HardDisk, uuid));
739 }
740 else
741 rc = E_FAIL;
742 }
743 break;
744 }
745
746 case MODIFYVM_SATA: // deprecated
747 {
748 if (!strcmp(ValueUnion.psz, "on") || !strcmp(ValueUnion.psz, "enable"))
749 {
750 ComPtr<IStorageController> ctl;
751 CHECK_ERROR(machine, AddStorageController(Bstr("SATA"), StorageBus_SATA, ctl.asOutParam()));
752 CHECK_ERROR(ctl, COMSETTER(ControllerType)(StorageControllerType_IntelAhci));
753 }
754 else if (!strcmp(ValueUnion.psz, "off") || !strcmp(ValueUnion.psz, "disable"))
755 CHECK_ERROR(machine, RemoveStorageController(Bstr("SATA")));
756 else
757 return errorArgument("Invalid --usb argument '%s'", ValueUnion.psz);
758 break;
759 }
760
761 case MODIFYVM_SCSIPORT: // deprecated
762 {
763 if (!strcmp(ValueUnion.psz, "none"))
764 {
765 rc = machine->DetachDevice(Bstr("LsiLogic"), GetOptState.uIndex, 0);
766 if (FAILED(rc))
767 CHECK_ERROR(machine, DetachDevice(Bstr("BusLogic"), GetOptState.uIndex, 0));
768 }
769 else
770 {
771 /* first guess is that it's a UUID */
772 Bstr uuid(ValueUnion.psz);
773 ComPtr<IMedium> hardDisk;
774 rc = a->virtualBox->GetHardDisk(uuid, hardDisk.asOutParam());
775 /* not successful? Then it must be a filename */
776 if (!hardDisk)
777 {
778 rc = a->virtualBox->FindHardDisk(Bstr(ValueUnion.psz), hardDisk.asOutParam());
779 if (FAILED(rc))
780 {
781 /* open the new hard disk object */
782 CHECK_ERROR(a->virtualBox,
783 OpenHardDisk(Bstr(ValueUnion.psz),
784 AccessMode_ReadWrite, false, Bstr(""),
785 false, Bstr(""), hardDisk.asOutParam()));
786 }
787 }
788 if (hardDisk)
789 {
790 hardDisk->COMGETTER(Id)(uuid.asOutParam());
791 rc = machine->AttachDevice(Bstr("LsiLogic"), GetOptState.uIndex, 0, DeviceType_HardDisk, uuid);
792 if (FAILED(rc))
793 CHECK_ERROR(machine,
794 AttachDevice(Bstr("BusLogic"),
795 GetOptState.uIndex, 0,
796 DeviceType_HardDisk, uuid));
797 }
798 else
799 rc = E_FAIL;
800 }
801 break;
802 }
803
804 case MODIFYVM_SCSITYPE: // deprecated
805 {
806 ComPtr<IStorageController> ctl;
807
808 if (!RTStrICmp(ValueUnion.psz, "LsiLogic"))
809 {
810 rc = machine->RemoveStorageController(Bstr("BusLogic"));
811 if (FAILED(rc))
812 CHECK_ERROR(machine, RemoveStorageController(Bstr("LsiLogic")));
813
814 CHECK_ERROR(machine,
815 AddStorageController(Bstr("LsiLogic"),
816 StorageBus_SCSI,
817 ctl.asOutParam()));
818
819 if (SUCCEEDED(rc))
820 CHECK_ERROR(ctl, COMSETTER(ControllerType)(StorageControllerType_LsiLogic));
821 }
822 else if (!RTStrICmp(ValueUnion.psz, "BusLogic"))
823 {
824 rc = machine->RemoveStorageController(Bstr("LsiLogic"));
825 if (FAILED(rc))
826 CHECK_ERROR(machine, RemoveStorageController(Bstr("BusLogic")));
827
828 CHECK_ERROR(machine,
829 AddStorageController(Bstr("BusLogic"),
830 StorageBus_SCSI,
831 ctl.asOutParam()));
832
833 if (SUCCEEDED(rc))
834 CHECK_ERROR(ctl, COMSETTER(ControllerType)(StorageControllerType_BusLogic));
835 }
836 else
837 return errorArgument("Invalid --scsitype argument '%s'", ValueUnion.psz);
838 break;
839 }
840
841 case MODIFYVM_SCSI: // deprecated
842 {
843 if (!strcmp(ValueUnion.psz, "on") || !strcmp(ValueUnion.psz, "enable"))
844 {
845 ComPtr<IStorageController> ctl;
846
847 CHECK_ERROR(machine, AddStorageController(Bstr("BusLogic"), StorageBus_SCSI, ctl.asOutParam()));
848 if (SUCCEEDED(rc))
849 CHECK_ERROR(ctl, COMSETTER(ControllerType)(StorageControllerType_BusLogic));
850 }
851 else if (!strcmp(ValueUnion.psz, "off") || !strcmp(ValueUnion.psz, "disable"))
852 {
853 rc = machine->RemoveStorageController(Bstr("BusLogic"));
854 if (FAILED(rc))
855 CHECK_ERROR(machine, RemoveStorageController(Bstr("LsiLogic")));
856 }
857 break;
858 }
859
860 case MODIFYVM_DVDPASSTHROUGH: // deprecated
861 {
862 CHECK_ERROR(machine, PassthroughDevice(Bstr("IDE Controller"), 1, 0, !strcmp(ValueUnion.psz, "on")));
863 break;
864 }
865
866 case MODIFYVM_DVD: // deprecated
867 {
868 ComPtr<IMedium> dvdMedium;
869 Bstr uuid(ValueUnion.psz);
870
871 /* unmount? */
872 if (!strcmp(ValueUnion.psz, "none"))
873 {
874 /* nothing to do, NULL object will cause unmount */
875 }
876 /* host drive? */
877 else if (!strncmp(ValueUnion.psz, "host:", 5))
878 {
879 ComPtr<IHost> host;
880 CHECK_ERROR(a->virtualBox, COMGETTER(Host)(host.asOutParam()));
881 rc = host->FindHostDVDDrive(Bstr(ValueUnion.psz + 5), dvdMedium.asOutParam());
882 if (!dvdMedium)
883 {
884 /* 2nd try: try with the real name, important on Linux+libhal */
885 char szPathReal[RTPATH_MAX];
886 if (RT_FAILURE(RTPathReal(ValueUnion.psz + 5, szPathReal, sizeof(szPathReal))))
887 {
888 errorArgument("Invalid host DVD drive name \"%s\"", ValueUnion.psz + 5);
889 rc = E_FAIL;
890 break;
891 }
892 rc = host->FindHostDVDDrive(Bstr(szPathReal), dvdMedium.asOutParam());
893 if (!dvdMedium)
894 {
895 errorArgument("Invalid host DVD drive name \"%s\"", ValueUnion.psz + 5);
896 rc = E_FAIL;
897 break;
898 }
899 }
900 }
901 else
902 {
903 /* first assume it's a UUID */
904 rc = a->virtualBox->GetDVDImage(uuid, dvdMedium.asOutParam());
905 if (FAILED(rc) || !dvdMedium)
906 {
907 /* must be a filename, check if it's in the collection */
908 rc = a->virtualBox->FindDVDImage(Bstr(ValueUnion.psz), dvdMedium.asOutParam());
909 /* not registered, do that on the fly */
910 if (!dvdMedium)
911 {
912 Bstr emptyUUID;
913 CHECK_ERROR(a->virtualBox, OpenDVDImage(Bstr(ValueUnion.psz),
914 emptyUUID, dvdMedium.asOutParam()));
915 }
916 }
917 if (!dvdMedium)
918 {
919 rc = E_FAIL;
920 break;
921 }
922 }
923
924 /** @todo generalize this, allow arbitrary number of DVD drives
925 * and as a consequence multiple attachments and different
926 * storage controllers. */
927 if (dvdMedium)
928 dvdMedium->COMGETTER(Id)(uuid.asOutParam());
929 CHECK_ERROR(machine, MountMedium(Bstr("IDE Controller"), 1, 0, uuid, FALSE /* aForce */));
930 break;
931 }
932
933 case MODIFYVM_FLOPPY: // deprecated
934 {
935 Bstr uuid(ValueUnion.psz);
936 ComPtr<IMedium> floppyMedium;
937 ComPtr<IMediumAttachment> floppyAttachment;
938 machine->GetMediumAttachment(Bstr("Floppy Controller"), 0, 0, floppyAttachment.asOutParam());
939
940 /* disable? */
941 if (!strcmp(ValueUnion.psz, "disabled"))
942 {
943 /* disable the controller */
944 if (floppyAttachment)
945 CHECK_ERROR(machine, DetachDevice(Bstr("Floppy Controller"), 0, 0));
946 }
947 else
948 {
949 /* enable the controller */
950 if (!floppyAttachment)
951 CHECK_ERROR(machine, AttachDevice(Bstr("Floppy Controller"), 0, 0, DeviceType_Floppy, NULL));
952
953 /* unmount? */
954 if ( !strcmp(ValueUnion.psz, "none")
955 || !strcmp(ValueUnion.psz, "empty")) // deprecated
956 {
957 /* nothing to do, NULL object will cause unmount */
958 }
959 /* host drive? */
960 else if (!strncmp(ValueUnion.psz, "host:", 5))
961 {
962 ComPtr<IHost> host;
963 CHECK_ERROR(a->virtualBox, COMGETTER(Host)(host.asOutParam()));
964 rc = host->FindHostFloppyDrive(Bstr(ValueUnion.psz + 5), floppyMedium.asOutParam());
965 if (!floppyMedium)
966 {
967 errorArgument("Invalid host floppy drive name \"%s\"", ValueUnion.psz + 5);
968 rc = E_FAIL;
969 break;
970 }
971 }
972 else
973 {
974 /* first assume it's a UUID */
975 rc = a->virtualBox->GetFloppyImage(uuid, floppyMedium.asOutParam());
976 if (FAILED(rc) || !floppyMedium)
977 {
978 /* must be a filename, check if it's in the collection */
979 rc = a->virtualBox->FindFloppyImage(Bstr(ValueUnion.psz), floppyMedium.asOutParam());
980 /* not registered, do that on the fly */
981 if (!floppyMedium)
982 {
983 Bstr emptyUUID;
984 CHECK_ERROR(a->virtualBox,
985 OpenFloppyImage(Bstr(ValueUnion.psz),
986 emptyUUID,
987 floppyMedium.asOutParam()));
988 }
989 }
990 if (!floppyMedium)
991 {
992 rc = E_FAIL;
993 break;
994 }
995 }
996 floppyMedium->COMGETTER(Id)(uuid.asOutParam());
997 CHECK_ERROR(machine, MountMedium(Bstr("Floppy Controller"), 0, 0, uuid, FALSE /* aForce */));
998 }
999 break;
1000 }
1001
1002 case MODIFYVM_NICTRACEFILE:
1003 {
1004 ComPtr<INetworkAdapter> nic;
1005
1006 CHECK_ERROR_BREAK(machine, GetNetworkAdapter(GetOptState.uIndex - 1, nic.asOutParam()));
1007 ASSERT(nic);
1008
1009 CHECK_ERROR(nic, COMSETTER(TraceFile)(Bstr(ValueUnion.psz)));
1010 break;
1011 }
1012
1013 case MODIFYVM_NICTRACE:
1014 {
1015 ComPtr<INetworkAdapter> nic;
1016
1017 CHECK_ERROR_BREAK(machine, GetNetworkAdapter(GetOptState.uIndex - 1, nic.asOutParam()));
1018 ASSERT(nic);
1019
1020 CHECK_ERROR(nic, COMSETTER(TraceEnabled)(ValueUnion.f));
1021 break;
1022 }
1023
1024 case MODIFYVM_NICTYPE:
1025 {
1026 ComPtr<INetworkAdapter> nic;
1027
1028 CHECK_ERROR_BREAK(machine, GetNetworkAdapter(GetOptState.uIndex - 1, nic.asOutParam()));
1029 ASSERT(nic);
1030
1031 if (!strcmp(ValueUnion.psz, "Am79C970A"))
1032 {
1033 CHECK_ERROR(nic, COMSETTER(AdapterType)(NetworkAdapterType_Am79C970A));
1034 }
1035 else if (!strcmp(ValueUnion.psz, "Am79C973"))
1036 {
1037 CHECK_ERROR(nic, COMSETTER(AdapterType)(NetworkAdapterType_Am79C973));
1038 }
1039#ifdef VBOX_WITH_E1000
1040 else if (!strcmp(ValueUnion.psz, "82540EM"))
1041 {
1042 CHECK_ERROR(nic, COMSETTER(AdapterType)(NetworkAdapterType_I82540EM));
1043 }
1044 else if (!strcmp(ValueUnion.psz, "82543GC"))
1045 {
1046 CHECK_ERROR(nic, COMSETTER(AdapterType)(NetworkAdapterType_I82543GC));
1047 }
1048 else if (!strcmp(ValueUnion.psz, "82545EM"))
1049 {
1050 CHECK_ERROR(nic, COMSETTER(AdapterType)(NetworkAdapterType_I82545EM));
1051 }
1052#endif
1053#ifdef VBOX_WITH_VIRTIO
1054 else if (!strcmp(ValueUnion.psz, "virtio"))
1055 {
1056 CHECK_ERROR(nic, COMSETTER(AdapterType)(NetworkAdapterType_Virtio));
1057 }
1058#endif /* VBOX_WITH_VIRTIO */
1059 else
1060 {
1061 errorArgument("Invalid NIC type '%s' specified for NIC %u", ValueUnion.psz, GetOptState.uIndex);
1062 rc = E_FAIL;
1063 }
1064 break;
1065 }
1066
1067 case MODIFYVM_NICSPEED:
1068 {
1069 ComPtr<INetworkAdapter> nic;
1070
1071 CHECK_ERROR_BREAK(machine, GetNetworkAdapter(GetOptState.uIndex - 1, nic.asOutParam()));
1072 ASSERT(nic);
1073
1074 CHECK_ERROR(nic, COMSETTER(LineSpeed)(ValueUnion.u32));
1075 break;
1076 }
1077
1078 case MODIFYVM_NIC:
1079 {
1080 ComPtr<INetworkAdapter> nic;
1081
1082 CHECK_ERROR_BREAK(machine, GetNetworkAdapter(GetOptState.uIndex - 1, nic.asOutParam()));
1083 ASSERT(nic);
1084
1085 if (!strcmp(ValueUnion.psz, "none"))
1086 {
1087 CHECK_ERROR(nic, COMSETTER(Enabled)(FALSE));
1088 }
1089 else if (!strcmp(ValueUnion.psz, "null"))
1090 {
1091 CHECK_ERROR(nic, COMSETTER(Enabled)(TRUE));
1092 CHECK_ERROR(nic, Detach());
1093 }
1094 else if (!strcmp(ValueUnion.psz, "nat"))
1095 {
1096 CHECK_ERROR(nic, COMSETTER(Enabled)(TRUE));
1097 CHECK_ERROR(nic, AttachToNAT());
1098 }
1099 else if ( !strcmp(ValueUnion.psz, "bridged")
1100 || !strcmp(ValueUnion.psz, "hostif")) /* backward compatibility */
1101 {
1102 CHECK_ERROR(nic, COMSETTER(Enabled)(TRUE));
1103 CHECK_ERROR(nic, AttachToBridgedInterface());
1104 }
1105 else if (!strcmp(ValueUnion.psz, "intnet"))
1106 {
1107 CHECK_ERROR(nic, COMSETTER(Enabled)(TRUE));
1108 CHECK_ERROR(nic, AttachToInternalNetwork());
1109 }
1110#if defined(VBOX_WITH_NETFLT)
1111 else if (!strcmp(ValueUnion.psz, "hostonly"))
1112 {
1113
1114 CHECK_ERROR(nic, COMSETTER(Enabled)(TRUE));
1115 CHECK_ERROR(nic, AttachToHostOnlyInterface());
1116 }
1117#endif
1118 else
1119 {
1120 errorArgument("Invalid type '%s' specfied for NIC %u", ValueUnion.psz, GetOptState.uIndex);
1121 rc = E_FAIL;
1122 }
1123 break;
1124 }
1125
1126 case MODIFYVM_CABLECONNECTED:
1127 {
1128 ComPtr<INetworkAdapter> nic;
1129
1130 CHECK_ERROR_BREAK(machine, GetNetworkAdapter(GetOptState.uIndex - 1, nic.asOutParam()));
1131 ASSERT(nic);
1132
1133 CHECK_ERROR(nic, COMSETTER(CableConnected)(ValueUnion.f));
1134 break;
1135 }
1136
1137 case MODIFYVM_BRIDGEADAPTER:
1138 case MODIFYVM_HOSTONLYADAPTER:
1139 {
1140 ComPtr<INetworkAdapter> nic;
1141
1142 CHECK_ERROR_BREAK(machine, GetNetworkAdapter(GetOptState.uIndex - 1, nic.asOutParam()));
1143 ASSERT(nic);
1144
1145 /* remove it? */
1146 if (!strcmp(ValueUnion.psz, "none"))
1147 {
1148 CHECK_ERROR(nic, COMSETTER(HostInterface)(NULL));
1149 }
1150 else
1151 {
1152 CHECK_ERROR(nic, COMSETTER(HostInterface)(Bstr(ValueUnion.psz)));
1153 }
1154 break;
1155 }
1156
1157 case MODIFYVM_INTNET:
1158 {
1159 ComPtr<INetworkAdapter> nic;
1160
1161 CHECK_ERROR_BREAK(machine, GetNetworkAdapter(GetOptState.uIndex - 1, nic.asOutParam()));
1162 ASSERT(nic);
1163
1164 /* remove it? */
1165 if (!strcmp(ValueUnion.psz, "none"))
1166 {
1167 CHECK_ERROR(nic, COMSETTER(InternalNetwork)(NULL));
1168 }
1169 else
1170 {
1171 CHECK_ERROR(nic, COMSETTER(InternalNetwork)(Bstr(ValueUnion.psz)));
1172 }
1173 break;
1174 }
1175
1176 case MODIFYVM_NATNET:
1177 {
1178 ComPtr<INetworkAdapter> nic;
1179
1180 CHECK_ERROR_BREAK(machine, GetNetworkAdapter(GetOptState.uIndex - 1, nic.asOutParam()));
1181 ASSERT(nic);
1182
1183 CHECK_ERROR(nic, COMSETTER(NATNetwork)(Bstr(ValueUnion.psz)));
1184 break;
1185 }
1186
1187 case MODIFYVM_MACADDRESS:
1188 {
1189 ComPtr<INetworkAdapter> nic;
1190
1191 CHECK_ERROR_BREAK(machine, GetNetworkAdapter(GetOptState.uIndex - 1, nic.asOutParam()));
1192 ASSERT(nic);
1193
1194 /* generate one? */
1195 if (!strcmp(ValueUnion.psz, "auto"))
1196 {
1197 CHECK_ERROR(nic, COMSETTER(MACAddress)(NULL));
1198 }
1199 else
1200 {
1201 CHECK_ERROR(nic, COMSETTER(MACAddress)(Bstr(ValueUnion.psz)));
1202 }
1203 break;
1204 }
1205
1206 case MODIFYVM_UARTMODE:
1207 {
1208 ComPtr<ISerialPort> uart;
1209 char *pszIRQ = NULL;
1210
1211 CHECK_ERROR_BREAK(machine, GetSerialPort(GetOptState.uIndex - 1, uart.asOutParam()));
1212 ASSERT(uart);
1213
1214 if (!strcmp(ValueUnion.psz, "disconnected"))
1215 {
1216 CHECK_ERROR(uart, COMSETTER(HostMode)(PortMode_Disconnected));
1217 }
1218 else if ( !strcmp(ValueUnion.psz, "server")
1219 || !strcmp(ValueUnion.psz, "client")
1220 || !strcmp(ValueUnion.psz, "file"))
1221 {
1222 const char *pszMode = ValueUnion.psz;
1223
1224 int vrc = RTGetOptFetchValue(&GetOptState, &ValueUnion, RTGETOPT_REQ_STRING);
1225 if (RT_FAILURE(vrc))
1226 return errorSyntax(USAGE_MODIFYVM,
1227 "Missing or Invalid argument to '%s'",
1228 GetOptState.pDef->pszLong);
1229
1230 CHECK_ERROR(uart, COMSETTER(Path)(Bstr(ValueUnion.psz)));
1231
1232 if (!strcmp(pszMode, "server"))
1233 {
1234 CHECK_ERROR(uart, COMSETTER(HostMode)(PortMode_HostPipe));
1235 CHECK_ERROR(uart, COMSETTER(Server)(TRUE));
1236 }
1237 else if (!strcmp(pszMode, "client"))
1238 {
1239 CHECK_ERROR(uart, COMSETTER(HostMode)(PortMode_HostPipe));
1240 CHECK_ERROR(uart, COMSETTER(Server)(FALSE));
1241 }
1242 else if (!strcmp(pszMode, "file"))
1243 {
1244 CHECK_ERROR(uart, COMSETTER(HostMode)(PortMode_RawFile));
1245 }
1246 }
1247 else
1248 {
1249 CHECK_ERROR(uart, COMSETTER(Path)(Bstr(ValueUnion.psz)));
1250 CHECK_ERROR(uart, COMSETTER(HostMode)(PortMode_HostDevice));
1251 }
1252 break;
1253 }
1254
1255 case MODIFYVM_UART:
1256 {
1257 ComPtr<ISerialPort> uart;
1258
1259 CHECK_ERROR_BREAK(machine, GetSerialPort(GetOptState.uIndex - 1, uart.asOutParam()));
1260 ASSERT(uart);
1261
1262 if (!strcmp(ValueUnion.psz, "off") || !strcmp(ValueUnion.psz, "disable"))
1263 CHECK_ERROR(uart, COMSETTER(Enabled)(FALSE));
1264 else
1265 {
1266 const char *pszIOBase = ValueUnion.psz;
1267 uint32_t uVal = 0;
1268
1269 int vrc = RTGetOptFetchValue(&GetOptState, &ValueUnion, RTGETOPT_REQ_UINT32) != MODIFYVM_UART;
1270 if (RT_FAILURE(vrc))
1271 return errorSyntax(USAGE_MODIFYVM,
1272 "Missing or Invalid argument to '%s'",
1273 GetOptState.pDef->pszLong);
1274
1275 CHECK_ERROR(uart, COMSETTER(IRQ)(ValueUnion.u32));
1276
1277 vrc = RTStrToUInt32Ex(pszIOBase, NULL, 0, &uVal);
1278 if (vrc != VINF_SUCCESS || uVal == 0)
1279 return errorArgument("Error parsing UART I/O base '%s'", pszIOBase);
1280 CHECK_ERROR(uart, COMSETTER(IOBase)(uVal));
1281
1282 CHECK_ERROR(uart, COMSETTER(Enabled)(TRUE));
1283 }
1284 break;
1285 }
1286
1287 case MODIFYVM_GUESTSTATISTICSINTERVAL:
1288 {
1289 CHECK_ERROR(machine, COMSETTER(StatisticsUpdateInterval)(ValueUnion.u32));
1290 break;
1291 }
1292
1293 case MODIFYVM_GUESTMEMORYBALLOON:
1294 {
1295 CHECK_ERROR(machine, COMSETTER(MemoryBalloonSize)(ValueUnion.u32));
1296 break;
1297 }
1298
1299 case MODIFYVM_AUDIOCONTROLLER:
1300 {
1301 ComPtr<IAudioAdapter> audioAdapter;
1302 machine->COMGETTER(AudioAdapter)(audioAdapter.asOutParam());
1303 ASSERT(audioAdapter);
1304
1305 if (!strcmp(ValueUnion.psz, "sb16"))
1306 CHECK_ERROR(audioAdapter, COMSETTER(AudioController)(AudioControllerType_SB16));
1307 else if (!strcmp(ValueUnion.psz, "ac97"))
1308 CHECK_ERROR(audioAdapter, COMSETTER(AudioController)(AudioControllerType_AC97));
1309 else
1310 {
1311 errorArgument("Invalid --audiocontroller argument '%s'", ValueUnion.psz);
1312 rc = E_FAIL;
1313 }
1314 break;
1315 }
1316
1317 case MODIFYVM_AUDIO:
1318 {
1319 ComPtr<IAudioAdapter> audioAdapter;
1320 machine->COMGETTER(AudioAdapter)(audioAdapter.asOutParam());
1321 ASSERT(audioAdapter);
1322
1323 /* disable? */
1324 if (!strcmp(ValueUnion.psz, "none"))
1325 {
1326 CHECK_ERROR(audioAdapter, COMSETTER(Enabled)(false));
1327 }
1328 else if (!strcmp(ValueUnion.psz, "null"))
1329 {
1330 CHECK_ERROR(audioAdapter, COMSETTER(AudioDriver)(AudioDriverType_Null));
1331 CHECK_ERROR(audioAdapter, COMSETTER(Enabled)(true));
1332 }
1333#ifdef RT_OS_WINDOWS
1334#ifdef VBOX_WITH_WINMM
1335 else if (!strcmp(ValueUnion.psz, "winmm"))
1336 {
1337 CHECK_ERROR(audioAdapter, COMSETTER(AudioDriver)(AudioDriverType_WinMM));
1338 CHECK_ERROR(audioAdapter, COMSETTER(Enabled)(true));
1339 }
1340#endif
1341 else if (!strcmp(ValueUnion.psz, "dsound"))
1342 {
1343 CHECK_ERROR(audioAdapter, COMSETTER(AudioDriver)(AudioDriverType_DirectSound));
1344 CHECK_ERROR(audioAdapter, COMSETTER(Enabled)(true));
1345 }
1346#endif /* RT_OS_WINDOWS */
1347#ifdef RT_OS_LINUX
1348# ifdef VBOX_WITH_ALSA
1349 else if (!strcmp(ValueUnion.psz, "alsa"))
1350 {
1351 CHECK_ERROR(audioAdapter, COMSETTER(AudioDriver)(AudioDriverType_ALSA));
1352 CHECK_ERROR(audioAdapter, COMSETTER(Enabled)(true));
1353 }
1354# endif
1355# ifdef VBOX_WITH_PULSE
1356 else if (!strcmp(ValueUnion.psz, "pulse"))
1357 {
1358 CHECK_ERROR(audioAdapter, COMSETTER(AudioDriver)(AudioDriverType_Pulse));
1359 CHECK_ERROR(audioAdapter, COMSETTER(Enabled)(true));
1360 }
1361# endif
1362#endif /* !RT_OS_LINUX */
1363#ifdef RT_OS_SOLARIS
1364 else if (!strcmp(ValueUnion.psz, "solaudio"))
1365 {
1366 CHECK_ERROR(audioAdapter, COMSETTER(AudioDriver)(AudioDriverType_SolAudio));
1367 CHECK_ERROR(audioAdapter, COMSETTER(Enabled)(true));
1368 }
1369#endif /* !RT_OS_SOLARIS */
1370#ifdef RT_OS_FREEBSD
1371 else if (!strcmp(ValueUnion.psz, "oss"))
1372 {
1373 CHECK_ERROR(audioAdapter, COMSETTER(AudioDriver)(AudioDriverType_OSS));
1374 CHECK_ERROR(audioAdapter, COMSETTER(Enabled)(true));
1375 }
1376# ifdef VBOX_WITH_PULSE
1377 else if (!strcmp(ValueUnion.psz, "pulse"))
1378 {
1379 CHECK_ERROR(audioAdapter, COMSETTER(AudioDriver)(AudioDriverType_Pulse));
1380 CHECK_ERROR(audioAdapter, COMSETTER(Enabled)(true));
1381 }
1382# endif
1383#endif /* !RT_OS_FREEBSD */
1384#ifdef RT_OS_DARWIN
1385 else if (!strcmp(ValueUnion.psz, "coreaudio"))
1386 {
1387 CHECK_ERROR(audioAdapter, COMSETTER(AudioDriver)(AudioDriverType_CoreAudio));
1388 CHECK_ERROR(audioAdapter, COMSETTER(Enabled)(true));
1389 }
1390
1391#endif /* !RT_OS_DARWIN */
1392# if defined(RT_OS_FREEBSD) || defined(RT_OS_LINUX) || defined(VBOX_WITH_SOLARIS_OSS)
1393 else if (!strcmp(ValueUnion.psz, "oss"))
1394 {
1395 CHECK_ERROR(audioAdapter, COMSETTER(AudioDriver)(AudioDriverType_OSS));
1396 CHECK_ERROR(audioAdapter, COMSETTER(Enabled)(true));
1397 }
1398# endif
1399 else
1400 {
1401 errorArgument("Invalid --audio argument '%s'", ValueUnion.psz);
1402 rc = E_FAIL;
1403 }
1404 break;
1405 }
1406
1407 case MODIFYVM_CLIPBOARD:
1408 {
1409 if (!strcmp(ValueUnion.psz, "disabled"))
1410 {
1411 CHECK_ERROR(machine, COMSETTER(ClipboardMode)(ClipboardMode_Disabled));
1412 }
1413 else if (!strcmp(ValueUnion.psz, "hosttoguest"))
1414 {
1415 CHECK_ERROR(machine, COMSETTER(ClipboardMode)(ClipboardMode_HostToGuest));
1416 }
1417 else if (!strcmp(ValueUnion.psz, "guesttohost"))
1418 {
1419 CHECK_ERROR(machine, COMSETTER(ClipboardMode)(ClipboardMode_GuestToHost));
1420 }
1421 else if (!strcmp(ValueUnion.psz, "bidirectional"))
1422 {
1423 CHECK_ERROR(machine, COMSETTER(ClipboardMode)(ClipboardMode_Bidirectional));
1424 }
1425 else
1426 {
1427 errorArgument("Invalid --clipboard argument '%s'", ValueUnion.psz);
1428 rc = E_FAIL;
1429 }
1430 break;
1431 }
1432
1433#ifdef VBOX_WITH_VRDP
1434 case MODIFYVM_VRDPPORT:
1435 {
1436 ComPtr<IVRDPServer> vrdpServer;
1437 machine->COMGETTER(VRDPServer)(vrdpServer.asOutParam());
1438 ASSERT(vrdpServer);
1439
1440 if (!strcmp(ValueUnion.psz, "default"))
1441 CHECK_ERROR(vrdpServer, COMSETTER(Ports)(Bstr("0")));
1442 else
1443 CHECK_ERROR(vrdpServer, COMSETTER(Ports)(Bstr(ValueUnion.psz)));
1444 break;
1445 }
1446
1447 case MODIFYVM_VRDPADDRESS:
1448 {
1449 ComPtr<IVRDPServer> vrdpServer;
1450 machine->COMGETTER(VRDPServer)(vrdpServer.asOutParam());
1451 ASSERT(vrdpServer);
1452
1453 CHECK_ERROR(vrdpServer, COMSETTER(NetAddress)(Bstr(ValueUnion.psz)));
1454 break;
1455 }
1456
1457 case MODIFYVM_VRDPAUTHTYPE:
1458 {
1459 ComPtr<IVRDPServer> vrdpServer;
1460 machine->COMGETTER(VRDPServer)(vrdpServer.asOutParam());
1461 ASSERT(vrdpServer);
1462
1463 if (!strcmp(ValueUnion.psz, "null"))
1464 {
1465 CHECK_ERROR(vrdpServer, COMSETTER(AuthType)(VRDPAuthType_Null));
1466 }
1467 else if (!strcmp(ValueUnion.psz, "external"))
1468 {
1469 CHECK_ERROR(vrdpServer, COMSETTER(AuthType)(VRDPAuthType_External));
1470 }
1471 else if (!strcmp(ValueUnion.psz, "guest"))
1472 {
1473 CHECK_ERROR(vrdpServer, COMSETTER(AuthType)(VRDPAuthType_Guest));
1474 }
1475 else
1476 {
1477 errorArgument("Invalid --vrdpauthtype argument '%s'", ValueUnion.psz);
1478 rc = E_FAIL;
1479 }
1480 break;
1481 }
1482
1483 case MODIFYVM_VRDPMULTICON:
1484 {
1485 ComPtr<IVRDPServer> vrdpServer;
1486 machine->COMGETTER(VRDPServer)(vrdpServer.asOutParam());
1487 ASSERT(vrdpServer);
1488
1489 CHECK_ERROR(vrdpServer, COMSETTER(AllowMultiConnection)(ValueUnion.f));
1490 break;
1491 }
1492
1493 case MODIFYVM_VRDPREUSECON:
1494 {
1495 ComPtr<IVRDPServer> vrdpServer;
1496 machine->COMGETTER(VRDPServer)(vrdpServer.asOutParam());
1497 ASSERT(vrdpServer);
1498
1499 CHECK_ERROR(vrdpServer, COMSETTER(ReuseSingleConnection)(ValueUnion.f));
1500 break;
1501 }
1502
1503 case MODIFYVM_VRDP:
1504 {
1505 ComPtr<IVRDPServer> vrdpServer;
1506 machine->COMGETTER(VRDPServer)(vrdpServer.asOutParam());
1507 ASSERT(vrdpServer);
1508
1509 CHECK_ERROR(vrdpServer, COMSETTER(Enabled)(ValueUnion.f));
1510 break;
1511 }
1512#endif /* VBOX_WITH_VRDP */
1513
1514 case MODIFYVM_USBEHCI:
1515 {
1516 ComPtr<IUSBController> UsbCtl;
1517 CHECK_ERROR(machine, COMGETTER(USBController)(UsbCtl.asOutParam()));
1518 if (SUCCEEDED(rc))
1519 CHECK_ERROR(UsbCtl, COMSETTER(EnabledEhci)(ValueUnion.f));
1520 break;
1521 }
1522
1523 case MODIFYVM_USB:
1524 {
1525 ComPtr<IUSBController> UsbCtl;
1526 CHECK_ERROR(machine, COMGETTER(USBController)(UsbCtl.asOutParam()));
1527 if (SUCCEEDED(rc))
1528 CHECK_ERROR(UsbCtl, COMSETTER(Enabled)(ValueUnion.f));
1529 break;
1530 }
1531
1532 case MODIFYVM_SNAPSHOTFOLDER:
1533 {
1534 if (!strcmp(ValueUnion.psz, "default"))
1535 CHECK_ERROR(machine, COMSETTER(SnapshotFolder)(NULL));
1536 else
1537 CHECK_ERROR(machine, COMSETTER(SnapshotFolder)(Bstr(ValueUnion.psz)));
1538 break;
1539 }
1540
1541 case MODIFYVM_TELEPORTER_ENABLED:
1542 {
1543 CHECK_ERROR(machine, COMSETTER(TeleporterEnabled)(ValueUnion.f));
1544 break;
1545 }
1546
1547 case MODIFYVM_TELEPORTER_PORT:
1548 {
1549 CHECK_ERROR(machine, COMSETTER(TeleporterPort)(ValueUnion.u32));
1550 break;
1551 }
1552
1553 case MODIFYVM_TELEPORTER_ADDRESS:
1554 {
1555 CHECK_ERROR(machine, COMSETTER(TeleporterAddress)(Bstr(ValueUnion.psz)));
1556 break;
1557 }
1558
1559 case MODIFYVM_TELEPORTER_PASSWORD:
1560 {
1561 CHECK_ERROR(machine, COMSETTER(TeleporterPassword)(Bstr(ValueUnion.psz)));
1562 break;
1563 }
1564
1565 case MODIFYVM_HARDWARE_UUID:
1566 {
1567 CHECK_ERROR(machine, COMSETTER(HardwareUUID)(Bstr(ValueUnion.psz)));
1568 break;
1569 }
1570
1571 default:
1572 {
1573 errorGetOpt(USAGE_MODIFYVM, c, &ValueUnion);
1574 rc = E_FAIL;
1575 break;
1576 }
1577 }
1578 }
1579
1580 /* commit changes */
1581 if (SUCCEEDED(rc))
1582 CHECK_ERROR(machine, SaveSettings());
1583
1584 /* it's important to always close sessions */
1585 a->session->Close();
1586
1587 return SUCCEEDED(rc) ? 0 : 1;
1588}
1589
1590#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