VirtualBox

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

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

medium: rename default IDE/FD storage controller names to IDE Controller and Floppy Controller

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 76.5 KB
Line 
1/* $Id: VBoxManageModifyVM.cpp 23249 2009-09-23 09:57:11Z 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 <VBox/log.h>
44
45#include "VBoxManage.h"
46
47#ifndef VBOX_ONLY_DOCS
48using namespace com;
49
50
51/** @todo refine this after HDD changes; MSC 8.0/64 has trouble with handleModifyVM. */
52#if defined(_MSC_VER)
53# pragma optimize("g", off)
54#endif
55
56int handleModifyVM(HandlerArg *a)
57{
58 HRESULT rc;
59 Bstr name;
60 Bstr ostype;
61 uint32_t memorySize = 0;
62 uint32_t vramSize = 0;
63 char *acpi = NULL;
64 char *hwvirtex = NULL;
65 char *nestedpaging = NULL;
66 char *vtxvpid = NULL;
67 char *pae = NULL;
68 uint32_t numCpus = UINT32_MAX;
69 char *ioapic = NULL;
70 uint32_t monitorcount = ~0;
71 char *accelerate3d = NULL;
72#ifdef VBOX_WITH_VIDEOHWACCEL
73 char *accelerate2dvideo = NULL;
74#endif
75 char *bioslogofadein = NULL;
76 char *bioslogofadeout = NULL;
77 uint32_t bioslogodisplaytime = ~0;
78 char *bioslogoimagepath = NULL;
79 char *biosbootmenumode = NULL;
80 char *biossystemtimeoffset = NULL;
81 char *biospxedebug = NULL;
82 DeviceType_T bootDevice[4];
83 int bootDeviceChanged[4] = { false };
84 char *hdds[50] = {0};
85 char *dvd = NULL;
86 char *dvdpassthrough = NULL;
87 char *idecontroller = NULL;
88 char *floppy = NULL;
89 char *audio = NULL;
90 char *audiocontroller = NULL;
91 char *clipboard = NULL;
92 char *firmware = NULL;
93#ifdef VBOX_WITH_VRDP
94 char *vrdp = NULL;
95 uint16_t vrdpport = UINT16_MAX;
96 char *vrdpaddress = NULL;
97 char *vrdpauthtype = NULL;
98 char *vrdpmulticon = NULL;
99 char *vrdpreusecon = NULL;
100#endif
101 int fUsbEnabled = -1;
102 int fUsbEhciEnabled = -1;
103 char *snapshotFolder = NULL;
104 ULONG guestMemBalloonSize = (ULONG)-1;
105 ULONG guestStatInterval = (ULONG)-1;
106 int fSataEnabled = -1;
107 int fScsiEnabled = -1;
108 int fScsiLsiLogic = -1;
109 int sataPortCount = -1;
110 int sataBootDevices[4] = {-1,-1,-1,-1};
111
112 /* VM ID + at least one parameter. Parameter arguments are checked
113 * individually. */
114 if (a->argc < 2)
115 return errorSyntax(USAGE_MODIFYVM, "Not enough parameters");
116
117 /* Get the number of network adapters */
118 ULONG NetworkAdapterCount = 0;
119 {
120 ComPtr <ISystemProperties> info;
121 CHECK_ERROR_RET (a->virtualBox, COMGETTER(SystemProperties) (info.asOutParam()), 1);
122 CHECK_ERROR_RET (info, COMGETTER(NetworkAdapterCount) (&NetworkAdapterCount), 1);
123 }
124 ULONG SerialPortCount = 0;
125 {
126 ComPtr <ISystemProperties> info;
127 CHECK_ERROR_RET (a->virtualBox, COMGETTER(SystemProperties) (info.asOutParam()), 1);
128 CHECK_ERROR_RET (info, COMGETTER(SerialPortCount) (&SerialPortCount), 1);
129 }
130
131 std::vector <char *> nics (NetworkAdapterCount, 0);
132 std::vector <char *> nictype (NetworkAdapterCount, 0);
133 std::vector <char *> cableconnected (NetworkAdapterCount, 0);
134 std::vector <char *> nictrace (NetworkAdapterCount, 0);
135 std::vector <char *> nictracefile (NetworkAdapterCount, 0);
136 std::vector <char *> nicspeed (NetworkAdapterCount, 0);
137 std::vector <char *> hostifdev (NetworkAdapterCount, 0);
138 std::vector <const char *> intnet (NetworkAdapterCount, 0);
139 std::vector <const char *> natnet (NetworkAdapterCount, 0);
140 std::vector <char *> macs (NetworkAdapterCount, 0);
141 std::vector <char *> uarts_mode (SerialPortCount, 0);
142 std::vector <ULONG> uarts_base (SerialPortCount, 0);
143 std::vector <ULONG> uarts_irq (SerialPortCount, 0);
144 std::vector <char *> uarts_path (SerialPortCount, 0);
145
146 for (int i = 1; i < a->argc; i++)
147 {
148 if ( !strcmp(a->argv[i], "--name")
149 || !strcmp(a->argv[i], "-name"))
150 {
151 if (a->argc <= i + 1)
152 return errorArgument("Missing argument to '%s'", a->argv[i]);
153 i++;
154 name = a->argv[i];
155 }
156 else if ( !strcmp(a->argv[i], "--ostype")
157 || !strcmp(a->argv[i], "-ostype"))
158 {
159 if (a->argc <= i + 1)
160 return errorArgument("Missing argument to '%s'", a->argv[i]);
161 i++;
162 ostype = a->argv[i];
163 }
164 else if ( !strcmp(a->argv[i], "--memory")
165 || !strcmp(a->argv[i], "-memory"))
166 {
167 if (a->argc <= i + 1)
168 return errorArgument("Missing argument to '%s'", a->argv[i]);
169 i++;
170 memorySize = RTStrToUInt32(a->argv[i]);
171 }
172 else if ( !strcmp(a->argv[i], "--vram")
173 || !strcmp(a->argv[i], "-vram"))
174 {
175 if (a->argc <= i + 1)
176 return errorArgument("Missing argument to '%s'", a->argv[i]);
177 i++;
178 vramSize = RTStrToUInt32(a->argv[i]);
179 }
180 else if ( !strcmp(a->argv[i], "--acpi")
181 || !strcmp(a->argv[i], "-acpi"))
182 {
183 if (a->argc <= i + 1)
184 return errorArgument("Missing argument to '%s'", a->argv[i]);
185 i++;
186 acpi = a->argv[i];
187 }
188 else if ( !strcmp(a->argv[i], "--ioapic")
189 || !strcmp(a->argv[i], "-ioapic"))
190 {
191 if (a->argc <= i + 1)
192 return errorArgument("Missing argument to '%s'", a->argv[i]);
193 i++;
194 ioapic = a->argv[i];
195 }
196 else if ( !strcmp(a->argv[i], "--hwvirtex")
197 || !strcmp(a->argv[i], "-hwvirtex"))
198 {
199 if (a->argc <= i + 1)
200 return errorArgument("Missing argument to '%s'", a->argv[i]);
201 i++;
202 hwvirtex = a->argv[i];
203 }
204 else if ( !strcmp(a->argv[i], "--nestedpaging")
205 || !strcmp(a->argv[i], "-nestedpaging"))
206 {
207 if (a->argc <= i + 1)
208 return errorArgument("Missing argument to '%s'", a->argv[i]);
209 i++;
210 nestedpaging = a->argv[i];
211 }
212 else if ( !strcmp(a->argv[i], "--vtxvpid")
213 || !strcmp(a->argv[i], "-vtxvpid"))
214 {
215 if (a->argc <= i + 1)
216 return errorArgument("Missing argument to '%s'", a->argv[i]);
217 i++;
218 vtxvpid = a->argv[i];
219 }
220 else if ( !strcmp(a->argv[i], "--pae")
221 || !strcmp(a->argv[i], "-pae"))
222 {
223 if (a->argc <= i + 1)
224 return errorArgument("Missing argument to '%s'", a->argv[i]);
225 i++;
226 pae = a->argv[i];
227 }
228 else if (!strcmp(a->argv[i], "--cpus"))
229 {
230 if (a->argc <= i + 1)
231 return errorArgument("Missing argument to '%s'", a->argv[i]);
232 i++;
233 numCpus = RTStrToUInt32(a->argv[i]);
234 if (numCpus == UINT32_MAX)
235 return errorArgument("The number of cpus cannot be 0.", a->argv[i]);
236 }
237 else if ( !strcmp(a->argv[i], "--monitorcount")
238 || !strcmp(a->argv[i], "-monitorcount"))
239 {
240 if (a->argc <= i + 1)
241 return errorArgument("Missing argument to '%s'", a->argv[i]);
242 i++;
243 monitorcount = RTStrToUInt32(a->argv[i]);
244 }
245 else if ( !strcmp(a->argv[i], "--accelerate3d")
246 || !strcmp(a->argv[i], "-accelerate3d"))
247 {
248 if (a->argc <= i + 1)
249 return errorArgument("Missing argument to '%s'", a->argv[i]);
250 i++;
251 accelerate3d = a->argv[i];
252 }
253#ifdef VBOX_WITH_VIDEOHWACCEL
254 else if ( !strcmp(a->argv[i], "--accelerate2dvideo")
255 || !strcmp(a->argv[i], "-accelerate2dvideo"))
256 {
257 if (a->argc <= i + 1)
258 return errorArgument("Missing argument to '%s'", a->argv[i]);
259 i++;
260 accelerate2dvideo = a->argv[i];
261 }
262#endif
263 else if ( !strcmp(a->argv[i], "--firmware")
264 || !strcmp(a->argv[i], "-firmware"))
265 {
266 if (a->argc <= i + 1)
267 return errorArgument("Missing argument to '%s'", a->argv[i]);
268 i++;
269 firmware = a->argv[i];
270 }
271 else if ( !strcmp(a->argv[i], "--bioslogofadein")
272 || !strcmp(a->argv[i], "-bioslogofadein"))
273 {
274 if (a->argc <= i + 1)
275 return errorArgument("Missing argument to '%s'", a->argv[i]);
276 i++;
277 bioslogofadein = a->argv[i];
278 }
279 else if ( !strcmp(a->argv[i], "--bioslogofadeout")
280 || !strcmp(a->argv[i], "-bioslogofadeout"))
281 {
282 if (a->argc <= i + 1)
283 return errorArgument("Missing argument to '%s'", a->argv[i]);
284 i++;
285 bioslogofadeout = a->argv[i];
286 }
287 else if ( !strcmp(a->argv[i], "--bioslogodisplaytime")
288 || !strcmp(a->argv[i], "-bioslogodisplaytime"))
289 {
290 if (a->argc <= i + 1)
291 return errorArgument("Missing argument to '%s'", a->argv[i]);
292 i++;
293 bioslogodisplaytime = RTStrToUInt32(a->argv[i]);
294 }
295 else if ( !strcmp(a->argv[i], "--bioslogoimagepath")
296 || !strcmp(a->argv[i], "-bioslogoimagepath"))
297 {
298 if (a->argc <= i + 1)
299 return errorArgument("Missing argument to '%s'", a->argv[i]);
300 i++;
301 bioslogoimagepath = a->argv[i];
302 }
303 else if ( !strcmp(a->argv[i], "--biosbootmenu")
304 || !strcmp(a->argv[i], "-biosbootmenu"))
305 {
306 if (a->argc <= i + 1)
307 return errorArgument("Missing argument to '%s'", a->argv[i]);
308 i++;
309 biosbootmenumode = a->argv[i];
310 }
311 else if ( !strcmp(a->argv[i], "--biossystemtimeoffset")
312 || !strcmp(a->argv[i], "-biossystemtimeoffset"))
313 {
314 if (a->argc <= i + 1)
315 return errorArgument("Missing argument to '%s'", a->argv[i]);
316 i++;
317 biossystemtimeoffset = a->argv[i];
318 }
319 else if ( !strcmp(a->argv[i], "--biospxedebug")
320 || !strcmp(a->argv[i], "-biospxedebug"))
321 {
322 if (a->argc <= i + 1)
323 return errorArgument("Missing argument to '%s'", a->argv[i]);
324 i++;
325 biospxedebug = a->argv[i];
326 }
327 else if ( !strncmp(a->argv[i], "--boot", 6)
328 || !strncmp(a->argv[i], "-boot", 5))
329 {
330 uint32_t n = 0;
331 if (!a->argv[i][5 + (a->argv[i][1] == '-')])
332 return errorSyntax(USAGE_MODIFYVM, "Missing boot slot number in '%s'", a->argv[i]);
333 if (VINF_SUCCESS != RTStrToUInt32Full(&a->argv[i][5 + (a->argv[i][1] == '-')], 10, &n))
334 return errorSyntax(USAGE_MODIFYVM, "Invalid boot slot number in '%s'", a->argv[i]);
335 if (a->argc <= i + 1)
336 return errorArgument("Missing argument to '%s'", a->argv[i]);
337 i++;
338 if (!strcmp(a->argv[i], "none"))
339 {
340 bootDevice[n - 1] = DeviceType_Null;
341 }
342 else if (!strcmp(a->argv[i], "floppy"))
343 {
344 bootDevice[n - 1] = DeviceType_Floppy;
345 }
346 else if (!strcmp(a->argv[i], "dvd"))
347 {
348 bootDevice[n - 1] = DeviceType_DVD;
349 }
350 else if (!strcmp(a->argv[i], "disk"))
351 {
352 bootDevice[n - 1] = DeviceType_HardDisk;
353 }
354 else if (!strcmp(a->argv[i], "net"))
355 {
356 bootDevice[n - 1] = DeviceType_Network;
357 }
358 else
359 return errorArgument("Invalid boot device '%s'", a->argv[i]);
360
361 bootDeviceChanged[n - 1] = true;
362 }
363 else if ( !strcmp(a->argv[i], "--hda")
364 || !strcmp(a->argv[i], "-hda"))
365 {
366 if (a->argc <= i + 1)
367 return errorArgument("Missing argument to '%s'", a->argv[i]);
368 i++;
369 hdds[0] = a->argv[i];
370 }
371 else if ( !strcmp(a->argv[i], "--hdb")
372 || !strcmp(a->argv[i], "-hdb"))
373 {
374 if (a->argc <= i + 1)
375 return errorArgument("Missing argument to '%s'", a->argv[i]);
376 i++;
377 hdds[1] = a->argv[i];
378 }
379 else if ( !strcmp(a->argv[i], "--hdd")
380 || !strcmp(a->argv[i], "-hdd"))
381 {
382 if (a->argc <= i + 1)
383 return errorArgument("Missing argument to '%s'", a->argv[i]);
384 i++;
385 hdds[2] = a->argv[i];
386 }
387 else if ( !strcmp(a->argv[i], "--dvd")
388 || !strcmp(a->argv[i], "-dvd"))
389 {
390 if (a->argc <= i + 1)
391 return errorArgument("Missing argument to '%s'", a->argv[i]);
392 i++;
393 dvd = a->argv[i];
394 }
395 else if ( !strcmp(a->argv[i], "--dvdpassthrough")
396 || !strcmp(a->argv[i], "-dvdpassthrough"))
397 {
398 if (a->argc <= i + 1)
399 return errorArgument("Missing argument to '%s'", a->argv[i]);
400 i++;
401 dvdpassthrough = a->argv[i];
402 }
403 else if ( !strcmp(a->argv[i], "--idecontroller")
404 || !strcmp(a->argv[i], "-idecontroller"))
405 {
406 if (a->argc <= i + 1)
407 return errorArgument("Missing argument to '%s'", a->argv[i]);
408 i++;
409 idecontroller = a->argv[i];
410 }
411 else if ( !strcmp(a->argv[i], "--floppy")
412 || !strcmp(a->argv[i], "-floppy"))
413 {
414 if (a->argc <= i + 1)
415 return errorArgument("Missing argument to '%s'", a->argv[i]);
416 i++;
417 floppy = a->argv[i];
418 }
419 else if ( !strcmp(a->argv[i], "--audio")
420 || !strcmp(a->argv[i], "-audio"))
421 {
422 if (a->argc <= i + 1)
423 return errorArgument("Missing argument to '%s'", a->argv[i]);
424 i++;
425 audio = a->argv[i];
426 }
427 else if ( !strcmp(a->argv[i], "--audiocontroller")
428 || !strcmp(a->argv[i], "-audiocontroller"))
429 {
430 if (a->argc <= i + 1)
431 return errorArgument("Missing argument to '%s'", a->argv[i]);
432 i++;
433 audiocontroller = a->argv[i];
434 }
435 else if ( !strcmp(a->argv[i], "--clipboard")
436 || !strcmp(a->argv[i], "-clipboard"))
437 {
438 if (a->argc <= i + 1)
439 return errorArgument("Missing argument to '%s'", a->argv[i]);
440 i++;
441 clipboard = a->argv[i];
442 }
443 else if ( !strncmp(a->argv[i], "--cableconnected", 16)
444 || !strncmp(a->argv[i], "-cableconnected", 15))
445 {
446 unsigned n = parseNum(&a->argv[i][15 + (a->argv[i][1] == '-')], NetworkAdapterCount, "NIC");
447 if (!n)
448 return 1;
449
450 if (a->argc <= i + 1)
451 return errorArgument("Missing argument to '%s'", a->argv[i]);
452
453 cableconnected[n - 1] = a->argv[i + 1];
454 i++;
455 }
456 /* watch for the right order of these --nic* comparisons! */
457 else if ( !strncmp(a->argv[i], "--nictracefile", 14)
458 || !strncmp(a->argv[i], "-nictracefile", 13))
459 {
460 unsigned n = parseNum(&a->argv[i][13 + (a->argv[i][1] == '-')], NetworkAdapterCount, "NIC");
461 if (!n)
462 return 1;
463 if (a->argc <= i + 1)
464 {
465 return errorArgument("Missing argument to '%s'", a->argv[i]);
466 }
467 nictracefile[n - 1] = a->argv[i + 1];
468 i++;
469 }
470 else if ( !strncmp(a->argv[i], "--nictrace", 10)
471 || !strncmp(a->argv[i], "-nictrace", 9))
472 {
473 unsigned n = parseNum(&a->argv[i][9 + (a->argv[i][1] == '-')], NetworkAdapterCount, "NIC");
474 if (!n)
475 return 1;
476 if (a->argc <= i + 1)
477 return errorArgument("Missing argument to '%s'", a->argv[i]);
478 nictrace[n - 1] = a->argv[i + 1];
479 i++;
480 }
481 else if ( !strncmp(a->argv[i], "--nictype", 9)
482 || !strncmp(a->argv[i], "-nictype", 8))
483 {
484 unsigned n = parseNum(&a->argv[i][8 + (a->argv[i][1] == '-')], NetworkAdapterCount, "NIC");
485 if (!n)
486 return 1;
487 if (a->argc <= i + 1)
488 return errorArgument("Missing argument to '%s'", a->argv[i]);
489 nictype[n - 1] = a->argv[i + 1];
490 i++;
491 }
492 else if ( !strncmp(a->argv[i], "--nicspeed", 10)
493 || !strncmp(a->argv[i], "-nicspeed", 9))
494 {
495 unsigned n = parseNum(&a->argv[i][9 + (a->argv[i][1] == '-')], NetworkAdapterCount, "NIC");
496 if (!n)
497 return 1;
498 if (a->argc <= i + 1)
499 return errorArgument("Missing argument to '%s'", a->argv[i]);
500 nicspeed[n - 1] = a->argv[i + 1];
501 i++;
502 }
503 else if ( !strncmp(a->argv[i], "--nic", 5)
504 || !strncmp(a->argv[i], "-nic", 4))
505 {
506 unsigned n = parseNum(&a->argv[i][4 + (a->argv[i][1] == '-')], NetworkAdapterCount, "NIC");
507 if (!n)
508 return 1;
509 if (a->argc <= i + 1)
510 return errorArgument("Missing argument to '%s'", a->argv[i]);
511 nics[n - 1] = a->argv[i + 1];
512 i++;
513 }
514 else if ( !strncmp(a->argv[i], "--hostifdev", 11)
515 || !strncmp(a->argv[i], "-hostifdev", 10)) /* backward compatibility */
516 {
517 unsigned n = parseNum(&a->argv[i][10 + (a->argv[i][1] == '-')], NetworkAdapterCount, "NIC");
518 if (!n)
519 return 1;
520 if (a->argc <= i + 1)
521 return errorArgument("Missing argument to '%s'", a->argv[i]);
522 hostifdev[n - 1] = a->argv[i + 1];
523 i++;
524 }
525 else if ( !strncmp(a->argv[i], "--bridgeadapter", 15)
526 || !strncmp(a->argv[i], "-bridgeadapter", 14))
527 {
528 unsigned n = parseNum(&a->argv[i][14 + (a->argv[i][1] == '-')], NetworkAdapterCount, "NIC");
529 if (!n)
530 return 1;
531 if (a->argc <= i + 1)
532 return errorArgument("Missing argument to '%s'", a->argv[i]);
533 hostifdev[n - 1] = a->argv[i + 1];
534 i++;
535 }
536#if defined(VBOX_WITH_NETFLT)
537 else if ( !strncmp(a->argv[i], "--hostonlyadapter", 17)
538 || !strncmp(a->argv[i], "-hostonlyadapter", 16))
539 {
540 unsigned n = parseNum(&a->argv[i][16 + (a->argv[i][1] == '-')], NetworkAdapterCount, "NIC");
541 if (!n)
542 return 1;
543 if (a->argc <= i + 1)
544 return errorArgument("Missing argument to '%s'", a->argv[i]);
545 hostifdev[n - 1] = a->argv[i + 1];
546 i++;
547 }
548#endif
549 else if ( !strncmp(a->argv[i], "--intnet", 8)
550 || !strncmp(a->argv[i], "-intnet", 7))
551 {
552 unsigned n = parseNum(&a->argv[i][7 + (a->argv[i][1] == '-')], NetworkAdapterCount, "NIC");
553 if (!n)
554 return 1;
555 if (a->argc <= i + 1)
556 return errorArgument("Missing argument to '%s'", a->argv[i]);
557 intnet[n - 1] = a->argv[i + 1];
558 i++;
559 }
560 else if ( !strncmp(a->argv[i], "--natnet", 8)
561 || !strncmp(a->argv[i], "-natnet", 7))
562 {
563 unsigned n = parseNum(&a->argv[i][7 + (a->argv[i][1] == '-')], NetworkAdapterCount, "NIC");
564 if (!n)
565 return 1;
566 if (a->argc <= i + 1)
567 return errorArgument("Missing argument to '%s'", a->argv[i]);
568
569 if (!strcmp(a->argv[i + 1], "default"))
570 natnet[n - 1] = "";
571 else
572 {
573 RTIPV4ADDR Network;
574 RTIPV4ADDR Netmask;
575 int rc = RTCidrStrToIPv4(a->argv[i + 1], &Network, &Netmask);
576 if (RT_FAILURE(rc))
577 return errorArgument("Invalid IPv4 network '%s' specified -- CIDR notation expected.\n", a->argv[i + 1]);
578 if (Netmask & 0x1f)
579 return errorArgument("Prefix length of the NAT network must be less than 28.\n");
580 natnet[n - 1] = a->argv[i + 1];
581 }
582 i++;
583 }
584 else if ( !strncmp(a->argv[i], "--macaddress", 12)
585 || !strncmp(a->argv[i], "-macaddress", 11))
586 {
587 unsigned n = parseNum(&a->argv[i][11 + (a->argv[i][1] == '-')], NetworkAdapterCount, "NIC");
588 if (!n)
589 return 1;
590 if (a->argc <= i + 1)
591 return errorArgument("Missing argument to '%s'", a->argv[i]);
592 macs[n - 1] = a->argv[i + 1];
593 i++;
594 }
595#ifdef VBOX_WITH_VRDP
596 else if ( !strcmp(a->argv[i], "--vrdp")
597 || !strcmp(a->argv[i], "-vrdp"))
598 {
599 if (a->argc <= i + 1)
600 return errorArgument("Missing argument to '%s'", a->argv[i]);
601 i++;
602 vrdp = a->argv[i];
603 }
604 else if ( !strcmp(a->argv[i], "--vrdpport")
605 || !strcmp(a->argv[i], "-vrdpport"))
606 {
607 if (a->argc <= i + 1)
608 return errorArgument("Missing argument to '%s'", a->argv[i]);
609 i++;
610 if (!strcmp(a->argv[i], "default"))
611 vrdpport = 0;
612 else
613 vrdpport = RTStrToUInt16(a->argv[i]);
614 }
615 else if ( !strcmp(a->argv[i], "--vrdpaddress")
616 || !strcmp(a->argv[i], "-vrdpaddress"))
617 {
618 if (a->argc <= i + 1)
619 return errorArgument("Missing argument to '%s'", a->argv[i]);
620 i++;
621 vrdpaddress = a->argv[i];
622 }
623 else if ( !strcmp(a->argv[i], "--vrdpauthtype")
624 || !strcmp(a->argv[i], "-vrdpauthtype"))
625 {
626 if (a->argc <= i + 1)
627 return errorArgument("Missing argument to '%s'", a->argv[i]);
628 i++;
629 vrdpauthtype = a->argv[i];
630 }
631 else if ( !strcmp(a->argv[i], "--vrdpmulticon")
632 || !strcmp(a->argv[i], "-vrdpmulticon"))
633 {
634 if (a->argc <= i + 1)
635 return errorArgument("Missing argument to '%s'", a->argv[i]);
636 i++;
637 vrdpmulticon = a->argv[i];
638 }
639 else if ( !strcmp(a->argv[i], "--vrdpreusecon")
640 || !strcmp(a->argv[i], "-vrdpreusecon"))
641 {
642 if (a->argc <= i + 1)
643 return errorArgument("Missing argument to '%s'", a->argv[i]);
644 i++;
645 vrdpreusecon = a->argv[i];
646 }
647#endif /* VBOX_WITH_VRDP */
648 else if ( !strcmp(a->argv[i], "--usb")
649 || !strcmp(a->argv[i], "-usb"))
650 {
651 if (a->argc <= i + 1)
652 return errorArgument("Missing argument to '%s'", a->argv[i]);
653 i++;
654 if (!strcmp(a->argv[i], "on") || !strcmp(a->argv[i], "enable"))
655 fUsbEnabled = 1;
656 else if (!strcmp(a->argv[i], "off") || !strcmp(a->argv[i], "disable"))
657 fUsbEnabled = 0;
658 else
659 return errorArgument("Invalid --usb argument '%s'", a->argv[i]);
660 }
661 else if ( !strcmp(a->argv[i], "--usbehci")
662 || !strcmp(a->argv[i], "-usbehci"))
663 {
664 if (a->argc <= i + 1)
665 return errorArgument("Missing argument to '%s'", a->argv[i]);
666 i++;
667 if (!strcmp(a->argv[i], "on") || !strcmp(a->argv[i], "enable"))
668 fUsbEhciEnabled = 1;
669 else if (!strcmp(a->argv[i], "off") || !strcmp(a->argv[i], "disable"))
670 fUsbEhciEnabled = 0;
671 else
672 return errorArgument("Invalid --usbehci argument '%s'", a->argv[i]);
673 }
674 else if ( !strcmp(a->argv[i], "--snapshotfolder")
675 || !strcmp(a->argv[i], "-snapshotfolder"))
676 {
677 if (a->argc <= i + 1)
678 return errorArgument("Missing argument to '%s'", a->argv[i]);
679 i++;
680 snapshotFolder = a->argv[i];
681 }
682 else if ( !strncmp(a->argv[i], "--uartmode", 10)
683 || !strncmp(a->argv[i], "-uartmode", 9))
684 {
685 unsigned n = parseNum(&a->argv[i][9 + (a->argv[i][1] == '-')], SerialPortCount, "UART");
686 if (!n)
687 return 1;
688 i++;
689 if (!strcmp(a->argv[i], "disconnected"))
690 {
691 uarts_mode[n - 1] = a->argv[i];
692 }
693 else
694 {
695 if (!strcmp(a->argv[i], "server") || !strcmp(a->argv[i], "client"))
696 {
697 uarts_mode[n - 1] = a->argv[i];
698 i++;
699#ifdef RT_OS_WINDOWS
700 if (!strncmp(a->argv[i], "\\\\.\\pipe\\", 9))
701 return errorArgument("Uart pipe must start with \\\\.\\pipe\\");
702#endif
703 }
704 else if (!strcmp(a->argv[i], "file"))
705 {
706 uarts_mode[n - 1] = a->argv[i];
707 i++;
708 }
709 else
710 {
711 uarts_mode[n - 1] = (char*)"device";
712 }
713 if (a->argc <= i)
714 return errorArgument("Missing argument to --uartmode");
715 uarts_path[n - 1] = a->argv[i];
716 }
717 }
718 else if ( !strncmp(a->argv[i], "--uart", 6)
719 || !strncmp(a->argv[i], "-uart", 5))
720 {
721 unsigned n = parseNum(&a->argv[i][5 + (a->argv[i][1] == '-')], SerialPortCount, "UART");
722 if (!n)
723 return 1;
724 if (a->argc <= i + 1)
725 return errorArgument("Missing argument to '%s'", a->argv[i]);
726 i++;
727 if (!strcmp(a->argv[i], "off") || !strcmp(a->argv[i], "disable"))
728 {
729 uarts_base[n - 1] = (ULONG)-1;
730 }
731 else
732 {
733 if (a->argc <= i + 1)
734 return errorArgument("Missing argument to '%s'", a->argv[i-1]);
735 uint32_t uVal;
736 int vrc;
737 vrc = RTStrToUInt32Ex(a->argv[i], NULL, 0, &uVal);
738 if (vrc != VINF_SUCCESS || uVal == 0)
739 return errorArgument("Error parsing UART I/O base '%s'", a->argv[i]);
740 uarts_base[n - 1] = uVal;
741 i++;
742 vrc = RTStrToUInt32Ex(a->argv[i], NULL, 0, &uVal);
743 if (vrc != VINF_SUCCESS)
744 return errorArgument("Error parsing UART IRQ '%s'", a->argv[i]);
745 uarts_irq[n - 1] = uVal;
746 }
747 }
748#ifdef VBOX_WITH_MEM_BALLOONING
749 else if ( !strcmp(a->argv[i], "--guestmemoryballoon")
750 || !strcmp(a->argv[i], "-guestmemoryballoon"))
751 {
752 if (a->argc <= i + 1)
753 return errorArgument("Missing argument to '%s'", a->argv[i]);
754 i++;
755 uint32_t uVal;
756 int vrc;
757 vrc = RTStrToUInt32Ex(a->argv[i], NULL, 0, &uVal);
758 if (vrc != VINF_SUCCESS)
759 return errorArgument("Error parsing guest memory balloon size '%s'", a->argv[i]);
760 guestMemBalloonSize = uVal;
761 }
762#endif
763 else if ( !strcmp(a->argv[i], "--gueststatisticsinterval")
764 || !strcmp(a->argv[i], "-gueststatisticsinterval"))
765 {
766 if (a->argc <= i + 1)
767 return errorArgument("Missing argument to '%s'", a->argv[i]);
768 i++;
769 uint32_t uVal;
770 int vrc;
771 vrc = RTStrToUInt32Ex(a->argv[i], NULL, 0, &uVal);
772 if (vrc != VINF_SUCCESS)
773 return errorArgument("Error parsing guest statistics interval '%s'", a->argv[i]);
774 guestStatInterval = uVal;
775 }
776 else if ( !strcmp(a->argv[i], "--sata")
777 || !strcmp(a->argv[i], "-sata"))
778 {
779 if (a->argc <= i + 1)
780 return errorArgument("Missing argument to '%s'", a->argv[i]);
781 i++;
782 if (!strcmp(a->argv[i], "on") || !strcmp(a->argv[i], "enable"))
783 fSataEnabled = 1;
784 else if (!strcmp(a->argv[i], "off") || !strcmp(a->argv[i], "disable"))
785 fSataEnabled = 0;
786 else
787 return errorArgument("Invalid --usb argument '%s'", a->argv[i]);
788 }
789 else if ( !strcmp(a->argv[i], "--sataportcount")
790 || !strcmp(a->argv[i], "-sataportcount"))
791 {
792 unsigned n;
793
794 if (a->argc <= i + 1)
795 return errorArgument("Missing arguments to '%s'", a->argv[i]);
796 i++;
797
798 n = parseNum(a->argv[i], 30, "SATA");
799 if (!n)
800 return 1;
801 sataPortCount = n;
802 }
803 else if ( !strncmp(a->argv[i], "--sataport", 10)
804 || !strncmp(a->argv[i], "-sataport", 9))
805 {
806 unsigned n = parseNum(&a->argv[i][9 + (a->argv[i][1] == '-')], 30, "SATA");
807 if (!n)
808 return 1;
809 if (a->argc <= i + 1)
810 return errorArgument("Missing argument to '%s'", a->argv[i]);
811 i++;
812 hdds[n-1+4] = a->argv[i];
813 }
814 else if ( !strncmp(a->argv[i], "--sataideemulation", 18)
815 || !strncmp(a->argv[i], "-sataideemulation", 17))
816 {
817 unsigned bootDevicePos = 0;
818 unsigned n;
819
820 bootDevicePos = parseNum(&a->argv[i][17 + (a->argv[i][1] == '-')], 4, "SATA");
821 if (!bootDevicePos)
822 return 1;
823 bootDevicePos--;
824
825 if (a->argc <= i + 1)
826 return errorArgument("Missing arguments to '%s'", a->argv[i]);
827 i++;
828
829 n = parseNum(a->argv[i], 30, "SATA");
830 if (!n)
831 return 1;
832
833 sataBootDevices[bootDevicePos] = n-1;
834 }
835 else if ( !strcmp(a->argv[i], "--scsi")
836 || !strcmp(a->argv[i], "-scsi"))
837 {
838 if (a->argc <= i + 1)
839 return errorArgument("Missing argument to '%s'", a->argv[i]);
840 i++;
841 if (!strcmp(a->argv[i], "on") || !strcmp(a->argv[i], "enable"))
842 fScsiEnabled = 1;
843 else if (!strcmp(a->argv[i], "off") || !strcmp(a->argv[i], "disable"))
844 fScsiEnabled = 0;
845 else
846 return errorArgument("Invalid --scsi argument '%s'", a->argv[i]);
847 }
848 else if ( !strncmp(a->argv[i], "--scsiport", 10)
849 || !strncmp(a->argv[i], "-scsiport", 9))
850 {
851 unsigned n = parseNum(&a->argv[i][9 + (a->argv[i][1] == '-')], 16, "SCSI");
852 if (!n)
853 return 1;
854 if (a->argc <= i + 1)
855 return errorArgument("Missing argument to '%s'", a->argv[i]);
856 i++;
857 hdds[n-1+34] = a->argv[i];
858 }
859 else if ( !strcmp(a->argv[i], "--scsitype")
860 || !strcmp(a->argv[i], "-scsitype"))
861 {
862 if (a->argc <= i + 1)
863 return errorArgument("Missing argument to '%s'", a->argv[i]);
864 i++;
865 if (!RTStrICmp(a->argv[i], "LsiLogic"))
866 fScsiLsiLogic = 1;
867 else if (!RTStrICmp(a->argv[i], "BusLogic"))
868 fScsiLsiLogic = 0;
869 else
870 return errorArgument("Invalid --scsitype argument '%s'", a->argv[i]);
871 }
872 else
873 return errorSyntax(USAGE_MODIFYVM, "Invalid parameter '%s'", Utf8Str(a->argv[i]).raw());
874 }
875
876 /* try to find the given machine */
877 ComPtr <IMachine> machine;
878 Bstr uuid (a->argv[0]);
879 if (!Guid(uuid).isEmpty())
880 {
881 CHECK_ERROR (a->virtualBox, GetMachine (uuid, machine.asOutParam()));
882 }
883 else
884 {
885 CHECK_ERROR (a->virtualBox, FindMachine(Bstr(a->argv[0]), machine.asOutParam()));
886 if (SUCCEEDED (rc))
887 machine->COMGETTER(Id)(uuid.asOutParam());
888 }
889 if (FAILED (rc))
890 return 1;
891
892 /* open a session for the VM */
893 CHECK_ERROR_RET (a->virtualBox, OpenSession(a->session, uuid), 1);
894
895 do
896 {
897 /* get the mutable session machine */
898 a->session->COMGETTER(Machine)(machine.asOutParam());
899
900 ComPtr <IBIOSSettings> biosSettings;
901 machine->COMGETTER(BIOSSettings)(biosSettings.asOutParam());
902
903 if (name)
904 CHECK_ERROR(machine, COMSETTER(Name)(name));
905 if (ostype)
906 {
907 ComPtr<IGuestOSType> guestOSType;
908 CHECK_ERROR(a->virtualBox, GetGuestOSType(ostype, guestOSType.asOutParam()));
909 if (SUCCEEDED(rc) && guestOSType)
910 {
911 CHECK_ERROR(machine, COMSETTER(OSTypeId)(ostype));
912 }
913 else
914 {
915 errorArgument("Invalid guest OS type '%s'", Utf8Str(ostype).raw());
916 rc = E_FAIL;
917 break;
918 }
919 }
920 if (memorySize > 0)
921 CHECK_ERROR(machine, COMSETTER(MemorySize)(memorySize));
922 if (vramSize > 0)
923 CHECK_ERROR(machine, COMSETTER(VRAMSize)(vramSize));
924 if (acpi)
925 {
926 if (!strcmp(acpi, "on"))
927 {
928 CHECK_ERROR(biosSettings, COMSETTER(ACPIEnabled)(true));
929 }
930 else if (!strcmp(acpi, "off"))
931 {
932 CHECK_ERROR(biosSettings, COMSETTER(ACPIEnabled)(false));
933 }
934 else
935 {
936 errorArgument("Invalid --acpi argument '%s'", acpi);
937 rc = E_FAIL;
938 break;
939 }
940 }
941 if (ioapic)
942 {
943 if (!strcmp(ioapic, "on"))
944 {
945 CHECK_ERROR(biosSettings, COMSETTER(IOAPICEnabled)(true));
946 }
947 else if (!strcmp(ioapic, "off"))
948 {
949 CHECK_ERROR(biosSettings, COMSETTER(IOAPICEnabled)(false));
950 }
951 else
952 {
953 errorArgument("Invalid --ioapic argument '%s'", ioapic);
954 rc = E_FAIL;
955 break;
956 }
957 }
958 if (hwvirtex)
959 {
960 if (!strcmp(hwvirtex, "on"))
961 {
962 CHECK_ERROR(machine, COMSETTER(HWVirtExEnabled)(TRUE));
963 }
964 else if (!strcmp(hwvirtex, "off"))
965 {
966 CHECK_ERROR(machine, COMSETTER(HWVirtExEnabled)(FALSE));
967 }
968 else
969 {
970 errorArgument("Invalid --hwvirtex argument '%s'", hwvirtex);
971 rc = E_FAIL;
972 break;
973 }
974 }
975 if (nestedpaging)
976 {
977 if (!strcmp(nestedpaging, "on"))
978 {
979 CHECK_ERROR(machine, COMSETTER(HWVirtExNestedPagingEnabled)(true));
980 }
981 else if (!strcmp(nestedpaging, "off"))
982 {
983 CHECK_ERROR(machine, COMSETTER(HWVirtExNestedPagingEnabled)(false));
984 }
985 else
986 {
987 errorArgument("Invalid --nestedpaging argument '%s'", ioapic);
988 rc = E_FAIL;
989 break;
990 }
991 }
992 if (vtxvpid)
993 {
994 if (!strcmp(vtxvpid, "on"))
995 {
996 CHECK_ERROR(machine, COMSETTER(HWVirtExVPIDEnabled)(true));
997 }
998 else if (!strcmp(vtxvpid, "off"))
999 {
1000 CHECK_ERROR(machine, COMSETTER(HWVirtExVPIDEnabled)(false));
1001 }
1002 else
1003 {
1004 errorArgument("Invalid --vtxvpid argument '%s'", ioapic);
1005 rc = E_FAIL;
1006 break;
1007 }
1008 }
1009 if (pae)
1010 {
1011 if (!strcmp(pae, "on"))
1012 {
1013 CHECK_ERROR(machine, COMSETTER(PAEEnabled)(true));
1014 }
1015 else if (!strcmp(pae, "off"))
1016 {
1017 CHECK_ERROR(machine, COMSETTER(PAEEnabled)(false));
1018 }
1019 else
1020 {
1021 errorArgument("Invalid --pae argument '%s'", ioapic);
1022 rc = E_FAIL;
1023 break;
1024 }
1025 }
1026 if (numCpus != UINT32_MAX)
1027 {
1028 CHECK_ERROR(machine, COMSETTER(CPUCount)(numCpus));
1029 }
1030 if (monitorcount != ~0U)
1031 {
1032 CHECK_ERROR(machine, COMSETTER(MonitorCount)(monitorcount));
1033 }
1034 if (accelerate3d)
1035 {
1036 if (!strcmp(accelerate3d, "on"))
1037 {
1038 CHECK_ERROR(machine, COMSETTER(Accelerate3DEnabled)(true));
1039 }
1040 else if (!strcmp(accelerate3d, "off"))
1041 {
1042 CHECK_ERROR(machine, COMSETTER(Accelerate3DEnabled)(false));
1043 }
1044 else
1045 {
1046 errorArgument("Invalid --accelerate3d argument '%s'", accelerate3d);
1047 rc = E_FAIL;
1048 break;
1049 }
1050 }
1051#ifdef VBOX_WITH_VIDEOHWACCEL
1052 if (accelerate2dvideo)
1053 {
1054 if (!strcmp(accelerate2dvideo, "on"))
1055 {
1056 CHECK_ERROR(machine, COMSETTER(Accelerate2DVideoEnabled)(true));
1057 }
1058 else if (!strcmp(accelerate2dvideo, "off"))
1059 {
1060 CHECK_ERROR(machine, COMSETTER(Accelerate2DVideoEnabled)(false));
1061 }
1062 else
1063 {
1064 errorArgument("Invalid --accelerate2dvideo argument '%s'", accelerate2dvideo);
1065 rc = E_FAIL;
1066 break;
1067 }
1068 }
1069#endif
1070 if (firmware)
1071 {
1072 if (!strcmp(firmware, "efi"))
1073 {
1074 CHECK_ERROR(machine, COMSETTER(FirmwareType)(FirmwareType_EFI));
1075 }
1076 else if (!strcmp(firmware, "bios"))
1077 {
1078 CHECK_ERROR(machine, COMSETTER(FirmwareType)(FirmwareType_BIOS));
1079 }
1080 else
1081 {
1082 errorArgument("Invalid --firmware argument '%s'", firmware);
1083 rc = E_FAIL;
1084 break;
1085 }
1086 }
1087 if (bioslogofadein)
1088 {
1089 if (!strcmp(bioslogofadein, "on"))
1090 {
1091 CHECK_ERROR(biosSettings, COMSETTER(LogoFadeIn)(true));
1092 }
1093 else if (!strcmp(bioslogofadein, "off"))
1094 {
1095 CHECK_ERROR(biosSettings, COMSETTER(LogoFadeIn)(false));
1096 }
1097 else
1098 {
1099 errorArgument("Invalid --bioslogofadein argument '%s'", bioslogofadein);
1100 rc = E_FAIL;
1101 break;
1102 }
1103 }
1104 if (bioslogofadeout)
1105 {
1106 if (!strcmp(bioslogofadeout, "on"))
1107 {
1108 CHECK_ERROR(biosSettings, COMSETTER(LogoFadeOut)(true));
1109 }
1110 else if (!strcmp(bioslogofadeout, "off"))
1111 {
1112 CHECK_ERROR(biosSettings, COMSETTER(LogoFadeOut)(false));
1113 }
1114 else
1115 {
1116 errorArgument("Invalid --bioslogofadeout argument '%s'", bioslogofadeout);
1117 rc = E_FAIL;
1118 break;
1119 }
1120 }
1121 if (bioslogodisplaytime != ~0U)
1122 {
1123 CHECK_ERROR(biosSettings, COMSETTER(LogoDisplayTime)(bioslogodisplaytime));
1124 }
1125 if (bioslogoimagepath)
1126 {
1127 CHECK_ERROR(biosSettings, COMSETTER(LogoImagePath)(Bstr(bioslogoimagepath)));
1128 }
1129 if (biosbootmenumode)
1130 {
1131 if (!strcmp(biosbootmenumode, "disabled"))
1132 CHECK_ERROR(biosSettings, COMSETTER(BootMenuMode)(BIOSBootMenuMode_Disabled));
1133 else if (!strcmp(biosbootmenumode, "menuonly"))
1134 CHECK_ERROR(biosSettings, COMSETTER(BootMenuMode)(BIOSBootMenuMode_MenuOnly));
1135 else if (!strcmp(biosbootmenumode, "messageandmenu"))
1136 CHECK_ERROR(biosSettings, COMSETTER(BootMenuMode)(BIOSBootMenuMode_MessageAndMenu));
1137 else
1138 {
1139 errorArgument("Invalid --biosbootmenu argument '%s'", biosbootmenumode);
1140 rc = E_FAIL;
1141 break;
1142 }
1143
1144 }
1145 if (biossystemtimeoffset)
1146 {
1147 LONG64 timeOffset = RTStrToInt64(biossystemtimeoffset);
1148 CHECK_ERROR(biosSettings, COMSETTER(TimeOffset)(timeOffset));
1149 }
1150 if (biospxedebug)
1151 {
1152 if (!strcmp(biospxedebug, "on"))
1153 {
1154 CHECK_ERROR(biosSettings, COMSETTER(PXEDebugEnabled)(true));
1155 }
1156 else if (!strcmp(biospxedebug, "off"))
1157 {
1158 CHECK_ERROR(biosSettings, COMSETTER(PXEDebugEnabled)(false));
1159 }
1160 else
1161 {
1162 errorArgument("Invalid --biospxedebug argument '%s'", biospxedebug);
1163 rc = E_FAIL;
1164 break;
1165 }
1166 }
1167 for (int curBootDev = 0; curBootDev < 4; curBootDev++)
1168 {
1169 if (bootDeviceChanged[curBootDev])
1170 CHECK_ERROR(machine, SetBootOrder (curBootDev + 1, bootDevice[curBootDev]));
1171 }
1172 if (hdds[0])
1173 {
1174 if (!strcmp(hdds[0], "none"))
1175 {
1176 machine->DetachDevice(Bstr("IDE Controller"), 0, 0);
1177 }
1178 else
1179 {
1180 /* first guess is that it's a UUID */
1181 Bstr uuid(hdds[0]);
1182 ComPtr<IMedium> hardDisk;
1183 rc = a->virtualBox->GetHardDisk(uuid, hardDisk.asOutParam());
1184 /* not successful? Then it must be a filename */
1185 if (!hardDisk)
1186 {
1187 rc = a->virtualBox->FindHardDisk(Bstr(hdds[0]), hardDisk.asOutParam());
1188 if (FAILED(rc))
1189 {
1190 /* open the new hard disk object */
1191 CHECK_ERROR(a->virtualBox, OpenHardDisk(Bstr(hdds[0]), AccessMode_ReadWrite, false, Bstr(""), false, Bstr(""), hardDisk.asOutParam()));
1192 }
1193 }
1194 if (hardDisk)
1195 {
1196 hardDisk->COMGETTER(Id)(uuid.asOutParam());
1197 CHECK_ERROR(machine, AttachDevice(Bstr("IDE Controller"), 0, 0, DeviceType_HardDisk, uuid));
1198 }
1199 else
1200 rc = E_FAIL;
1201 if (FAILED(rc))
1202 break;
1203 }
1204 }
1205 if (hdds[1])
1206 {
1207 if (!strcmp(hdds[1], "none"))
1208 {
1209 machine->DetachDevice(Bstr("IDE Controller"), 0, 1);
1210 }
1211 else
1212 {
1213 /* first guess is that it's a UUID */
1214 Bstr uuid(hdds[1]);
1215 ComPtr<IMedium> hardDisk;
1216 rc = a->virtualBox->GetHardDisk(uuid, hardDisk.asOutParam());
1217 /* not successful? Then it must be a filename */
1218 if (!hardDisk)
1219 {
1220 rc = a->virtualBox->FindHardDisk(Bstr(hdds[1]), hardDisk.asOutParam());
1221 if (FAILED(rc))
1222 {
1223 /* open the new hard disk object */
1224 CHECK_ERROR(a->virtualBox, OpenHardDisk(Bstr(hdds[1]), AccessMode_ReadWrite, false, Bstr(""), false, Bstr(""), hardDisk.asOutParam()));
1225 }
1226 }
1227 if (hardDisk)
1228 {
1229 hardDisk->COMGETTER(Id)(uuid.asOutParam());
1230 CHECK_ERROR(machine, AttachDevice(Bstr("IDE Controller"), 0, 1, DeviceType_HardDisk, uuid));
1231 }
1232 else
1233 rc = E_FAIL;
1234 if (FAILED(rc))
1235 break;
1236 }
1237 }
1238 if (hdds[2])
1239 {
1240 if (!strcmp(hdds[2], "none"))
1241 {
1242 machine->DetachDevice(Bstr("IDE Controller"), 1, 1);
1243 }
1244 else
1245 {
1246 /* first guess is that it's a UUID */
1247 Bstr uuid(hdds[2]);
1248 ComPtr<IMedium> hardDisk;
1249 rc = a->virtualBox->GetHardDisk(uuid, hardDisk.asOutParam());
1250 /* not successful? Then it must be a filename */
1251 if (!hardDisk)
1252 {
1253 rc = a->virtualBox->FindHardDisk(Bstr(hdds[2]), hardDisk.asOutParam());
1254 if (FAILED(rc))
1255 {
1256 /* open the new hard disk object */
1257 CHECK_ERROR(a->virtualBox, OpenHardDisk(Bstr(hdds[2]), AccessMode_ReadWrite, false, Bstr(""), false, Bstr(""), hardDisk.asOutParam()));
1258 }
1259 }
1260 if (hardDisk)
1261 {
1262 hardDisk->COMGETTER(Id)(uuid.asOutParam());
1263 CHECK_ERROR(machine, AttachDevice(Bstr("IDE Controller"), 1, 1, DeviceType_HardDisk, uuid));
1264 }
1265 else
1266 rc = E_FAIL;
1267 if (FAILED(rc))
1268 break;
1269 }
1270 }
1271 if (dvd)
1272 {
1273 ComPtr<IMedium> dvdMedium;
1274
1275 /* unmount? */
1276 if (!strcmp(dvd, "none"))
1277 {
1278 /* nothing to do, NULL object will cause unmount */
1279 }
1280 /* host drive? */
1281 else if (!strncmp(dvd, "host:", 5))
1282 {
1283 ComPtr<IHost> host;
1284 CHECK_ERROR(a->virtualBox, COMGETTER(Host)(host.asOutParam()));
1285 rc = host->FindHostDVDDrive(Bstr(dvd + 5), dvdMedium.asOutParam());
1286 if (!dvdMedium)
1287 {
1288 /* 2nd try: try with the real name, important on Linux+libhal */
1289 char szPathReal[RTPATH_MAX];
1290 if (RT_FAILURE(RTPathReal(dvd + 5, szPathReal, sizeof(szPathReal))))
1291 {
1292 errorArgument("Invalid host DVD drive name \"%s\"", dvd + 5);
1293 rc = E_FAIL;
1294 break;
1295 }
1296 rc = host->FindHostDVDDrive(Bstr(szPathReal), dvdMedium.asOutParam());
1297 if (!dvdMedium)
1298 {
1299 errorArgument("Invalid host DVD drive name \"%s\"", dvd + 5);
1300 rc = E_FAIL;
1301 break;
1302 }
1303 }
1304 }
1305 else
1306 {
1307 /* first assume it's a UUID */
1308 Bstr uuid(dvd);
1309 rc = a->virtualBox->GetDVDImage(uuid, dvdMedium.asOutParam());
1310 if (FAILED(rc) || !dvdMedium)
1311 {
1312 /* must be a filename, check if it's in the collection */
1313 rc = a->virtualBox->FindDVDImage(Bstr(dvd), dvdMedium.asOutParam());
1314 /* not registered, do that on the fly */
1315 if (!dvdMedium)
1316 {
1317 Bstr emptyUUID;
1318 CHECK_ERROR(a->virtualBox, OpenDVDImage(Bstr(dvd), emptyUUID, dvdMedium.asOutParam()));
1319 }
1320 }
1321 if (!dvdMedium)
1322 {
1323 rc = E_FAIL;
1324 break;
1325 }
1326 }
1327
1328 /** @todo generalize this, allow arbitrary number of DVD drives
1329 * and as a consequence multiple attachments and different
1330 * storage controllers. */
1331 dvdMedium->COMGETTER(Id)(uuid.asOutParam());
1332 CHECK_ERROR(machine, MountMedium(Bstr("IDE Controller"), 1, 0, uuid));
1333 }
1334 if (dvdpassthrough)
1335 {
1336 ComPtr<IMediumAttachment> dvdAttachment;
1337 machine->GetMediumAttachment(Bstr("IDE Controller"), 1, 0, dvdAttachment.asOutParam());
1338 ASSERT(dvdAttachment);
1339
1340 CHECK_ERROR(dvdAttachment, COMSETTER(Passthrough)(!strcmp(dvdpassthrough, "on")));
1341 }
1342 if (idecontroller)
1343 {
1344 ComPtr<IStorageController> storageController;
1345 CHECK_ERROR(machine, GetStorageControllerByName(Bstr("IDE Controller"), storageController.asOutParam()));
1346
1347 if (!RTStrICmp(idecontroller, "PIIX3"))
1348 {
1349 CHECK_ERROR(storageController, COMSETTER(ControllerType)(StorageControllerType_PIIX3));
1350 }
1351 else if (!RTStrICmp(idecontroller, "PIIX4"))
1352 {
1353 CHECK_ERROR(storageController, COMSETTER(ControllerType)(StorageControllerType_PIIX4));
1354 }
1355 else if (!RTStrICmp(idecontroller, "ICH6"))
1356 {
1357 CHECK_ERROR(storageController, COMSETTER(ControllerType)(StorageControllerType_ICH6));
1358 }
1359 else
1360 {
1361 errorArgument("Invalid --idecontroller argument '%s'", idecontroller);
1362 rc = E_FAIL;
1363 break;
1364 }
1365 }
1366 if (floppy)
1367 {
1368 ComPtr<IMedium> floppyMedium;
1369 ComPtr<IMediumAttachment> floppyAttachment;
1370 machine->GetMediumAttachment(Bstr("Floppy Controller"), 0, 0, floppyAttachment.asOutParam());
1371
1372 /* disable? */
1373 if (!strcmp(floppy, "disabled"))
1374 {
1375 /* disable the controller */
1376 if (floppyAttachment)
1377 CHECK_ERROR(machine, DetachDevice(Bstr("Floppy Controller"), 0, 0));
1378 }
1379 else
1380 {
1381 /* enable the controller */
1382 if (!floppyAttachment)
1383 CHECK_ERROR(machine, AttachDevice(Bstr("Floppy Controller"), 0, 0, DeviceType_Floppy, NULL));
1384
1385 /* unmount? */
1386 if ( !strcmp(floppy, "none")
1387 || !strcmp(floppy, "empty")) // deprecated
1388 {
1389 /* nothing to do, NULL object will cause unmount */
1390 }
1391 /* host drive? */
1392 else if (!strncmp(floppy, "host:", 5))
1393 {
1394 ComPtr<IHost> host;
1395 CHECK_ERROR(a->virtualBox, COMGETTER(Host)(host.asOutParam()));
1396 rc = host->FindHostFloppyDrive(Bstr(floppy + 5), floppyMedium.asOutParam());
1397 if (!floppyMedium)
1398 {
1399 errorArgument("Invalid host floppy drive name \"%s\"", floppy + 5);
1400 rc = E_FAIL;
1401 break;
1402 }
1403 }
1404 else
1405 {
1406 /* first assume it's a UUID */
1407 Bstr uuid(floppy);
1408 rc = a->virtualBox->GetFloppyImage(uuid, floppyMedium.asOutParam());
1409 if (FAILED(rc) || !floppyMedium)
1410 {
1411 /* must be a filename, check if it's in the collection */
1412 rc = a->virtualBox->FindFloppyImage(Bstr(floppy), floppyMedium.asOutParam());
1413 /* not registered, do that on the fly */
1414 if (!floppyMedium)
1415 {
1416 Bstr emptyUUID;
1417 CHECK_ERROR(a->virtualBox, OpenFloppyImage(Bstr(floppy), emptyUUID, floppyMedium.asOutParam()));
1418 }
1419 }
1420 if (!floppyMedium)
1421 {
1422 rc = E_FAIL;
1423 break;
1424 }
1425 }
1426 floppyMedium->COMGETTER(Id)(uuid.asOutParam());
1427 CHECK_ERROR(machine, MountMedium(Bstr("Floppy Controller"), 0, 0, uuid));
1428 }
1429 }
1430 if (audio || audiocontroller)
1431 {
1432 ComPtr<IAudioAdapter> audioAdapter;
1433 machine->COMGETTER(AudioAdapter)(audioAdapter.asOutParam());
1434 ASSERT(audioAdapter);
1435
1436 if (audio)
1437 {
1438 /* disable? */
1439 if (!strcmp(audio, "none"))
1440 {
1441 CHECK_ERROR(audioAdapter, COMSETTER(Enabled)(false));
1442 }
1443 else if (!strcmp(audio, "null"))
1444 {
1445 CHECK_ERROR(audioAdapter, COMSETTER(AudioDriver)(AudioDriverType_Null));
1446 CHECK_ERROR(audioAdapter, COMSETTER(Enabled)(true));
1447 }
1448#ifdef RT_OS_WINDOWS
1449#ifdef VBOX_WITH_WINMM
1450 else if (!strcmp(audio, "winmm"))
1451 {
1452 CHECK_ERROR(audioAdapter, COMSETTER(AudioDriver)(AudioDriverType_WinMM));
1453 CHECK_ERROR(audioAdapter, COMSETTER(Enabled)(true));
1454 }
1455#endif
1456 else if (!strcmp(audio, "dsound"))
1457 {
1458 CHECK_ERROR(audioAdapter, COMSETTER(AudioDriver)(AudioDriverType_DirectSound));
1459 CHECK_ERROR(audioAdapter, COMSETTER(Enabled)(true));
1460 }
1461#endif /* RT_OS_WINDOWS */
1462#ifdef RT_OS_LINUX
1463 else if (!strcmp(audio, "oss"))
1464 {
1465 CHECK_ERROR(audioAdapter, COMSETTER(AudioDriver)(AudioDriverType_OSS));
1466 CHECK_ERROR(audioAdapter, COMSETTER(Enabled)(true));
1467 }
1468# ifdef VBOX_WITH_ALSA
1469 else if (!strcmp(audio, "alsa"))
1470 {
1471 CHECK_ERROR(audioAdapter, COMSETTER(AudioDriver)(AudioDriverType_ALSA));
1472 CHECK_ERROR(audioAdapter, COMSETTER(Enabled)(true));
1473 }
1474# endif
1475# ifdef VBOX_WITH_PULSE
1476 else if (!strcmp(audio, "pulse"))
1477 {
1478 CHECK_ERROR(audioAdapter, COMSETTER(AudioDriver)(AudioDriverType_Pulse));
1479 CHECK_ERROR(audioAdapter, COMSETTER(Enabled)(true));
1480 }
1481# endif
1482#endif /* !RT_OS_LINUX */
1483#ifdef RT_OS_SOLARIS
1484 else if (!strcmp(audio, "solaudio"))
1485 {
1486 CHECK_ERROR(audioAdapter, COMSETTER(AudioDriver)(AudioDriverType_SolAudio));
1487 CHECK_ERROR(audioAdapter, COMSETTER(Enabled)(true));
1488 }
1489
1490# ifdef VBOX_WITH_SOLARIS_OSS
1491 else if (!strcmp(audio, "oss"))
1492 {
1493 CHECK_ERROR(audioAdapter, COMSETTER(AudioDriver)(AudioDriverType_OSS));
1494 CHECK_ERROR(audioAdapter, COMSETTER(Enabled)(true));
1495 }
1496# endif
1497
1498#endif /* !RT_OS_SOLARIS */
1499#ifdef RT_OS_DARWIN
1500 else if (!strcmp(audio, "coreaudio"))
1501 {
1502 CHECK_ERROR(audioAdapter, COMSETTER(AudioDriver)(AudioDriverType_CoreAudio));
1503 CHECK_ERROR(audioAdapter, COMSETTER(Enabled)(true));
1504 }
1505
1506#endif /* !RT_OS_DARWIN */
1507 else
1508 {
1509 errorArgument("Invalid --audio argument '%s'", audio);
1510 rc = E_FAIL;
1511 break;
1512 }
1513 }
1514 if (audiocontroller)
1515 {
1516 if (!strcmp(audiocontroller, "sb16"))
1517 CHECK_ERROR(audioAdapter, COMSETTER(AudioController)(AudioControllerType_SB16));
1518 else if (!strcmp(audiocontroller, "ac97"))
1519 CHECK_ERROR(audioAdapter, COMSETTER(AudioController)(AudioControllerType_AC97));
1520 else
1521 {
1522 errorArgument("Invalid --audiocontroller argument '%s'", audiocontroller);
1523 rc = E_FAIL;
1524 break;
1525 }
1526 }
1527 }
1528 /* Shared clipboard state */
1529 if (clipboard)
1530 {
1531/* ComPtr<IClipboardMode> clipboardMode;
1532 machine->COMGETTER(ClipboardMode)(clipboardMode.asOutParam());
1533 ASSERT(clipboardMode);
1534*/
1535 if (!strcmp(clipboard, "disabled"))
1536 {
1537 CHECK_ERROR(machine, COMSETTER(ClipboardMode)(ClipboardMode_Disabled));
1538 }
1539 else if (!strcmp(clipboard, "hosttoguest"))
1540 {
1541 CHECK_ERROR(machine, COMSETTER(ClipboardMode)(ClipboardMode_HostToGuest));
1542 }
1543 else if (!strcmp(clipboard, "guesttohost"))
1544 {
1545 CHECK_ERROR(machine, COMSETTER(ClipboardMode)(ClipboardMode_GuestToHost));
1546 }
1547 else if (!strcmp(clipboard, "bidirectional"))
1548 {
1549 CHECK_ERROR(machine, COMSETTER(ClipboardMode)(ClipboardMode_Bidirectional));
1550 }
1551 else
1552 {
1553 errorArgument("Invalid --clipboard argument '%s'", clipboard);
1554 rc = E_FAIL;
1555 break;
1556 }
1557 }
1558 /* iterate through all possible NICs */
1559 for (ULONG n = 0; n < NetworkAdapterCount; n ++)
1560 {
1561 ComPtr<INetworkAdapter> nic;
1562 CHECK_ERROR_RET (machine, GetNetworkAdapter (n, nic.asOutParam()), 1);
1563
1564 ASSERT(nic);
1565
1566 /* something about the NIC? */
1567 if (nics[n])
1568 {
1569 if (!strcmp(nics[n], "none"))
1570 {
1571 CHECK_ERROR_RET(nic, COMSETTER(Enabled) (FALSE), 1);
1572 }
1573 else if (!strcmp(nics[n], "null"))
1574 {
1575 CHECK_ERROR_RET(nic, COMSETTER(Enabled) (TRUE), 1);
1576 CHECK_ERROR_RET(nic, Detach(), 1);
1577 }
1578 else if (!strcmp(nics[n], "nat"))
1579 {
1580 CHECK_ERROR_RET(nic, COMSETTER(Enabled) (TRUE), 1);
1581 CHECK_ERROR_RET(nic, AttachToNAT(), 1);
1582 }
1583 else if ( !strcmp(nics[n], "bridged")
1584 || !strcmp(nics[n], "hostif")) /* backward compatibility */
1585 {
1586 CHECK_ERROR_RET(nic, COMSETTER(Enabled) (TRUE), 1);
1587 CHECK_ERROR_RET(nic, AttachToBridgedInterface(), 1);
1588 }
1589 else if (!strcmp(nics[n], "intnet"))
1590 {
1591 CHECK_ERROR_RET(nic, COMSETTER(Enabled) (TRUE), 1);
1592 CHECK_ERROR_RET(nic, AttachToInternalNetwork(), 1);
1593 }
1594#if defined(VBOX_WITH_NETFLT)
1595 else if (!strcmp(nics[n], "hostonly"))
1596 {
1597
1598 CHECK_ERROR_RET(nic, COMSETTER(Enabled) (TRUE), 1);
1599 CHECK_ERROR_RET(nic, AttachToHostOnlyInterface(), 1);
1600 }
1601#endif
1602 else
1603 {
1604 errorArgument("Invalid type '%s' specfied for NIC %lu", nics[n], n + 1);
1605 rc = E_FAIL;
1606 break;
1607 }
1608 }
1609
1610 /* something about the NIC type? */
1611 if (nictype[n])
1612 {
1613 if (!strcmp(nictype[n], "Am79C970A"))
1614 {
1615 CHECK_ERROR_RET(nic, COMSETTER(AdapterType)(NetworkAdapterType_Am79C970A), 1);
1616 }
1617 else if (!strcmp(nictype[n], "Am79C973"))
1618 {
1619 CHECK_ERROR_RET(nic, COMSETTER(AdapterType)(NetworkAdapterType_Am79C973), 1);
1620 }
1621#ifdef VBOX_WITH_E1000
1622 else if (!strcmp(nictype[n], "82540EM"))
1623 {
1624 CHECK_ERROR_RET(nic, COMSETTER(AdapterType)(NetworkAdapterType_I82540EM), 1);
1625 }
1626 else if (!strcmp(nictype[n], "82543GC"))
1627 {
1628 CHECK_ERROR_RET(nic, COMSETTER(AdapterType)(NetworkAdapterType_I82543GC), 1);
1629 }
1630 else if (!strcmp(nictype[n], "82545EM"))
1631 {
1632 CHECK_ERROR_RET(nic, COMSETTER(AdapterType)(NetworkAdapterType_I82545EM), 1);
1633 }
1634#endif
1635#ifdef VBOX_WITH_VIRTIO
1636 else if (!strcmp(nictype[n], "virtio"))
1637 {
1638 CHECK_ERROR_RET(nic, COMSETTER(AdapterType)(NetworkAdapterType_Virtio), 1);
1639 }
1640#endif /* VBOX_WITH_VIRTIO */
1641 else
1642 {
1643 errorArgument("Invalid NIC type '%s' specified for NIC %lu", nictype[n], n + 1);
1644 rc = E_FAIL;
1645 break;
1646 }
1647 }
1648
1649 /* something about the MAC address? */
1650 if (macs[n])
1651 {
1652 /* generate one? */
1653 if (!strcmp(macs[n], "auto"))
1654 {
1655 CHECK_ERROR_RET(nic, COMSETTER(MACAddress)(NULL), 1);
1656 }
1657 else
1658 {
1659 CHECK_ERROR_RET(nic, COMSETTER(MACAddress)(Bstr(macs[n])), 1);
1660 }
1661 }
1662
1663 /* something about the reported link speed? */
1664 if (nicspeed[n])
1665 {
1666 uint32_t u32LineSpeed;
1667
1668 u32LineSpeed = RTStrToUInt32(nicspeed[n]);
1669
1670 if (u32LineSpeed < 1000 || u32LineSpeed > 4000000)
1671 {
1672 errorArgument("Invalid --nicspeed%lu argument '%s'", n + 1, nicspeed[n]);
1673 rc = E_FAIL;
1674 break;
1675 }
1676 CHECK_ERROR_RET(nic, COMSETTER(LineSpeed)(u32LineSpeed), 1);
1677 }
1678
1679 /* the link status flag? */
1680 if (cableconnected[n])
1681 {
1682 if (!strcmp(cableconnected[n], "on"))
1683 {
1684 CHECK_ERROR_RET(nic, COMSETTER(CableConnected)(TRUE), 1);
1685 }
1686 else if (!strcmp(cableconnected[n], "off"))
1687 {
1688 CHECK_ERROR_RET(nic, COMSETTER(CableConnected)(FALSE), 1);
1689 }
1690 else
1691 {
1692 errorArgument("Invalid --cableconnected%lu argument '%s'", n + 1, cableconnected[n]);
1693 rc = E_FAIL;
1694 break;
1695 }
1696 }
1697
1698 /* the trace flag? */
1699 if (nictrace[n])
1700 {
1701 if (!strcmp(nictrace[n], "on"))
1702 {
1703 CHECK_ERROR_RET(nic, COMSETTER(TraceEnabled)(TRUE), 1);
1704 }
1705 else if (!strcmp(nictrace[n], "off"))
1706 {
1707 CHECK_ERROR_RET(nic, COMSETTER(TraceEnabled)(FALSE), 1);
1708 }
1709 else
1710 {
1711 errorArgument("Invalid --nictrace%lu argument '%s'", n + 1, nictrace[n]);
1712 rc = E_FAIL;
1713 break;
1714 }
1715 }
1716
1717 /* the tracefile flag? */
1718 if (nictracefile[n])
1719 {
1720 CHECK_ERROR_RET(nic, COMSETTER(TraceFile)(Bstr(nictracefile[n])), 1);
1721 }
1722
1723 /* the host interface device? */
1724 if (hostifdev[n])
1725 {
1726 /* remove it? */
1727 if (!strcmp(hostifdev[n], "none"))
1728 {
1729 CHECK_ERROR_RET(nic, COMSETTER(HostInterface)(NULL), 1);
1730 }
1731 else
1732 {
1733 CHECK_ERROR_RET(nic, COMSETTER(HostInterface)(Bstr(hostifdev[n])), 1);
1734 }
1735 }
1736
1737 /* the internal network name? */
1738 if (intnet[n])
1739 {
1740 /* remove it? */
1741 if (!strcmp(intnet[n], "none"))
1742 {
1743 CHECK_ERROR_RET(nic, COMSETTER(InternalNetwork)(NULL), 1);
1744 }
1745 else
1746 {
1747 CHECK_ERROR_RET(nic, COMSETTER(InternalNetwork)(Bstr(intnet[n])), 1);
1748 }
1749 }
1750 /* the network of the NAT */
1751 if (natnet[n])
1752 {
1753 CHECK_ERROR_RET(nic, COMSETTER(NATNetwork)(Bstr(natnet[n])), 1);
1754 }
1755 }
1756 if (FAILED(rc))
1757 break;
1758
1759 /* iterate through all possible serial ports */
1760 for (ULONG n = 0; n < SerialPortCount; n ++)
1761 {
1762 ComPtr<ISerialPort> uart;
1763 CHECK_ERROR_RET (machine, GetSerialPort (n, uart.asOutParam()), 1);
1764
1765 ASSERT(uart);
1766
1767 if (uarts_base[n])
1768 {
1769 if (uarts_base[n] == (ULONG)-1)
1770 {
1771 CHECK_ERROR_RET(uart, COMSETTER(Enabled) (FALSE), 1);
1772 }
1773 else
1774 {
1775 CHECK_ERROR_RET(uart, COMSETTER(IOBase) (uarts_base[n]), 1);
1776 CHECK_ERROR_RET(uart, COMSETTER(IRQ) (uarts_irq[n]), 1);
1777 CHECK_ERROR_RET(uart, COMSETTER(Enabled) (TRUE), 1);
1778 }
1779 }
1780 if (uarts_mode[n])
1781 {
1782 if (!strcmp(uarts_mode[n], "disconnected"))
1783 {
1784 CHECK_ERROR_RET(uart, COMSETTER(HostMode) (PortMode_Disconnected), 1);
1785 }
1786 else
1787 {
1788 CHECK_ERROR_RET(uart, COMSETTER(Path) (Bstr(uarts_path[n])), 1);
1789 if (!strcmp(uarts_mode[n], "server"))
1790 {
1791 CHECK_ERROR_RET(uart, COMSETTER(HostMode) (PortMode_HostPipe), 1);
1792 CHECK_ERROR_RET(uart, COMSETTER(Server) (TRUE), 1);
1793 }
1794 else if (!strcmp(uarts_mode[n], "client"))
1795 {
1796 CHECK_ERROR_RET(uart, COMSETTER(HostMode) (PortMode_HostPipe), 1);
1797 CHECK_ERROR_RET(uart, COMSETTER(Server) (FALSE), 1);
1798 }
1799 else if (!strcmp(uarts_mode[n], "file"))
1800 {
1801 CHECK_ERROR_RET(uart, COMSETTER(HostMode) (PortMode_RawFile), 1);
1802 }
1803 else
1804 {
1805 CHECK_ERROR_RET(uart, COMSETTER(HostMode) (PortMode_HostDevice), 1);
1806 }
1807 }
1808 }
1809 }
1810 if (FAILED(rc))
1811 break;
1812
1813#ifdef VBOX_WITH_VRDP
1814 if (vrdp || (vrdpport != UINT16_MAX) || vrdpaddress || vrdpauthtype || vrdpmulticon || vrdpreusecon)
1815 {
1816 ComPtr<IVRDPServer> vrdpServer;
1817 machine->COMGETTER(VRDPServer)(vrdpServer.asOutParam());
1818 ASSERT(vrdpServer);
1819 if (vrdpServer)
1820 {
1821 if (vrdp)
1822 {
1823 if (!strcmp(vrdp, "on"))
1824 {
1825 CHECK_ERROR(vrdpServer, COMSETTER(Enabled)(true));
1826 }
1827 else if (!strcmp(vrdp, "off"))
1828 {
1829 CHECK_ERROR(vrdpServer, COMSETTER(Enabled)(false));
1830 }
1831 else
1832 {
1833 errorArgument("Invalid --vrdp argument '%s'", vrdp);
1834 rc = E_FAIL;
1835 break;
1836 }
1837 }
1838 if (vrdpport != UINT16_MAX)
1839 {
1840 CHECK_ERROR(vrdpServer, COMSETTER(Port)(vrdpport));
1841 }
1842 if (vrdpaddress)
1843 {
1844 CHECK_ERROR(vrdpServer, COMSETTER(NetAddress)(Bstr(vrdpaddress)));
1845 }
1846 if (vrdpauthtype)
1847 {
1848 if (!strcmp(vrdpauthtype, "null"))
1849 {
1850 CHECK_ERROR(vrdpServer, COMSETTER(AuthType)(VRDPAuthType_Null));
1851 }
1852 else if (!strcmp(vrdpauthtype, "external"))
1853 {
1854 CHECK_ERROR(vrdpServer, COMSETTER(AuthType)(VRDPAuthType_External));
1855 }
1856 else if (!strcmp(vrdpauthtype, "guest"))
1857 {
1858 CHECK_ERROR(vrdpServer, COMSETTER(AuthType)(VRDPAuthType_Guest));
1859 }
1860 else
1861 {
1862 errorArgument("Invalid --vrdpauthtype argument '%s'", vrdpauthtype);
1863 rc = E_FAIL;
1864 break;
1865 }
1866 }
1867 if (vrdpmulticon)
1868 {
1869 if (!strcmp(vrdpmulticon, "on"))
1870 {
1871 CHECK_ERROR(vrdpServer, COMSETTER(AllowMultiConnection)(true));
1872 }
1873 else if (!strcmp(vrdpmulticon, "off"))
1874 {
1875 CHECK_ERROR(vrdpServer, COMSETTER(AllowMultiConnection)(false));
1876 }
1877 else
1878 {
1879 errorArgument("Invalid --vrdpmulticon argument '%s'", vrdpmulticon);
1880 rc = E_FAIL;
1881 break;
1882 }
1883 }
1884 if (vrdpreusecon)
1885 {
1886 if (!strcmp(vrdpreusecon, "on"))
1887 {
1888 CHECK_ERROR(vrdpServer, COMSETTER(ReuseSingleConnection)(true));
1889 }
1890 else if (!strcmp(vrdpreusecon, "off"))
1891 {
1892 CHECK_ERROR(vrdpServer, COMSETTER(ReuseSingleConnection)(false));
1893 }
1894 else
1895 {
1896 errorArgument("Invalid --vrdpreusecon argument '%s'", vrdpreusecon);
1897 rc = E_FAIL;
1898 break;
1899 }
1900 }
1901 }
1902 }
1903#endif /* VBOX_WITH_VRDP */
1904
1905 /*
1906 * USB enable/disable
1907 */
1908 if (fUsbEnabled != -1)
1909 {
1910 ComPtr<IUSBController> UsbCtl;
1911 CHECK_ERROR(machine, COMGETTER(USBController)(UsbCtl.asOutParam()));
1912 if (SUCCEEDED(rc))
1913 {
1914 CHECK_ERROR(UsbCtl, COMSETTER(Enabled)(!!fUsbEnabled));
1915 }
1916 }
1917 /*
1918 * USB EHCI enable/disable
1919 */
1920 if (fUsbEhciEnabled != -1)
1921 {
1922 ComPtr<IUSBController> UsbCtl;
1923 CHECK_ERROR(machine, COMGETTER(USBController)(UsbCtl.asOutParam()));
1924 if (SUCCEEDED(rc))
1925 {
1926 CHECK_ERROR(UsbCtl, COMSETTER(EnabledEhci)(!!fUsbEhciEnabled));
1927 }
1928 }
1929
1930 if (snapshotFolder)
1931 {
1932 if (!strcmp(snapshotFolder, "default"))
1933 {
1934 CHECK_ERROR(machine, COMSETTER(SnapshotFolder)(NULL));
1935 }
1936 else
1937 {
1938 CHECK_ERROR(machine, COMSETTER(SnapshotFolder)(Bstr(snapshotFolder)));
1939 }
1940 }
1941
1942 if (guestMemBalloonSize != (ULONG)-1)
1943 CHECK_ERROR(machine, COMSETTER(MemoryBalloonSize)(guestMemBalloonSize));
1944
1945 if (guestStatInterval != (ULONG)-1)
1946 CHECK_ERROR(machine, COMSETTER(StatisticsUpdateInterval)(guestStatInterval));
1947
1948 /*
1949 * SATA controller enable/disable
1950 */
1951 if (fSataEnabled != -1)
1952 {
1953 if (fSataEnabled)
1954 {
1955 ComPtr<IStorageController> ctl;
1956 CHECK_ERROR(machine, AddStorageController(Bstr("SATA"), StorageBus_SATA, ctl.asOutParam()));
1957 CHECK_ERROR(ctl, COMSETTER(ControllerType)(StorageControllerType_IntelAhci));
1958 }
1959 else
1960 CHECK_ERROR(machine, RemoveStorageController(Bstr("SATA")));
1961 }
1962
1963 for (uint32_t i = 4; i < 34; i++)
1964 {
1965 if (hdds[i])
1966 {
1967 if (!strcmp(hdds[i], "none"))
1968 {
1969 machine->DetachDevice(Bstr("SATA"), i-4, 0);
1970 }
1971 else
1972 {
1973 /* first guess is that it's a UUID */
1974 Bstr uuid(hdds[i]);
1975 ComPtr<IMedium> hardDisk;
1976 rc = a->virtualBox->GetHardDisk(uuid, hardDisk.asOutParam());
1977 /* not successful? Then it must be a filename */
1978 if (!hardDisk)
1979 {
1980 rc = a->virtualBox->FindHardDisk(Bstr(hdds[i]), hardDisk.asOutParam());
1981 if (FAILED(rc))
1982 {
1983 /* open the new hard disk object */
1984 CHECK_ERROR(a->virtualBox, OpenHardDisk(Bstr(hdds[i]), AccessMode_ReadWrite, false, Bstr(""), false, Bstr(""), hardDisk.asOutParam()));
1985 }
1986 }
1987 if (hardDisk)
1988 {
1989 hardDisk->COMGETTER(Id)(uuid.asOutParam());
1990 CHECK_ERROR(machine, AttachDevice(Bstr("SATA"), i-4, 0, DeviceType_HardDisk, uuid));
1991 }
1992 else
1993 rc = E_FAIL;
1994 if (FAILED(rc))
1995 break;
1996 }
1997 }
1998 }
1999
2000 for (uint32_t i = 0; i < 4; i++)
2001 {
2002 if (sataBootDevices[i] != -1)
2003 {
2004 ComPtr<IStorageController> SataCtl;
2005 CHECK_ERROR(machine, GetStorageControllerByName(Bstr("SATA"), SataCtl.asOutParam()));
2006 if (SUCCEEDED(rc))
2007 {
2008 CHECK_ERROR(SataCtl, SetIDEEmulationPort(i, sataBootDevices[i]));
2009 }
2010 }
2011 }
2012
2013 if (sataPortCount != -1)
2014 {
2015 ComPtr<IStorageController> SataCtl;
2016 CHECK_ERROR(machine, GetStorageControllerByName(Bstr("SATA"), SataCtl.asOutParam()));
2017 if (SUCCEEDED(rc))
2018 {
2019 CHECK_ERROR(SataCtl, COMSETTER(PortCount)(sataPortCount));
2020 }
2021 }
2022
2023 /*
2024 * SCSI controller enable/disable
2025 */
2026 if (fScsiEnabled != -1)
2027 {
2028 if (fScsiEnabled)
2029 {
2030 ComPtr<IStorageController> ctl;
2031 if (!fScsiLsiLogic)
2032 {
2033 CHECK_ERROR(machine, AddStorageController(Bstr("BusLogic"), StorageBus_SCSI, ctl.asOutParam()));
2034 CHECK_ERROR(ctl, COMSETTER(ControllerType)(StorageControllerType_BusLogic));
2035 }
2036 else /* LsiLogic is default */
2037 {
2038 CHECK_ERROR(machine, AddStorageController(Bstr("LsiLogic"), StorageBus_SCSI, ctl.asOutParam()));
2039 CHECK_ERROR(ctl, COMSETTER(ControllerType)(StorageControllerType_LsiLogic));
2040 }
2041 }
2042 else
2043 {
2044 rc = machine->RemoveStorageController(Bstr("LsiLogic"));
2045 if (!SUCCEEDED(rc))
2046 CHECK_ERROR(machine, RemoveStorageController(Bstr("BusLogic")));
2047 }
2048 }
2049
2050 for (uint32_t i = 34; i < 50; i++)
2051 {
2052 if (hdds[i])
2053 {
2054 if (!strcmp(hdds[i], "none"))
2055 {
2056 rc = machine->DetachDevice(Bstr("LsiLogic"), i-34, 0);
2057 if (!SUCCEEDED(rc))
2058 CHECK_ERROR(machine, DetachDevice(Bstr("BusLogic"), i-34, 0));
2059 }
2060 else
2061 {
2062 /* first guess is that it's a UUID */
2063 Bstr uuid(hdds[i]);
2064 ComPtr<IMedium> hardDisk;
2065 rc = a->virtualBox->GetHardDisk(uuid, hardDisk.asOutParam());
2066 /* not successful? Then it must be a filename */
2067 if (!hardDisk)
2068 {
2069 rc = a->virtualBox->FindHardDisk(Bstr(hdds[i]), hardDisk.asOutParam());
2070 if (FAILED(rc))
2071 {
2072 /* open the new hard disk object */
2073 CHECK_ERROR(a->virtualBox, OpenHardDisk(Bstr(hdds[i]), AccessMode_ReadWrite, false, Bstr(""), false, Bstr(""), hardDisk.asOutParam()));
2074 }
2075 }
2076 if (hardDisk)
2077 {
2078 hardDisk->COMGETTER(Id)(uuid.asOutParam());
2079 rc = machine->AttachDevice(Bstr("LsiLogic"), i-34, 0, DeviceType_HardDisk, uuid);
2080 if (!SUCCEEDED(rc))
2081 CHECK_ERROR(machine, AttachDevice(Bstr("BusLogic"), i-34, 0, DeviceType_HardDisk, uuid));
2082 }
2083 else
2084 rc = E_FAIL;
2085 if (FAILED(rc))
2086 break;
2087 }
2088 }
2089 }
2090
2091 /* commit changes */
2092 CHECK_ERROR(machine, SaveSettings());
2093 }
2094 while (0);
2095
2096 /* it's important to always close sessions */
2097 a->session->Close();
2098
2099 return SUCCEEDED(rc) ? 0 : 1;
2100}
2101
2102#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