VirtualBox

source: vbox/trunk/src/VBox/Frontends/VBoxManage/VBoxManageInfo.cpp@ 27452

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

VBoxManageInfo: consmetics

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 83.2 KB
Line 
1/* $Id: VBoxManageInfo.cpp 27255 2010-03-10 15:40:24Z vboxsync $ */
2/** @file
3 * VBoxManage - The 'showvminfo' command and helper routines.
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#ifndef VBOX_ONLY_DOCS
23
24/*******************************************************************************
25* Header Files *
26*******************************************************************************/
27#include <VBox/com/com.h>
28#include <VBox/com/string.h>
29#include <VBox/com/Guid.h>
30#include <VBox/com/array.h>
31#include <VBox/com/ErrorInfo.h>
32#include <VBox/com/errorprint.h>
33
34#include <VBox/com/VirtualBox.h>
35
36#include <VBox/log.h>
37#include <iprt/stream.h>
38#include <iprt/time.h>
39#include <iprt/string.h>
40#include <iprt/getopt.h>
41#include <iprt/ctype.h>
42
43#include "VBoxManage.h"
44using namespace com;
45
46
47// funcs
48///////////////////////////////////////////////////////////////////////////////
49
50void showSnapshots(ComPtr<ISnapshot> &rootSnapshot,
51 ComPtr<ISnapshot> &currentSnapshot,
52 VMINFO_DETAILS details,
53 const Bstr &prefix /* = ""*/,
54 int level /*= 0*/)
55{
56 /* start with the root */
57 Bstr name;
58 Bstr uuid;
59 rootSnapshot->COMGETTER(Name)(name.asOutParam());
60 rootSnapshot->COMGETTER(Id)(uuid.asOutParam());
61 if (details == VMINFO_MACHINEREADABLE)
62 {
63 /* print with hierarchical numbering */
64 RTPrintf("SnapshotName%lS=\"%lS\"\n", prefix.raw(), name.raw());
65 RTPrintf("SnapshotUUID%lS=\"%s\"\n", prefix.raw(), Utf8Str(uuid).raw());
66 }
67 else
68 {
69 /* print with indentation */
70 bool fCurrent = (rootSnapshot == currentSnapshot);
71 RTPrintf(" %lSName: %lS (UUID: %s)%s\n",
72 prefix.raw(),
73 name.raw(),
74 Utf8Str(uuid).raw(),
75 (fCurrent) ? " *" : "");
76 }
77
78 /* get the children */
79 SafeIfaceArray <ISnapshot> coll;
80 rootSnapshot->COMGETTER(Children)(ComSafeArrayAsOutParam(coll));
81 if (!coll.isNull())
82 {
83 for (size_t index = 0; index < coll.size(); ++index)
84 {
85 ComPtr<ISnapshot> snapshot = coll[index];
86 if (snapshot)
87 {
88 Bstr newPrefix;
89 if (details == VMINFO_MACHINEREADABLE)
90 newPrefix = Utf8StrFmt("%lS-%d", prefix.raw(), index + 1);
91 else
92 {
93 newPrefix = Utf8StrFmt("%lS ", prefix.raw());
94 }
95
96 /* recursive call */
97 showSnapshots(snapshot, currentSnapshot, details, newPrefix, level + 1);
98 }
99 }
100 }
101}
102
103static void makeTimeStr (char *s, int cb, int64_t millies)
104{
105 RTTIME t;
106 RTTIMESPEC ts;
107
108 RTTimeSpecSetMilli(&ts, millies);
109
110 RTTimeExplode (&t, &ts);
111
112 RTStrPrintf(s, cb, "%04d/%02d/%02d %02d:%02d:%02d UTC",
113 t.i32Year, t.u8Month, t.u8MonthDay,
114 t.u8Hour, t.u8Minute, t.u8Second);
115}
116
117/* Disable global optimizations for MSC 8.0/64 to make it compile in reasonable
118 time. MSC 7.1/32 doesn't have quite as much trouble with it, but still
119 sufficient to qualify for this hack as well since this code isn't performance
120 critical and probably won't gain much from the extra optimizing in real life. */
121#if defined(_MSC_VER)
122# pragma optimize("g", off)
123#endif
124
125HRESULT showVMInfo (ComPtr<IVirtualBox> virtualBox,
126 ComPtr<IMachine> machine,
127 VMINFO_DETAILS details /*= VMINFO_NONE*/,
128 ComPtr<IConsole> console /*= ComPtr <IConsole> ()*/)
129{
130 HRESULT rc;
131
132 /*
133 * The rules for output in -argdump format:
134 * 1) the key part (the [0-9a-zA-Z_]+ string before the '=' delimiter)
135 * is all lowercase for "VBoxManage modifyvm" parameters. Any
136 * other values printed are in CamelCase.
137 * 2) strings (anything non-decimal) are printed surrounded by
138 * double quotes '"'. If the strings themselves contain double
139 * quotes, these characters are escaped by '\'. Any '\' character
140 * in the original string is also escaped by '\'.
141 * 3) numbers (containing just [0-9\-]) are written out unchanged.
142 */
143
144 /** @todo the quoting is not yet implemented! */
145 /** @todo error checking! */
146
147 BOOL accessible = FALSE;
148 CHECK_ERROR(machine, COMGETTER(Accessible)(&accessible));
149 if (FAILED(rc)) return rc;
150
151 Bstr uuid;
152 rc = machine->COMGETTER(Id)(uuid.asOutParam());
153
154 if (!accessible)
155 {
156 if (details == VMINFO_COMPACT)
157 RTPrintf("\"<inaccessible>\" {%s}\n", Utf8Str(uuid).raw());
158 else
159 {
160 if (details == VMINFO_MACHINEREADABLE)
161 RTPrintf("name=\"<inaccessible>\"\n");
162 else
163 RTPrintf("Name: <inaccessible!>\n");
164 if (details == VMINFO_MACHINEREADABLE)
165 RTPrintf("UUID=\"%s\"\n", Utf8Str(uuid).raw());
166 else
167 RTPrintf("UUID: %s\n", Utf8Str(uuid).raw());
168 if (details != VMINFO_MACHINEREADABLE)
169 {
170 Bstr settingsFilePath;
171 rc = machine->COMGETTER(SettingsFilePath)(settingsFilePath.asOutParam());
172 RTPrintf("Config file: %lS\n", settingsFilePath.raw());
173 ComPtr<IVirtualBoxErrorInfo> accessError;
174 rc = machine->COMGETTER(AccessError)(accessError.asOutParam());
175 RTPrintf("Access error details:\n");
176 ErrorInfo ei(accessError);
177 GluePrintErrorInfo(ei);
178 RTPrintf("\n");
179 }
180 }
181 return S_OK;
182 }
183
184 Bstr machineName;
185 rc = machine->COMGETTER(Name)(machineName.asOutParam());
186
187 if (details == VMINFO_COMPACT)
188 {
189 RTPrintf("\"%lS\" {%s}\n", machineName.raw(), Utf8Str(uuid).raw());
190 return S_OK;
191 }
192
193 if (details == VMINFO_MACHINEREADABLE)
194 RTPrintf("name=\"%lS\"\n", machineName.raw());
195 else
196 RTPrintf("Name: %lS\n", machineName.raw());
197
198 Bstr osTypeId;
199 rc = machine->COMGETTER(OSTypeId)(osTypeId.asOutParam());
200 ComPtr<IGuestOSType> osType;
201 rc = virtualBox->GetGuestOSType (osTypeId, osType.asOutParam());
202 Bstr osName;
203 rc = osType->COMGETTER(Description)(osName.asOutParam());
204 if (details == VMINFO_MACHINEREADABLE)
205 RTPrintf("ostype=\"%lS\"\n", osTypeId.raw());
206 else
207 RTPrintf("Guest OS: %lS\n", osName.raw());
208
209 if (details == VMINFO_MACHINEREADABLE)
210 RTPrintf("UUID=\"%s\"\n", Utf8Str(uuid).raw());
211 else
212 RTPrintf("UUID: %s\n", Utf8Str(uuid).raw());
213
214 Bstr settingsFilePath;
215 rc = machine->COMGETTER(SettingsFilePath)(settingsFilePath.asOutParam());
216 if (details == VMINFO_MACHINEREADABLE)
217 RTPrintf("CfgFile=\"%lS\"\n", settingsFilePath.raw());
218 else
219 RTPrintf("Config file: %lS\n", settingsFilePath.raw());
220
221 Bstr strHardwareUuid;
222 rc = machine->COMGETTER(HardwareUUID)(strHardwareUuid.asOutParam());
223 if (details == VMINFO_MACHINEREADABLE)
224 RTPrintf("hardwareuuid=\"%lS\"\n", strHardwareUuid.raw());
225 else
226 RTPrintf("Hardware UUID: %lS\n", strHardwareUuid.raw());
227
228 ULONG memorySize;
229 rc = machine->COMGETTER(MemorySize)(&memorySize);
230 if (details == VMINFO_MACHINEREADABLE)
231 RTPrintf("memory=%u\n", memorySize);
232 else
233 RTPrintf("Memory size: %uMB\n", memorySize);
234
235 ULONG vramSize;
236 rc = machine->COMGETTER(VRAMSize)(&vramSize);
237 if (details == VMINFO_MACHINEREADABLE)
238 RTPrintf("vram=%u\n", vramSize);
239 else
240 RTPrintf("VRAM size: %uMB\n", vramSize);
241
242 BOOL fHpetEnabled;
243 machine->COMGETTER(HpetEnabled)(&fHpetEnabled);
244 if (details == VMINFO_MACHINEREADABLE)
245 RTPrintf("hpet=\"%s\"\n", fHpetEnabled ? "on" : "off");
246 else
247 RTPrintf("HPET: %s\n", fHpetEnabled ? "on" : "off");
248
249 ULONG numCpus;
250 rc = machine->COMGETTER(CPUCount)(&numCpus);
251 if (details == VMINFO_MACHINEREADABLE)
252 RTPrintf("cpus=%u\n", numCpus);
253 else
254 RTPrintf("Number of CPUs: %u\n", numCpus);
255
256 BOOL fSyntheticCpu;
257 machine->GetCpuProperty(CpuPropertyType_Synthetic, &fSyntheticCpu);
258 if (details == VMINFO_MACHINEREADABLE)
259 RTPrintf("synthcpu=\"%s\"\n", fSyntheticCpu ? "on" : "off");
260 else
261 RTPrintf("Synthetic Cpu: %s\n", fSyntheticCpu ? "on" : "off");
262
263 if (details != VMINFO_MACHINEREADABLE)
264 RTPrintf("CPUID overrides: ");
265 ULONG cFound = 0;
266 static uint32_t const s_auCpuIdRanges[] =
267 {
268 UINT32_C(0x00000000), UINT32_C(0x0000000a),
269 UINT32_C(0x80000000), UINT32_C(0x8000000a)
270 };
271 for (unsigned i = 0; i < RT_ELEMENTS(s_auCpuIdRanges); i += 2)
272 for (uint32_t uLeaf = s_auCpuIdRanges[i]; uLeaf < s_auCpuIdRanges[i + 1]; uLeaf++)
273 {
274 ULONG uEAX, uEBX, uECX, uEDX;
275 rc = machine->GetCpuIdLeaf(uLeaf, &uEAX, &uEBX, &uECX, &uEDX);
276 if (SUCCEEDED(rc))
277 {
278 if (details == VMINFO_MACHINEREADABLE)
279 RTPrintf("cpuid=%08x,%08x,%08x,%08x,%08x", uLeaf, uEAX, uEBX, uECX, uEDX);
280 else
281 {
282 if (!cFound)
283 RTPrintf("Leaf no. EAX EBX ECX EDX\n");
284 RTPrintf(" %08x %08x %08x %08x %08x\n", uLeaf, uEAX, uEBX, uECX, uEDX);
285 }
286 cFound++;
287 }
288 }
289 if (!cFound && details != VMINFO_MACHINEREADABLE)
290 RTPrintf("None\n");
291
292 ComPtr <IBIOSSettings> biosSettings;
293 machine->COMGETTER(BIOSSettings)(biosSettings.asOutParam());
294
295 BIOSBootMenuMode_T bootMenuMode;
296 biosSettings->COMGETTER(BootMenuMode)(&bootMenuMode);
297 const char *pszBootMenu = NULL;
298 switch (bootMenuMode)
299 {
300 case BIOSBootMenuMode_Disabled:
301 pszBootMenu = "disabled";
302 break;
303 case BIOSBootMenuMode_MenuOnly:
304 if (details == VMINFO_MACHINEREADABLE)
305 pszBootMenu = "menuonly";
306 else
307 pszBootMenu = "menu only";
308 break;
309 default:
310 if (details == VMINFO_MACHINEREADABLE)
311 pszBootMenu = "messageandmenu";
312 else
313 pszBootMenu = "message and menu";
314 }
315 if (details == VMINFO_MACHINEREADABLE)
316 RTPrintf("bootmenu=\"%s\"\n", pszBootMenu);
317 else
318 RTPrintf("Boot menu mode: %s\n", pszBootMenu);
319
320 ULONG maxBootPosition = 0;
321 ComPtr<ISystemProperties> systemProperties;
322 virtualBox->COMGETTER(SystemProperties)(systemProperties.asOutParam());
323 systemProperties->COMGETTER(MaxBootPosition)(&maxBootPosition);
324 for (ULONG i = 1; i <= maxBootPosition; i++)
325 {
326 DeviceType_T bootOrder;
327 machine->GetBootOrder(i, &bootOrder);
328 if (bootOrder == DeviceType_Floppy)
329 {
330 if (details == VMINFO_MACHINEREADABLE)
331 RTPrintf("boot%d=\"floppy\"\n", i);
332 else
333 RTPrintf("Boot Device (%d): Floppy\n", i);
334 }
335 else if (bootOrder == DeviceType_DVD)
336 {
337 if (details == VMINFO_MACHINEREADABLE)
338 RTPrintf("boot%d=\"dvd\"\n", i);
339 else
340 RTPrintf("Boot Device (%d): DVD\n", i);
341 }
342 else if (bootOrder == DeviceType_HardDisk)
343 {
344 if (details == VMINFO_MACHINEREADABLE)
345 RTPrintf("boot%d=\"disk\"\n", i);
346 else
347 RTPrintf("Boot Device (%d): HardDisk\n", i);
348 }
349 else if (bootOrder == DeviceType_Network)
350 {
351 if (details == VMINFO_MACHINEREADABLE)
352 RTPrintf("boot%d=\"net\"\n", i);
353 else
354 RTPrintf("Boot Device (%d): Network\n", i);
355 }
356 else if (bootOrder == DeviceType_USB)
357 {
358 if (details == VMINFO_MACHINEREADABLE)
359 RTPrintf("boot%d=\"usb\"\n", i);
360 else
361 RTPrintf("Boot Device (%d): USB\n", i);
362 }
363 else if (bootOrder == DeviceType_SharedFolder)
364 {
365 if (details == VMINFO_MACHINEREADABLE)
366 RTPrintf("boot%d=\"sharedfolder\"\n", i);
367 else
368 RTPrintf("Boot Device (%d): Shared Folder\n", i);
369 }
370 else
371 {
372 if (details == VMINFO_MACHINEREADABLE)
373 RTPrintf("boot%d=\"none\"\n", i);
374 else
375 RTPrintf("Boot Device (%d): Not Assigned\n", i);
376 }
377 }
378
379 BOOL acpiEnabled;
380 biosSettings->COMGETTER(ACPIEnabled)(&acpiEnabled);
381 if (details == VMINFO_MACHINEREADABLE)
382 RTPrintf("acpi=\"%s\"\n", acpiEnabled ? "on" : "off");
383 else
384 RTPrintf("ACPI: %s\n", acpiEnabled ? "on" : "off");
385
386 BOOL ioapicEnabled;
387 biosSettings->COMGETTER(IOAPICEnabled)(&ioapicEnabled);
388 if (details == VMINFO_MACHINEREADABLE)
389 RTPrintf("ioapic=\"%s\"\n", ioapicEnabled ? "on" : "off");
390 else
391 RTPrintf("IOAPIC: %s\n", ioapicEnabled ? "on" : "off");
392
393 BOOL PAEEnabled;
394 machine->GetCpuProperty(CpuPropertyType_PAE, &PAEEnabled);
395 if (details == VMINFO_MACHINEREADABLE)
396 RTPrintf("pae=\"%s\"\n", PAEEnabled ? "on" : "off");
397 else
398 RTPrintf("PAE: %s\n", PAEEnabled ? "on" : "off");
399
400 LONG64 timeOffset;
401 biosSettings->COMGETTER(TimeOffset)(&timeOffset);
402 if (details == VMINFO_MACHINEREADABLE)
403 RTPrintf("biossystemtimeoffset=%lld\n", timeOffset);
404 else
405 RTPrintf("Time offset: %lld ms\n", timeOffset);
406
407 BOOL RTCUseUTC;
408 machine->COMGETTER(RTCUseUTC)(&RTCUseUTC);
409 if (details == VMINFO_MACHINEREADABLE)
410 RTPrintf("rtcuseutc=\"%s\"\n", RTCUseUTC ? "on" : "off");
411 else
412 RTPrintf("RTC: %s\n", RTCUseUTC ? "UTC" : "local time");
413
414 BOOL hwVirtExEnabled;
415 machine->GetHWVirtExProperty(HWVirtExPropertyType_Enabled, &hwVirtExEnabled);
416 if (details == VMINFO_MACHINEREADABLE)
417 RTPrintf("hwvirtex=\"%s\"\n", hwVirtExEnabled ? "on" : "off");
418 else
419 RTPrintf("Hardw. virt.ext: %s\n", hwVirtExEnabled ? "on" : "off");
420
421 BOOL hwVirtExExclusive;
422 machine->GetHWVirtExProperty(HWVirtExPropertyType_Exclusive, &hwVirtExExclusive);
423 if (details == VMINFO_MACHINEREADABLE)
424 RTPrintf("hwvirtexexcl=\"%s\"\n", hwVirtExExclusive ? "on" : "off");
425 else
426 RTPrintf("Hardw. virt.ext exclusive: %s\n", hwVirtExExclusive ? "on" : "off");
427
428 BOOL HWVirtExNestedPagingEnabled;
429 machine->GetHWVirtExProperty(HWVirtExPropertyType_NestedPaging, &HWVirtExNestedPagingEnabled);
430 if (details == VMINFO_MACHINEREADABLE)
431 RTPrintf("nestedpaging=\"%s\"\n", HWVirtExNestedPagingEnabled ? "on" : "off");
432 else
433 RTPrintf("Nested Paging: %s\n", HWVirtExNestedPagingEnabled ? "on" : "off");
434
435 BOOL HWVirtExLargePagesEnabled;
436 machine->GetHWVirtExProperty(HWVirtExPropertyType_LargePages, &HWVirtExLargePagesEnabled);
437 if (details == VMINFO_MACHINEREADABLE)
438 RTPrintf("largepages=\"%s\"\n", HWVirtExLargePagesEnabled ? "on" : "off");
439 else
440 RTPrintf("Large Pages: %s\n", HWVirtExLargePagesEnabled ? "on" : "off");
441
442 BOOL HWVirtExVPIDEnabled;
443 machine->GetHWVirtExProperty(HWVirtExPropertyType_VPID, &HWVirtExVPIDEnabled);
444 if (details == VMINFO_MACHINEREADABLE)
445 RTPrintf("vtxvpid=\"%s\"\n", HWVirtExVPIDEnabled ? "on" : "off");
446 else
447 RTPrintf("VT-x VPID: %s\n", HWVirtExVPIDEnabled ? "on" : "off");
448
449 MachineState_T machineState;
450 const char *pszState = NULL;
451 rc = machine->COMGETTER(State)(&machineState);
452 switch (machineState)
453 {
454 case MachineState_PoweredOff:
455 pszState = details == VMINFO_MACHINEREADABLE ? "poweroff" : "powered off";
456 break;
457 case MachineState_Saved:
458 pszState = "saved";
459 break;
460 case MachineState_Aborted:
461 pszState = "aborted";
462 break;
463 case MachineState_Teleported:
464 pszState = "teleported";
465 break;
466 case MachineState_Running:
467 pszState = "running";
468 break;
469 case MachineState_Paused:
470 pszState = "paused";
471 break;
472 case MachineState_Stuck:
473 pszState = details == VMINFO_MACHINEREADABLE ? "gurumeditation" : "guru meditation";
474 break;
475 case MachineState_LiveSnapshotting:
476 pszState = details == VMINFO_MACHINEREADABLE ? "livesnapshotting" : "live snapshotting";
477 break;
478 case MachineState_Teleporting:
479 pszState = "teleporting";
480 break;
481 case MachineState_Starting:
482 pszState = "starting";
483 break;
484 case MachineState_Stopping:
485 pszState = "stopping";
486 break;
487 case MachineState_Saving:
488 pszState = "saving";
489 break;
490 case MachineState_Restoring:
491 pszState = "restoring";
492 break;
493 case MachineState_TeleportingPausedVM:
494 pszState = details == VMINFO_MACHINEREADABLE ? "teleportingpausedvm" : "teleporting paused vm";
495 break;
496 case MachineState_TeleportingIn:
497 pszState = details == VMINFO_MACHINEREADABLE ? "teleportingin" : "teleporting (incoming)";
498 break;
499 case MachineState_RestoringSnapshot:
500 pszState = details == VMINFO_MACHINEREADABLE ? "restoringsnapshot" : "restoring snapshot";
501 case MachineState_DeletingSnapshot:
502 pszState = details == VMINFO_MACHINEREADABLE ? "deletingsnapshot" : "deleting snapshot";
503 case MachineState_SettingUp:
504 pszState = details == VMINFO_MACHINEREADABLE ? "settingup" : "setting up";
505 break;
506 default:
507 pszState = "unknown";
508 break;
509 }
510 LONG64 stateSince;
511 machine->COMGETTER(LastStateChange)(&stateSince);
512 RTTIMESPEC timeSpec;
513 RTTimeSpecSetMilli(&timeSpec, stateSince);
514 char pszTime[30] = {0};
515 RTTimeSpecToString(&timeSpec, pszTime, sizeof(pszTime));
516 Bstr stateFile;
517 machine->COMGETTER(StateFilePath)(stateFile.asOutParam());
518 if (details == VMINFO_MACHINEREADABLE)
519 {
520 RTPrintf("VMState=\"%s\"\n", pszState);
521 RTPrintf("VMStateChangeTime=\"%s\"\n", pszTime);
522 if (!stateFile.isEmpty())
523 RTPrintf("VMStateFile=\"%lS\"\n", stateFile.raw());
524 }
525 else
526 RTPrintf("State: %s (since %s)\n", pszState, pszTime);
527
528 ULONG numMonitors;
529 machine->COMGETTER(MonitorCount)(&numMonitors);
530 if (details == VMINFO_MACHINEREADABLE)
531 RTPrintf("monitorcount=%d\n", numMonitors);
532 else
533 RTPrintf("Monitor count: %d\n", numMonitors);
534
535 BOOL accelerate3d;
536 machine->COMGETTER(Accelerate3DEnabled)(&accelerate3d);
537 if (details == VMINFO_MACHINEREADABLE)
538 RTPrintf("accelerate3d=\"%s\"\n", accelerate3d ? "on" : "off");
539 else
540 RTPrintf("3D Acceleration: %s\n", accelerate3d ? "on" : "off");
541
542#ifdef VBOX_WITH_VIDEOHWACCEL
543 BOOL accelerate2dVideo;
544 machine->COMGETTER(Accelerate2DVideoEnabled)(&accelerate2dVideo);
545 if (details == VMINFO_MACHINEREADABLE)
546 RTPrintf("accelerate2dvideo=\"%s\"\n", accelerate2dVideo ? "on" : "off");
547 else
548 RTPrintf("2D Video Acceleration: %s\n", accelerate2dVideo ? "on" : "off");
549#endif
550
551 BOOL teleporterEnabled;
552 machine->COMGETTER(TeleporterEnabled)(&teleporterEnabled);
553 if (details == VMINFO_MACHINEREADABLE)
554 RTPrintf("teleporterenabled=\"%s\"\n", teleporterEnabled ? "on" : "off");
555 else
556 RTPrintf("Teleporter Enabled: %s\n", teleporterEnabled ? "on" : "off");
557
558 ULONG teleporterPort;
559 machine->COMGETTER(TeleporterPort)(&teleporterPort);
560 if (details == VMINFO_MACHINEREADABLE)
561 RTPrintf("teleporterport=%u\n", teleporterPort);
562 else
563 RTPrintf("Teleporter Port: %u\n", teleporterPort);
564
565 Bstr teleporterAddress;
566 machine->COMGETTER(TeleporterAddress)(teleporterAddress.asOutParam());
567 if (details == VMINFO_MACHINEREADABLE)
568 RTPrintf("teleporteraddress=\"%lS\"\n", teleporterAddress.raw());
569 else
570 RTPrintf("Teleporter Address: %lS\n", teleporterAddress.raw());
571
572 Bstr teleporterPassword;
573 machine->COMGETTER(TeleporterPassword)(teleporterPassword.asOutParam());
574 if (details == VMINFO_MACHINEREADABLE)
575 RTPrintf("teleporterpassword=\"%lS\"\n", teleporterPassword.raw());
576 else
577 RTPrintf("Teleporter Password: %lS\n", teleporterPassword.raw());
578
579 /*
580 * Storage Controllers and their attached Mediums.
581 */
582 com::SafeIfaceArray<IStorageController> storageCtls;
583 CHECK_ERROR(machine, COMGETTER(StorageControllers)(ComSafeArrayAsOutParam (storageCtls)));
584 for (size_t i = 0; i < storageCtls.size(); ++ i)
585 {
586 ComPtr<IStorageController> storageCtl = storageCtls[i];
587 StorageControllerType_T enmCtlType = StorageControllerType_Null;
588 const char *pszCtl = NULL;
589 ULONG ulValue = 0;
590 Bstr storageCtlName;
591
592 storageCtl->COMGETTER(Name)(storageCtlName.asOutParam());
593 if (details == VMINFO_MACHINEREADABLE)
594 RTPrintf("storagecontrollername%u=\"%lS\"\n", i, storageCtlName.raw());
595 else
596 RTPrintf("Storage Controller Name (%u): %lS\n", i, storageCtlName.raw());
597
598 storageCtl->COMGETTER(ControllerType)(&enmCtlType);
599 switch (enmCtlType)
600 {
601 case StorageControllerType_LsiLogic:
602 pszCtl = "LsiLogic";
603 break;
604 case StorageControllerType_BusLogic:
605 pszCtl = "BusLogic";
606 break;
607 case StorageControllerType_IntelAhci:
608 pszCtl = "IntelAhci";
609 break;
610 case StorageControllerType_PIIX3:
611 pszCtl = "PIIX3";
612 break;
613 case StorageControllerType_PIIX4:
614 pszCtl = "PIIX4";
615 break;
616 case StorageControllerType_ICH6:
617 pszCtl = "ICH6";
618 break;
619 case StorageControllerType_I82078:
620 pszCtl = "I82078";
621 break;
622
623 default:
624 pszCtl = "unknown";
625 }
626 if (details == VMINFO_MACHINEREADABLE)
627 RTPrintf("storagecontrollertype%u=\"%s\"\n", i, pszCtl);
628 else
629 RTPrintf("Storage Controller Type (%u): %s\n", i, pszCtl);
630
631 storageCtl->COMGETTER(Instance)(&ulValue);
632 if (details == VMINFO_MACHINEREADABLE)
633 RTPrintf("storagecontrollerinstance%u=\"%lu\"\n", i, ulValue);
634 else
635 RTPrintf("Storage Controller Instance Number (%u): %lu\n", i, ulValue);
636
637 storageCtl->COMGETTER(MaxPortCount)(&ulValue);
638 if (details == VMINFO_MACHINEREADABLE)
639 RTPrintf("storagecontrollermaxportcount%u=\"%lu\"\n", i, ulValue);
640 else
641 RTPrintf("Storage Controller Max Port Count (%u): %lu\n", i, ulValue);
642
643 storageCtl->COMGETTER(PortCount)(&ulValue);
644 if (details == VMINFO_MACHINEREADABLE)
645 RTPrintf("storagecontrollerportcount%u=\"%lu\"\n", i, ulValue);
646 else
647 RTPrintf("Storage Controller Port Count (%u): %lu\n", i, ulValue);
648 }
649
650 for (size_t j = 0; j < storageCtls.size(); ++ j)
651 {
652 ComPtr<IStorageController> storageCtl = storageCtls[j];
653 ComPtr<IMedium> medium;
654 Bstr storageCtlName;
655 Bstr filePath;
656 ULONG cDevices;
657 ULONG cPorts;
658
659 storageCtl->COMGETTER(Name)(storageCtlName.asOutParam());
660 storageCtl->COMGETTER(MaxDevicesPerPortCount)(&cDevices);
661 storageCtl->COMGETTER(PortCount)(&cPorts);
662
663 for (ULONG i = 0; i < cPorts; ++ i)
664 {
665 for (ULONG k = 0; k < cDevices; ++ k)
666 {
667 rc = machine->GetMedium(storageCtlName, i, k, medium.asOutParam());
668 if (SUCCEEDED(rc) && medium)
669 {
670 BOOL fPassthrough;
671 ComPtr<IMediumAttachment> mediumAttach;
672
673 rc = machine->GetMediumAttachment(storageCtlName, i, k, mediumAttach.asOutParam());
674 if (SUCCEEDED(rc) && mediumAttach)
675 mediumAttach->COMGETTER(Passthrough)(&fPassthrough);
676
677 medium->COMGETTER(Location)(filePath.asOutParam());
678 medium->COMGETTER(Id)(uuid.asOutParam());
679
680 if (details == VMINFO_MACHINEREADABLE)
681 {
682 RTPrintf("\"%lS-%d-%d\"=\"%lS\"\n", storageCtlName.raw(),
683 i, k, filePath.raw());
684 RTPrintf("\"%lS-ImageUUID-%d-%d\"=\"%s\"\n",
685 storageCtlName.raw(), i, k, Utf8Str(uuid).raw());
686 if (fPassthrough)
687 RTPrintf("\"%lS-dvdpassthrough\"=\"%s\"\n", storageCtlName.raw(),
688 fPassthrough ? "on" : "off");
689 }
690 else
691 {
692 RTPrintf("%lS (%d, %d): %lS (UUID: %s)",
693 storageCtlName.raw(), i, k, filePath.raw(),
694 Utf8Str(uuid).raw());
695 if (fPassthrough)
696 RTPrintf(" (passthrough enabled)");
697 RTPrintf("\n");
698 }
699 }
700 else if (SUCCEEDED(rc))
701 {
702 if (details == VMINFO_MACHINEREADABLE)
703 RTPrintf("\"%lS-%d-%d\"=\"emptydrive\"\n", storageCtlName.raw(), i, k);
704 else
705 RTPrintf("%lS (%d, %d): Empty\n", storageCtlName.raw(), i, k);
706 }
707 else
708 {
709 if (details == VMINFO_MACHINEREADABLE)
710 RTPrintf("\"%lS-%d-%d\"=\"none\"\n", storageCtlName.raw(), i, k);
711 }
712 }
713 }
714 }
715
716 /* get the maximum amount of NICS */
717 ComPtr<ISystemProperties> sysProps;
718 virtualBox->COMGETTER(SystemProperties)(sysProps.asOutParam());
719 ULONG maxNICs = 0;
720 sysProps->COMGETTER(NetworkAdapterCount)(&maxNICs);
721 for (ULONG currentNIC = 0; currentNIC < maxNICs; currentNIC++)
722 {
723 ComPtr<INetworkAdapter> nic;
724 rc = machine->GetNetworkAdapter(currentNIC, nic.asOutParam());
725 if (SUCCEEDED(rc) && nic)
726 {
727 BOOL fEnabled;
728 nic->COMGETTER(Enabled)(&fEnabled);
729 if (!fEnabled)
730 {
731 if (details == VMINFO_MACHINEREADABLE)
732 RTPrintf("nic%d=\"none\"\n", currentNIC + 1);
733 else
734 RTPrintf("NIC %d: disabled\n", currentNIC + 1);
735 }
736 else
737 {
738 Bstr strMACAddress;
739 nic->COMGETTER(MACAddress)(strMACAddress.asOutParam());
740 Utf8Str strAttachment;
741 NetworkAttachmentType_T attachment;
742 nic->COMGETTER(AttachmentType)(&attachment);
743 switch (attachment)
744 {
745 case NetworkAttachmentType_Null:
746 if (details == VMINFO_MACHINEREADABLE)
747 strAttachment = "null";
748 else
749 strAttachment = "none";
750 break;
751 case NetworkAttachmentType_NAT:
752 {
753 Bstr strNetwork;
754 nic->COMGETTER(NATNetwork)(strNetwork.asOutParam());
755 if (details == VMINFO_MACHINEREADABLE)
756 {
757 RTPrintf("natnet%d=\"%lS\"\n", currentNIC + 1, strNetwork.raw());
758 strAttachment = "nat";
759 }
760 else if (!strNetwork.isEmpty())
761 strAttachment = Utf8StrFmt("NAT (%lS)", strNetwork.raw());
762 else
763 strAttachment = "NAT";
764 break;
765 }
766 case NetworkAttachmentType_Bridged:
767 {
768 Bstr strBridgeAdp;
769 nic->COMGETTER(HostInterface)(strBridgeAdp.asOutParam());
770 if (details == VMINFO_MACHINEREADABLE)
771 {
772 RTPrintf("bridgeadapter%d=\"%lS\"\n", currentNIC + 1, strBridgeAdp.raw());
773 strAttachment = "bridged";
774 }
775 else
776 strAttachment = Utf8StrFmt("Bridged Interface '%lS'", strBridgeAdp.raw());
777 break;
778 }
779 case NetworkAttachmentType_Internal:
780 {
781 Bstr strNetwork;
782 nic->COMGETTER(InternalNetwork)(strNetwork.asOutParam());
783 if (details == VMINFO_MACHINEREADABLE)
784 {
785 RTPrintf("intnet%d=\"%lS\"\n", currentNIC + 1, strNetwork.raw());
786 strAttachment = "intnet";
787 }
788 else
789 strAttachment = Utf8StrFmt("Internal Network '%s'", Utf8Str(strNetwork).raw());
790 break;
791 }
792#if defined(VBOX_WITH_NETFLT)
793 case NetworkAttachmentType_HostOnly:
794 {
795 Bstr strHostonlyAdp;
796 nic->COMGETTER(HostInterface)(strHostonlyAdp.asOutParam());
797 if (details == VMINFO_MACHINEREADABLE)
798 {
799 RTPrintf("hostonlyadapter%d=\"%lS\"\n", currentNIC + 1, strHostonlyAdp.raw());
800 strAttachment = "hostonly";
801 }
802 else
803 strAttachment = Utf8StrFmt("Host-only Interface '%lS'", strHostonlyAdp.raw());
804 break;
805 }
806#endif
807 default:
808 strAttachment = "unknown";
809 break;
810 }
811
812 /* cable connected */
813 BOOL fConnected;
814 nic->COMGETTER(CableConnected)(&fConnected);
815
816 /* trace stuff */
817 BOOL fTraceEnabled;
818 nic->COMGETTER(TraceEnabled)(&fTraceEnabled);
819 Bstr traceFile;
820 nic->COMGETTER(TraceFile)(traceFile.asOutParam());
821
822 /* NIC type */
823 Utf8Str strNICType;
824 NetworkAdapterType_T NICType;
825 nic->COMGETTER(AdapterType)(&NICType);
826 switch (NICType) {
827 case NetworkAdapterType_Am79C970A:
828 strNICType = "Am79C970A";
829 break;
830 case NetworkAdapterType_Am79C973:
831 strNICType = "Am79C973";
832 break;
833#ifdef VBOX_WITH_E1000
834 case NetworkAdapterType_I82540EM:
835 strNICType = "82540EM";
836 break;
837 case NetworkAdapterType_I82543GC:
838 strNICType = "82543GC";
839 break;
840 case NetworkAdapterType_I82545EM:
841 strNICType = "82545EM";
842 break;
843#endif
844#ifdef VBOX_WITH_VIRTIO
845 case NetworkAdapterType_Virtio:
846 strNICType = "virtio";
847 break;
848#endif /* VBOX_WITH_VIRTIO */
849 default:
850 strNICType = "unknown";
851 break;
852 }
853
854 /* reported line speed */
855 ULONG ulLineSpeed;
856 nic->COMGETTER(LineSpeed)(&ulLineSpeed);
857
858 if (details == VMINFO_MACHINEREADABLE)
859 {
860 RTPrintf("macaddress%d=\"%lS\"\n", currentNIC + 1, strMACAddress.raw());
861 RTPrintf("cableconnected%d=\"%s\"\n", currentNIC + 1, fConnected ? "on" : "off");
862 RTPrintf("nic%d=\"%s\"\n", currentNIC + 1, strAttachment.raw());
863 }
864 else
865 RTPrintf("NIC %d: MAC: %lS, Attachment: %s, Cable connected: %s, Trace: %s (file: %lS), Type: %s, Reported speed: %d Mbps\n",
866 currentNIC + 1, strMACAddress.raw(), strAttachment.raw(),
867 fConnected ? "on" : "off",
868 fTraceEnabled ? "on" : "off",
869 traceFile.isEmpty() ? Bstr("none").raw() : traceFile.raw(),
870 strNICType.raw(),
871 ulLineSpeed / 1000);
872 }
873 }
874 }
875
876 /* Pointing device information */
877 PointingHidType_T aPointingHid;
878 const char *pszHid = "Unknown";
879 const char *pszMrHid = "unknown";
880 machine->COMGETTER(PointingHidType)(&aPointingHid);
881 switch (aPointingHid)
882 {
883 case PointingHidType_None:
884 pszHid = "None";
885 pszMrHid = "none";
886 break;
887 case PointingHidType_PS2Mouse:
888 pszHid = "PS/2 Mouse";
889 pszMrHid = "ps2mouse";
890 break;
891 case PointingHidType_USBMouse:
892 pszHid = "USB Mouse";
893 pszMrHid = "usbmouse";
894 break;
895 case PointingHidType_USBTablet:
896 pszHid = "USB Tablet";
897 pszMrHid = "usbtablet";
898 break;
899 case PointingHidType_ComboMouse:
900 pszHid = "USB Tablet and PS/2 Mouse";
901 pszMrHid = "combomouse";
902 break;
903 default:
904 break;
905 }
906 if (details == VMINFO_MACHINEREADABLE)
907 RTPrintf("hidpointing=\"%s\"\n", pszMrHid);
908 else
909 RTPrintf("Pointing Device: %s\n", pszHid);
910
911 /* Keyboard device information */
912 KeyboardHidType_T aKeyboardHid;
913 machine->COMGETTER(KeyboardHidType)(&aKeyboardHid);
914 pszHid = "Unknown";
915 pszMrHid = "unknown";
916 switch (aKeyboardHid)
917 {
918 case KeyboardHidType_None:
919 pszHid = "None";
920 pszMrHid = "none";
921 break;
922 case KeyboardHidType_PS2Keyboard:
923 pszHid = "PS/2 Keyboard";
924 pszMrHid = "ps2kbd";
925 break;
926 case KeyboardHidType_USBKeyboard:
927 pszHid = "USB Keyboard";
928 pszMrHid = "usbkbd";
929 break;
930 case KeyboardHidType_ComboKeyboard:
931 pszHid = "USB and PS/2 Keyboard";
932 pszMrHid = "combokbd";
933 break;
934 default:
935 break;
936 }
937 if (details == VMINFO_MACHINEREADABLE)
938 RTPrintf("hidkeyboard=\"%s\"\n", pszMrHid);
939 else
940 RTPrintf("Keyboard Device: %s\n", pszHid);
941
942 /* get the maximum amount of UARTs */
943 ULONG maxUARTs = 0;
944 sysProps->COMGETTER(SerialPortCount)(&maxUARTs);
945 for (ULONG currentUART = 0; currentUART < maxUARTs; currentUART++)
946 {
947 ComPtr<ISerialPort> uart;
948 rc = machine->GetSerialPort(currentUART, uart.asOutParam());
949 if (SUCCEEDED(rc) && uart)
950 {
951 BOOL fEnabled;
952 uart->COMGETTER(Enabled)(&fEnabled);
953 if (!fEnabled)
954 {
955 if (details == VMINFO_MACHINEREADABLE)
956 RTPrintf("uart%d=\"off\"\n", currentUART + 1);
957 else
958 RTPrintf("UART %d: disabled\n", currentUART + 1);
959 }
960 else
961 {
962 ULONG ulIRQ, ulIOBase;
963 PortMode_T HostMode;
964 Bstr path;
965 BOOL fServer;
966 uart->COMGETTER(IRQ)(&ulIRQ);
967 uart->COMGETTER(IOBase)(&ulIOBase);
968 uart->COMGETTER(Path)(path.asOutParam());
969 uart->COMGETTER(Server)(&fServer);
970 uart->COMGETTER(HostMode)(&HostMode);
971
972 if (details == VMINFO_MACHINEREADABLE)
973 RTPrintf("uart%d=\"%#06x,%d\"\n", currentUART + 1,
974 ulIOBase, ulIRQ);
975 else
976 RTPrintf("UART %d: I/O base: 0x%04x, IRQ: %d",
977 currentUART + 1, ulIOBase, ulIRQ);
978 switch (HostMode)
979 {
980 default:
981 case PortMode_Disconnected:
982 if (details == VMINFO_MACHINEREADABLE)
983 RTPrintf("uartmode%d=\"disconnected\"\n", currentUART + 1);
984 else
985 RTPrintf(", disconnected\n");
986 break;
987 case PortMode_RawFile:
988 if (details == VMINFO_MACHINEREADABLE)
989 RTPrintf("uartmode%d=\"%lS\"\n", currentUART + 1,
990 path.raw());
991 else
992 RTPrintf(", attached to raw file '%lS'\n",
993 path.raw());
994 break;
995 case PortMode_HostPipe:
996 if (details == VMINFO_MACHINEREADABLE)
997 RTPrintf("uartmode%d=\"%s,%lS\"\n", currentUART + 1,
998 fServer ? "server" : "client", path.raw());
999 else
1000 RTPrintf(", attached to pipe (%s) '%lS'\n",
1001 fServer ? "server" : "client", path.raw());
1002 break;
1003 case PortMode_HostDevice:
1004 if (details == VMINFO_MACHINEREADABLE)
1005 RTPrintf("uartmode%d=\"%lS\"\n", currentUART + 1,
1006 path.raw());
1007 else
1008 RTPrintf(", attached to device '%lS'\n", path.raw());
1009 break;
1010 }
1011 }
1012 }
1013 }
1014
1015 ComPtr<IAudioAdapter> AudioAdapter;
1016 rc = machine->COMGETTER(AudioAdapter)(AudioAdapter.asOutParam());
1017 if (SUCCEEDED(rc))
1018 {
1019 const char *pszDrv = "Unknown";
1020 const char *pszCtrl = "Unknown";
1021 BOOL fEnabled;
1022 rc = AudioAdapter->COMGETTER(Enabled)(&fEnabled);
1023 if (SUCCEEDED(rc) && fEnabled)
1024 {
1025 AudioDriverType_T enmDrvType;
1026 rc = AudioAdapter->COMGETTER(AudioDriver)(&enmDrvType);
1027 switch (enmDrvType)
1028 {
1029 case AudioDriverType_Null:
1030 if (details == VMINFO_MACHINEREADABLE)
1031 pszDrv = "null";
1032 else
1033 pszDrv = "Null";
1034 break;
1035 case AudioDriverType_WinMM:
1036 if (details == VMINFO_MACHINEREADABLE)
1037 pszDrv = "winmm";
1038 else
1039 pszDrv = "WINMM";
1040 break;
1041 case AudioDriverType_DirectSound:
1042 if (details == VMINFO_MACHINEREADABLE)
1043 pszDrv = "dsound";
1044 else
1045 pszDrv = "DSOUND";
1046 break;
1047 case AudioDriverType_OSS:
1048 if (details == VMINFO_MACHINEREADABLE)
1049 pszDrv = "oss";
1050 else
1051 pszDrv = "OSS";
1052 break;
1053 case AudioDriverType_ALSA:
1054 if (details == VMINFO_MACHINEREADABLE)
1055 pszDrv = "alsa";
1056 else
1057 pszDrv = "ALSA";
1058 break;
1059 case AudioDriverType_Pulse:
1060 if (details == VMINFO_MACHINEREADABLE)
1061 pszDrv = "pulse";
1062 else
1063 pszDrv = "PulseAudio";
1064 break;
1065 case AudioDriverType_CoreAudio:
1066 if (details == VMINFO_MACHINEREADABLE)
1067 pszDrv = "coreaudio";
1068 else
1069 pszDrv = "CoreAudio";
1070 break;
1071 case AudioDriverType_SolAudio:
1072 if (details == VMINFO_MACHINEREADABLE)
1073 pszDrv = "solaudio";
1074 else
1075 pszDrv = "SolAudio";
1076 break;
1077 default:
1078 if (details == VMINFO_MACHINEREADABLE)
1079 pszDrv = "unknown";
1080 break;
1081 }
1082 AudioControllerType_T enmCtrlType;
1083 rc = AudioAdapter->COMGETTER(AudioController)(&enmCtrlType);
1084 switch (enmCtrlType)
1085 {
1086 case AudioControllerType_AC97:
1087 if (details == VMINFO_MACHINEREADABLE)
1088 pszCtrl = "ac97";
1089 else
1090 pszCtrl = "AC97";
1091 break;
1092 case AudioControllerType_SB16:
1093 if (details == VMINFO_MACHINEREADABLE)
1094 pszCtrl = "sb16";
1095 else
1096 pszCtrl = "SB16";
1097 break;
1098 }
1099 }
1100 else
1101 fEnabled = FALSE;
1102 if (details == VMINFO_MACHINEREADABLE)
1103 {
1104 if (fEnabled)
1105 RTPrintf("audio=\"%s\"\n", pszDrv);
1106 else
1107 RTPrintf("audio=\"none\"\n");
1108 }
1109 else
1110 {
1111 RTPrintf("Audio: %s",
1112 fEnabled ? "enabled" : "disabled");
1113 if (fEnabled)
1114 RTPrintf(" (Driver: %s, Controller: %s)",
1115 pszDrv, pszCtrl);
1116 RTPrintf("\n");
1117 }
1118 }
1119
1120 /* Shared clipboard */
1121 {
1122 const char *psz = "Unknown";
1123 ClipboardMode_T enmMode;
1124 rc = machine->COMGETTER(ClipboardMode)(&enmMode);
1125 switch (enmMode)
1126 {
1127 case ClipboardMode_Disabled:
1128 if (details == VMINFO_MACHINEREADABLE)
1129 psz = "disabled";
1130 else
1131 psz = "disabled";
1132 break;
1133 case ClipboardMode_HostToGuest:
1134 if (details == VMINFO_MACHINEREADABLE)
1135 psz = "hosttoguest";
1136 else
1137 psz = "HostToGuest";
1138 break;
1139 case ClipboardMode_GuestToHost:
1140 if (details == VMINFO_MACHINEREADABLE)
1141 psz = "guesttohost";
1142 else
1143 psz = "GuestToHost";
1144 break;
1145 case ClipboardMode_Bidirectional:
1146 if (details == VMINFO_MACHINEREADABLE)
1147 psz = "bidirectional";
1148 else
1149 psz = "Bidirectional";
1150 break;
1151 default:
1152 if (details == VMINFO_MACHINEREADABLE)
1153 psz = "unknown";
1154 break;
1155 }
1156 if (details == VMINFO_MACHINEREADABLE)
1157 RTPrintf("clipboard=\"%s\"\n", psz);
1158 else
1159 RTPrintf("Clipboard Mode: %s\n", psz);
1160 }
1161
1162 if (console)
1163 {
1164 ComPtr<IDisplay> display;
1165 CHECK_ERROR_RET(console, COMGETTER(Display)(display.asOutParam()), rc);
1166 do
1167 {
1168 ULONG xRes, yRes, bpp;
1169 rc = display->COMGETTER(Width)(&xRes);
1170 if (rc == E_ACCESSDENIED)
1171 break; /* VM not powered up */
1172 if (FAILED(rc))
1173 {
1174 com::ErrorInfo info (display);
1175 GluePrintErrorInfo(info);
1176 return rc;
1177 }
1178 rc = display->COMGETTER(Height)(&yRes);
1179 if (rc == E_ACCESSDENIED)
1180 break; /* VM not powered up */
1181 if (FAILED(rc))
1182 {
1183 com::ErrorInfo info (display);
1184 GluePrintErrorInfo(info);
1185 return rc;
1186 }
1187 rc = display->COMGETTER(BitsPerPixel)(&bpp);
1188 if (rc == E_ACCESSDENIED)
1189 break; /* VM not powered up */
1190 if (FAILED(rc))
1191 {
1192 com::ErrorInfo info (display);
1193 GluePrintErrorInfo(info);
1194 return rc;
1195 }
1196 if (details == VMINFO_MACHINEREADABLE)
1197 RTPrintf("VideoMode=\"%d,%d,%d\"\n", xRes, yRes, bpp);
1198 else
1199 RTPrintf("Video mode: %dx%dx%d\n", xRes, yRes, bpp);
1200 }
1201 while (0);
1202 }
1203
1204 /*
1205 * VRDP
1206 */
1207 ComPtr<IVRDPServer> vrdpServer;
1208 rc = machine->COMGETTER(VRDPServer)(vrdpServer.asOutParam());
1209 if (SUCCEEDED(rc) && vrdpServer)
1210 {
1211 BOOL fEnabled = false;
1212 vrdpServer->COMGETTER(Enabled)(&fEnabled);
1213 if (fEnabled)
1214 {
1215 LONG vrdpPort = -1;
1216 Bstr ports;
1217 vrdpServer->COMGETTER(Ports)(ports.asOutParam());
1218 Bstr address;
1219 vrdpServer->COMGETTER(NetAddress)(address.asOutParam());
1220 BOOL fMultiCon;
1221 vrdpServer->COMGETTER(AllowMultiConnection)(&fMultiCon);
1222 BOOL fReuseCon;
1223 vrdpServer->COMGETTER(ReuseSingleConnection)(&fReuseCon);
1224 VRDPAuthType_T vrdpAuthType;
1225 const char *strAuthType;
1226 vrdpServer->COMGETTER(AuthType)(&vrdpAuthType);
1227 switch (vrdpAuthType)
1228 {
1229 case VRDPAuthType_Null:
1230 strAuthType = "null";
1231 break;
1232 case VRDPAuthType_External:
1233 strAuthType = "external";
1234 break;
1235 case VRDPAuthType_Guest:
1236 strAuthType = "guest";
1237 break;
1238 default:
1239 strAuthType = "unknown";
1240 break;
1241 }
1242 if (console)
1243 {
1244 ComPtr<IRemoteDisplayInfo> remoteDisplayInfo;
1245 CHECK_ERROR_RET(console, COMGETTER(RemoteDisplayInfo)(remoteDisplayInfo.asOutParam()), rc);
1246 rc = remoteDisplayInfo->COMGETTER(Port)(&vrdpPort);
1247 if (rc == E_ACCESSDENIED)
1248 {
1249 vrdpPort = -1; /* VM not powered up */
1250 }
1251 if (FAILED(rc))
1252 {
1253 com::ErrorInfo info (remoteDisplayInfo);
1254 GluePrintErrorInfo(info);
1255 return rc;
1256 }
1257 }
1258 if (details == VMINFO_MACHINEREADABLE)
1259 {
1260 RTPrintf("vrdp=\"on\"\n");
1261 RTPrintf("vrdpport=%d\n", vrdpPort);
1262 RTPrintf("vrdpports=\"%lS\"\n", ports.raw());
1263 RTPrintf("vrdpaddress=\"%lS\"\n", address.raw());
1264 RTPrintf("vrdpauthtype=\"%s\"\n", strAuthType);
1265 RTPrintf("vrdpmulticon=\"%s\"\n", fMultiCon ? "on" : "off");
1266 RTPrintf("vrdpreusecon=\"%s\"\n", fReuseCon ? "on" : "off");
1267 }
1268 else
1269 {
1270 if (address.isEmpty())
1271 address = "0.0.0.0";
1272 RTPrintf("VRDP: enabled (Address %lS, Ports %lS, MultiConn: %s, ReuseSingleConn: %s, Authentication type: %s)\n", address.raw(), ports.raw(), fMultiCon ? "on" : "off", fReuseCon ? "on" : "off", strAuthType);
1273 if (console && vrdpPort != -1 && vrdpPort != 0)
1274 RTPrintf("VRDP port: %d\n", vrdpPort);
1275 }
1276 }
1277 else
1278 {
1279 if (details == VMINFO_MACHINEREADABLE)
1280 RTPrintf("vrdp=\"off\"\n");
1281 else
1282 RTPrintf("VRDP: disabled\n");
1283 }
1284 }
1285
1286 /*
1287 * USB.
1288 */
1289 ComPtr<IUSBController> USBCtl;
1290 rc = machine->COMGETTER(USBController)(USBCtl.asOutParam());
1291 if (SUCCEEDED(rc))
1292 {
1293 BOOL fEnabled;
1294 rc = USBCtl->COMGETTER(Enabled)(&fEnabled);
1295 if (FAILED(rc))
1296 fEnabled = false;
1297 if (details == VMINFO_MACHINEREADABLE)
1298 RTPrintf("usb=\"%s\"\n", fEnabled ? "on" : "off");
1299 else
1300 RTPrintf("USB: %s\n", fEnabled ? "enabled" : "disabled");
1301
1302 SafeIfaceArray <IUSBDeviceFilter> Coll;
1303 rc = USBCtl->COMGETTER(DeviceFilters)(ComSafeArrayAsOutParam(Coll));
1304 if (SUCCEEDED(rc))
1305 {
1306 if (details != VMINFO_MACHINEREADABLE)
1307 RTPrintf("\nUSB Device Filters:\n\n");
1308
1309 if (Coll.size() == 0)
1310 {
1311 if (details != VMINFO_MACHINEREADABLE)
1312 RTPrintf("<none>\n\n");
1313 }
1314 else
1315 {
1316 for (size_t index = 0; index < Coll.size(); ++index)
1317 {
1318 ComPtr<IUSBDeviceFilter> DevPtr = Coll[index];
1319
1320 /* Query info. */
1321
1322 if (details != VMINFO_MACHINEREADABLE)
1323 RTPrintf("Index: %zu\n", index);
1324
1325 BOOL bActive = FALSE;
1326 CHECK_ERROR_RET (DevPtr, COMGETTER (Active) (&bActive), rc);
1327 if (details == VMINFO_MACHINEREADABLE)
1328 RTPrintf("USBFilterActive%zu=\"%s\"\n", index + 1, bActive ? "on" : "off");
1329 else
1330 RTPrintf("Active: %s\n", bActive ? "yes" : "no");
1331
1332 Bstr bstr;
1333 CHECK_ERROR_RET (DevPtr, COMGETTER (Name) (bstr.asOutParam()), rc);
1334 if (details == VMINFO_MACHINEREADABLE)
1335 RTPrintf("USBFilterName%zu=\"%lS\"\n", index + 1, bstr.raw());
1336 else
1337 RTPrintf("Name: %lS\n", bstr.raw());
1338 CHECK_ERROR_RET (DevPtr, COMGETTER (VendorId) (bstr.asOutParam()), rc);
1339 if (details == VMINFO_MACHINEREADABLE)
1340 RTPrintf("USBFilterVendorId%zu=\"%lS\"\n", index + 1, bstr.raw());
1341 else
1342 RTPrintf("VendorId: %lS\n", bstr.raw());
1343 CHECK_ERROR_RET (DevPtr, COMGETTER (ProductId) (bstr.asOutParam()), rc);
1344 if (details == VMINFO_MACHINEREADABLE)
1345 RTPrintf("USBFilterProductId%zu=\"%lS\"\n", index + 1, bstr.raw());
1346 else
1347 RTPrintf("ProductId: %lS\n", bstr.raw());
1348 CHECK_ERROR_RET (DevPtr, COMGETTER (Revision) (bstr.asOutParam()), rc);
1349 if (details == VMINFO_MACHINEREADABLE)
1350 RTPrintf("USBFilterRevision%zu=\"%lS\"\n", index + 1, bstr.raw());
1351 else
1352 RTPrintf("Revision: %lS\n", bstr.raw());
1353 CHECK_ERROR_RET (DevPtr, COMGETTER (Manufacturer) (bstr.asOutParam()), rc);
1354 if (details == VMINFO_MACHINEREADABLE)
1355 RTPrintf("USBFilterManufacturer%zu=\"%lS\"\n", index + 1, bstr.raw());
1356 else
1357 RTPrintf("Manufacturer: %lS\n", bstr.raw());
1358 CHECK_ERROR_RET (DevPtr, COMGETTER (Product) (bstr.asOutParam()), rc);
1359 if (details == VMINFO_MACHINEREADABLE)
1360 RTPrintf("USBFilterProduct%zu=\"%lS\"\n", index + 1, bstr.raw());
1361 else
1362 RTPrintf("Product: %lS\n", bstr.raw());
1363 CHECK_ERROR_RET (DevPtr, COMGETTER (Remote) (bstr.asOutParam()), rc);
1364 if (details == VMINFO_MACHINEREADABLE)
1365 RTPrintf("USBFilterRemote%zu=\"%lS\"\n", index + 1, bstr.raw());
1366 else
1367 RTPrintf("Remote: %lS\n", bstr.raw());
1368 CHECK_ERROR_RET (DevPtr, COMGETTER (SerialNumber) (bstr.asOutParam()), rc);
1369 if (details == VMINFO_MACHINEREADABLE)
1370 RTPrintf("USBFilterSerialNumber%zu=\"%lS\"\n", index + 1, bstr.raw());
1371 else
1372 RTPrintf("Serial Number: %lS\n", bstr.raw());
1373 if (details != VMINFO_MACHINEREADABLE)
1374 {
1375 ULONG fMaskedIfs;
1376 CHECK_ERROR_RET (DevPtr, COMGETTER (MaskedInterfaces) (&fMaskedIfs), rc);
1377 if (fMaskedIfs)
1378 RTPrintf("Masked Interfaces: 0x%08x\n", fMaskedIfs);
1379 RTPrintf("\n");
1380 }
1381 }
1382 }
1383 }
1384
1385 if (console)
1386 {
1387 /* scope */
1388 {
1389 if (details != VMINFO_MACHINEREADABLE)
1390 RTPrintf("Available remote USB devices:\n\n");
1391
1392 SafeIfaceArray <IHostUSBDevice> coll;
1393 CHECK_ERROR_RET (console, COMGETTER(RemoteUSBDevices) (ComSafeArrayAsOutParam(coll)), rc);
1394
1395 if (coll.size() == 0)
1396 {
1397 if (details != VMINFO_MACHINEREADABLE)
1398 RTPrintf("<none>\n\n");
1399 }
1400 else
1401 {
1402 for (size_t index = 0; index < coll.size(); ++index)
1403 {
1404 ComPtr <IHostUSBDevice> dev = coll[index];
1405
1406 /* Query info. */
1407 Bstr id;
1408 CHECK_ERROR_RET (dev, COMGETTER(Id)(id.asOutParam()), rc);
1409 USHORT usVendorId;
1410 CHECK_ERROR_RET (dev, COMGETTER(VendorId)(&usVendorId), rc);
1411 USHORT usProductId;
1412 CHECK_ERROR_RET (dev, COMGETTER(ProductId)(&usProductId), rc);
1413 USHORT bcdRevision;
1414 CHECK_ERROR_RET (dev, COMGETTER(Revision)(&bcdRevision), rc);
1415
1416 if (details == VMINFO_MACHINEREADABLE)
1417 RTPrintf("USBRemoteUUID%zu=\"%S\"\n"
1418 "USBRemoteVendorId%zu=\"%#06x\"\n"
1419 "USBRemoteProductId%zu=\"%#06x\"\n"
1420 "USBRemoteRevision%zu=\"%#04x%02x\"\n",
1421 index + 1, Utf8Str(id).raw(),
1422 index + 1, usVendorId,
1423 index + 1, usProductId,
1424 index + 1, bcdRevision >> 8, bcdRevision & 0xff);
1425 else
1426 RTPrintf("UUID: %S\n"
1427 "VendorId: 0x%04x (%04X)\n"
1428 "ProductId: 0x%04x (%04X)\n"
1429 "Revision: %u.%u (%02u%02u)\n",
1430 Utf8Str(id).raw(),
1431 usVendorId, usVendorId, usProductId, usProductId,
1432 bcdRevision >> 8, bcdRevision & 0xff,
1433 bcdRevision >> 8, bcdRevision & 0xff);
1434
1435 /* optional stuff. */
1436 Bstr bstr;
1437 CHECK_ERROR_RET (dev, COMGETTER(Manufacturer)(bstr.asOutParam()), rc);
1438 if (!bstr.isEmpty())
1439 {
1440 if (details == VMINFO_MACHINEREADABLE)
1441 RTPrintf("USBRemoteManufacturer%zu=\"%lS\"\n", index + 1, bstr.raw());
1442 else
1443 RTPrintf("Manufacturer: %lS\n", bstr.raw());
1444 }
1445 CHECK_ERROR_RET (dev, COMGETTER(Product)(bstr.asOutParam()), rc);
1446 if (!bstr.isEmpty())
1447 {
1448 if (details == VMINFO_MACHINEREADABLE)
1449 RTPrintf("USBRemoteProduct%zu=\"%lS\"\n", index + 1, bstr.raw());
1450 else
1451 RTPrintf("Product: %lS\n", bstr.raw());
1452 }
1453 CHECK_ERROR_RET (dev, COMGETTER(SerialNumber)(bstr.asOutParam()), rc);
1454 if (!bstr.isEmpty())
1455 {
1456 if (details == VMINFO_MACHINEREADABLE)
1457 RTPrintf("USBRemoteSerialNumber%zu=\"%lS\"\n", index + 1, bstr.raw());
1458 else
1459 RTPrintf("SerialNumber: %lS\n", bstr.raw());
1460 }
1461 CHECK_ERROR_RET (dev, COMGETTER(Address)(bstr.asOutParam()), rc);
1462 if (!bstr.isEmpty())
1463 {
1464 if (details == VMINFO_MACHINEREADABLE)
1465 RTPrintf("USBRemoteAddress%zu=\"%lS\"\n", index + 1, bstr.raw());
1466 else
1467 RTPrintf("Address: %lS\n", bstr.raw());
1468 }
1469
1470 if (details != VMINFO_MACHINEREADABLE)
1471 RTPrintf("\n");
1472 }
1473 }
1474 }
1475
1476 /* scope */
1477 {
1478 if (details != VMINFO_MACHINEREADABLE)
1479 RTPrintf ("Currently Attached USB Devices:\n\n");
1480
1481 SafeIfaceArray <IUSBDevice> coll;
1482 CHECK_ERROR_RET (console, COMGETTER(USBDevices) (ComSafeArrayAsOutParam(coll)), rc);
1483
1484 if (coll.size() == 0)
1485 {
1486 if (details != VMINFO_MACHINEREADABLE)
1487 RTPrintf("<none>\n\n");
1488 }
1489 else
1490 {
1491 for (size_t index = 0; index < coll.size(); ++index)
1492 {
1493 ComPtr <IUSBDevice> dev = coll[index];
1494
1495 /* Query info. */
1496 Bstr id;
1497 CHECK_ERROR_RET (dev, COMGETTER(Id)(id.asOutParam()), rc);
1498 USHORT usVendorId;
1499 CHECK_ERROR_RET (dev, COMGETTER(VendorId)(&usVendorId), rc);
1500 USHORT usProductId;
1501 CHECK_ERROR_RET (dev, COMGETTER(ProductId)(&usProductId), rc);
1502 USHORT bcdRevision;
1503 CHECK_ERROR_RET (dev, COMGETTER(Revision)(&bcdRevision), rc);
1504
1505 if (details == VMINFO_MACHINEREADABLE)
1506 RTPrintf("USBAttachedUUID%zu=\"%S\"\n"
1507 "USBAttachedVendorId%zu=\"%#06x\"\n"
1508 "USBAttachedProductId%zu=\"%#06x\"\n"
1509 "USBAttachedRevision%zu=\"%#04x%02x\"\n",
1510 index + 1, Utf8Str(id).raw(),
1511 index + 1, usVendorId,
1512 index + 1, usProductId,
1513 index + 1, bcdRevision >> 8, bcdRevision & 0xff);
1514 else
1515 RTPrintf("UUID: %S\n"
1516 "VendorId: 0x%04x (%04X)\n"
1517 "ProductId: 0x%04x (%04X)\n"
1518 "Revision: %u.%u (%02u%02u)\n",
1519 Utf8Str(id).raw(),
1520 usVendorId, usVendorId, usProductId, usProductId,
1521 bcdRevision >> 8, bcdRevision & 0xff,
1522 bcdRevision >> 8, bcdRevision & 0xff);
1523
1524 /* optional stuff. */
1525 Bstr bstr;
1526 CHECK_ERROR_RET (dev, COMGETTER(Manufacturer)(bstr.asOutParam()), rc);
1527 if (!bstr.isEmpty())
1528 {
1529 if (details == VMINFO_MACHINEREADABLE)
1530 RTPrintf("USBAttachedManufacturer%zu=\"%lS\"\n", index + 1, bstr.raw());
1531 else
1532 RTPrintf("Manufacturer: %lS\n", bstr.raw());
1533 }
1534 CHECK_ERROR_RET (dev, COMGETTER(Product)(bstr.asOutParam()), rc);
1535 if (!bstr.isEmpty())
1536 {
1537 if (details == VMINFO_MACHINEREADABLE)
1538 RTPrintf("USBAttachedProduct%zu=\"%lS\"\n", index + 1, bstr.raw());
1539 else
1540 RTPrintf("Product: %lS\n", bstr.raw());
1541 }
1542 CHECK_ERROR_RET (dev, COMGETTER(SerialNumber)(bstr.asOutParam()), rc);
1543 if (!bstr.isEmpty())
1544 {
1545 if (details == VMINFO_MACHINEREADABLE)
1546 RTPrintf("USBAttachedSerialNumber%zu=\"%lS\"\n", index + 1, bstr.raw());
1547 else
1548 RTPrintf("SerialNumber: %lS\n", bstr.raw());
1549 }
1550 CHECK_ERROR_RET (dev, COMGETTER(Address)(bstr.asOutParam()), rc);
1551 if (!bstr.isEmpty())
1552 {
1553 if (details == VMINFO_MACHINEREADABLE)
1554 RTPrintf("USBAttachedAddress%zu=\"%lS\"\n", index + 1, bstr.raw());
1555 else
1556 RTPrintf("Address: %lS\n", bstr.raw());
1557 }
1558
1559 if (details != VMINFO_MACHINEREADABLE)
1560 RTPrintf("\n");
1561 }
1562 }
1563 }
1564 }
1565 } /* USB */
1566
1567 /*
1568 * Shared folders
1569 */
1570 if (details != VMINFO_MACHINEREADABLE)
1571 RTPrintf("Shared folders: ");
1572 uint32_t numSharedFolders = 0;
1573#if 0 // not yet implemented
1574 /* globally shared folders first */
1575 {
1576 SafeIfaceArray <ISharedFolder> sfColl;
1577 CHECK_ERROR_RET(virtualBox, COMGETTER(SharedFolders)(ComSafeArrayAsOutParam(sfColl)), rc);
1578 for (size_t i = 0; i < sfColl.size(); ++i)
1579 {
1580 ComPtr<ISharedFolder> sf = sfColl[i];
1581 Bstr name, hostPath;
1582 sf->COMGETTER(Name)(name.asOutParam());
1583 sf->COMGETTER(HostPath)(hostPath.asOutParam());
1584 RTPrintf("Name: '%lS', Host path: '%lS' (global mapping)\n", name.raw(), hostPath.raw());
1585 ++numSharedFolders;
1586 }
1587 }
1588#endif
1589 /* now VM mappings */
1590 {
1591 com::SafeIfaceArray <ISharedFolder> folders;
1592
1593 CHECK_ERROR_RET(machine, COMGETTER(SharedFolders)(ComSafeArrayAsOutParam(folders)), rc);
1594
1595 for (size_t i = 0; i < folders.size(); ++i)
1596 {
1597 ComPtr <ISharedFolder> sf = folders[i];
1598
1599 Bstr name, hostPath;
1600 BOOL writable;
1601 sf->COMGETTER(Name)(name.asOutParam());
1602 sf->COMGETTER(HostPath)(hostPath.asOutParam());
1603 sf->COMGETTER(Writable)(&writable);
1604 if (!numSharedFolders && details != VMINFO_MACHINEREADABLE)
1605 RTPrintf("\n\n");
1606 if (details == VMINFO_MACHINEREADABLE)
1607 {
1608 RTPrintf("SharedFolderNameMachineMapping%zu=\"%lS\"\n", i + 1,
1609 name.raw());
1610 RTPrintf("SharedFolderPathMachineMapping%zu=\"%lS\"\n", i + 1,
1611 hostPath.raw());
1612 }
1613 else
1614 RTPrintf("Name: '%lS', Host path: '%lS' (machine mapping), %s\n",
1615 name.raw(), hostPath.raw(), writable ? "writable" : "readonly");
1616 ++numSharedFolders;
1617 }
1618 }
1619 /* transient mappings */
1620 if (console)
1621 {
1622 com::SafeIfaceArray <ISharedFolder> folders;
1623
1624 CHECK_ERROR_RET(console, COMGETTER(SharedFolders)(ComSafeArrayAsOutParam(folders)), rc);
1625
1626 for (size_t i = 0; i < folders.size(); ++i)
1627 {
1628 ComPtr <ISharedFolder> sf = folders[i];
1629
1630 Bstr name, hostPath;
1631 sf->COMGETTER(Name)(name.asOutParam());
1632 sf->COMGETTER(HostPath)(hostPath.asOutParam());
1633 if (!numSharedFolders && details != VMINFO_MACHINEREADABLE)
1634 RTPrintf("\n\n");
1635 if (details == VMINFO_MACHINEREADABLE)
1636 {
1637 RTPrintf("SharedFolderNameTransientMapping%zu=\"%lS\"\n", i + 1,
1638 name.raw());
1639 RTPrintf("SharedFolderPathTransientMapping%zu=\"%lS\"\n", i + 1,
1640 hostPath.raw());
1641 }
1642 else
1643 RTPrintf("Name: '%lS', Host path: '%lS' (transient mapping)\n", name.raw(), hostPath.raw());
1644 ++numSharedFolders;
1645 }
1646 }
1647 if (!numSharedFolders && details != VMINFO_MACHINEREADABLE)
1648 RTPrintf("<none>\n");
1649 if (details != VMINFO_MACHINEREADABLE)
1650 RTPrintf("\n");
1651
1652 if (console)
1653 {
1654 /*
1655 * Live VRDP info.
1656 */
1657 ComPtr<IRemoteDisplayInfo> remoteDisplayInfo;
1658 CHECK_ERROR_RET(console, COMGETTER(RemoteDisplayInfo)(remoteDisplayInfo.asOutParam()), rc);
1659 BOOL Active;
1660 ULONG NumberOfClients;
1661 LONG64 BeginTime;
1662 LONG64 EndTime;
1663 ULONG64 BytesSent;
1664 ULONG64 BytesSentTotal;
1665 ULONG64 BytesReceived;
1666 ULONG64 BytesReceivedTotal;
1667 Bstr User;
1668 Bstr Domain;
1669 Bstr ClientName;
1670 Bstr ClientIP;
1671 ULONG ClientVersion;
1672 ULONG EncryptionStyle;
1673
1674 CHECK_ERROR_RET(remoteDisplayInfo, COMGETTER(Active) (&Active), rc);
1675 CHECK_ERROR_RET(remoteDisplayInfo, COMGETTER(NumberOfClients) (&NumberOfClients), rc);
1676 CHECK_ERROR_RET(remoteDisplayInfo, COMGETTER(BeginTime) (&BeginTime), rc);
1677 CHECK_ERROR_RET(remoteDisplayInfo, COMGETTER(EndTime) (&EndTime), rc);
1678 CHECK_ERROR_RET(remoteDisplayInfo, COMGETTER(BytesSent) (&BytesSent), rc);
1679 CHECK_ERROR_RET(remoteDisplayInfo, COMGETTER(BytesSentTotal) (&BytesSentTotal), rc);
1680 CHECK_ERROR_RET(remoteDisplayInfo, COMGETTER(BytesReceived) (&BytesReceived), rc);
1681 CHECK_ERROR_RET(remoteDisplayInfo, COMGETTER(BytesReceivedTotal) (&BytesReceivedTotal), rc);
1682 CHECK_ERROR_RET(remoteDisplayInfo, COMGETTER(User) (User.asOutParam ()), rc);
1683 CHECK_ERROR_RET(remoteDisplayInfo, COMGETTER(Domain) (Domain.asOutParam ()), rc);
1684 CHECK_ERROR_RET(remoteDisplayInfo, COMGETTER(ClientName) (ClientName.asOutParam ()), rc);
1685 CHECK_ERROR_RET(remoteDisplayInfo, COMGETTER(ClientIP) (ClientIP.asOutParam ()), rc);
1686 CHECK_ERROR_RET(remoteDisplayInfo, COMGETTER(ClientVersion) (&ClientVersion), rc);
1687 CHECK_ERROR_RET(remoteDisplayInfo, COMGETTER(EncryptionStyle) (&EncryptionStyle), rc);
1688
1689 if (details == VMINFO_MACHINEREADABLE)
1690 RTPrintf("VRDPActiveConnection=\"%s\"\n", Active ? "on": "off");
1691 else
1692 RTPrintf("VRDP Connection: %s\n", Active? "active": "not active");
1693
1694 if (details == VMINFO_MACHINEREADABLE)
1695 RTPrintf("VRDPClients=%d\n", NumberOfClients);
1696 else
1697 RTPrintf("Clients so far: %d\n", NumberOfClients);
1698
1699 if (NumberOfClients > 0)
1700 {
1701 char timestr[128];
1702
1703 if (Active)
1704 {
1705 makeTimeStr (timestr, sizeof (timestr), BeginTime);
1706 if (details == VMINFO_MACHINEREADABLE)
1707 RTPrintf("VRDPStartTime=\"%s\"\n", timestr);
1708 else
1709 RTPrintf("Start time: %s\n", timestr);
1710 }
1711 else
1712 {
1713 makeTimeStr (timestr, sizeof (timestr), BeginTime);
1714 if (details == VMINFO_MACHINEREADABLE)
1715 RTPrintf("VRDPLastStartTime=\"%s\"\n", timestr);
1716 else
1717 RTPrintf("Last started: %s\n", timestr);
1718 makeTimeStr (timestr, sizeof (timestr), EndTime);
1719 if (details == VMINFO_MACHINEREADABLE)
1720 RTPrintf("VRDPLastEndTime=\"%s\"\n", timestr);
1721 else
1722 RTPrintf("Last ended: %s\n", timestr);
1723 }
1724
1725 uint64_t ThroughputSend = 0;
1726 uint64_t ThroughputReceive = 0;
1727 if (EndTime != BeginTime)
1728 {
1729 ThroughputSend = (BytesSent * 1000) / (EndTime - BeginTime);
1730 ThroughputReceive = (BytesReceived * 1000) / (EndTime - BeginTime);
1731 }
1732
1733 if (details == VMINFO_MACHINEREADABLE)
1734 {
1735 RTPrintf("VRDPBytesSent=%llu\n", BytesSent);
1736 RTPrintf("VRDPThroughputSend=%llu\n", ThroughputSend);
1737 RTPrintf("VRDPBytesSentTotal=%llu\n", BytesSentTotal);
1738
1739 RTPrintf("VRDPBytesReceived=%llu\n", BytesReceived);
1740 RTPrintf("VRDPThroughputReceive=%llu\n", ThroughputReceive);
1741 RTPrintf("VRDPBytesReceivedTotal=%llu\n", BytesReceivedTotal);
1742 }
1743 else
1744 {
1745 RTPrintf("Sent: %llu Bytes\n", BytesSent);
1746 RTPrintf("Average speed: %llu B/s\n", ThroughputSend);
1747 RTPrintf("Sent total: %llu Bytes\n", BytesSentTotal);
1748
1749 RTPrintf("Received: %llu Bytes\n", BytesReceived);
1750 RTPrintf("Speed: %llu B/s\n", ThroughputReceive);
1751 RTPrintf("Received total: %llu Bytes\n", BytesReceivedTotal);
1752 }
1753
1754 if (Active)
1755 {
1756 if (details == VMINFO_MACHINEREADABLE)
1757 {
1758 RTPrintf("VRDPUserName=\"%lS\"\n", User.raw());
1759 RTPrintf("VRDPDomain=\"%lS\"\n", Domain.raw());
1760 RTPrintf("VRDPClientName=\"%lS\"\n", ClientName.raw());
1761 RTPrintf("VRDPClientIP=\"%lS\"\n", ClientIP.raw());
1762 RTPrintf("VRDPClientVersion=%d\n", ClientVersion);
1763 RTPrintf("VRDPEncryption=\"%s\"\n", EncryptionStyle == 0? "RDP4": "RDP5 (X.509)");
1764 }
1765 else
1766 {
1767 RTPrintf("User name: %lS\n", User.raw());
1768 RTPrintf("Domain: %lS\n", Domain.raw());
1769 RTPrintf("Client name: %lS\n", ClientName.raw());
1770 RTPrintf("Client IP: %lS\n", ClientIP.raw());
1771 RTPrintf("Client version: %d\n", ClientVersion);
1772 RTPrintf("Encryption: %s\n", EncryptionStyle == 0? "RDP4": "RDP5 (X.509)");
1773 }
1774 }
1775 }
1776
1777 if (details != VMINFO_MACHINEREADABLE)
1778 RTPrintf("\n");
1779 }
1780
1781 if ( details == VMINFO_STANDARD
1782 || details == VMINFO_FULL
1783 || details == VMINFO_MACHINEREADABLE)
1784 {
1785 Bstr description;
1786 machine->COMGETTER(Description)(description.asOutParam());
1787 if (!description.isEmpty())
1788 {
1789 if (details == VMINFO_MACHINEREADABLE)
1790 RTPrintf("description=\"%lS\"\n", description.raw());
1791 else
1792 RTPrintf("Description:\n%lS\n", description.raw());
1793 }
1794 }
1795
1796 ULONG guestVal;
1797 if (details != VMINFO_MACHINEREADABLE)
1798 RTPrintf("Guest:\n\n");
1799
1800 rc = machine->COMGETTER(MemoryBalloonSize)(&guestVal);
1801 if (SUCCEEDED(rc))
1802 {
1803 if (details == VMINFO_MACHINEREADABLE)
1804 RTPrintf("GuestMemoryBalloon=%d\n", guestVal);
1805 else
1806 RTPrintf("Configured memory balloon size: %d MB\n", guestVal);
1807 }
1808 rc = machine->COMGETTER(StatisticsUpdateInterval)(&guestVal);
1809 if (SUCCEEDED(rc))
1810 {
1811 if (details == VMINFO_MACHINEREADABLE)
1812 RTPrintf("GuestStatisticsUpdateInterval=%d\n", guestVal);
1813 else
1814 {
1815 if (guestVal == 0)
1816 RTPrintf("Statistics update: disabled\n");
1817 else
1818 RTPrintf("Statistics update interval: %d seconds\n", guestVal);
1819 }
1820 }
1821 if (details != VMINFO_MACHINEREADABLE)
1822 RTPrintf("\n");
1823
1824 if ( console
1825 && ( details == VMINFO_STATISTICS
1826 || details == VMINFO_FULL
1827 || details == VMINFO_MACHINEREADABLE))
1828 {
1829 ComPtr <IGuest> guest;
1830
1831 rc = console->COMGETTER(Guest)(guest.asOutParam());
1832 if (SUCCEEDED(rc))
1833 {
1834 ULONG statVal;
1835
1836 rc = guest->GetStatistic(0, GuestStatisticType_SampleNumber, &statVal);
1837 if (SUCCEEDED(rc))
1838 {
1839 if (details == VMINFO_MACHINEREADABLE)
1840 RTPrintf("StatGuestSample=%d\n", statVal);
1841 else
1842 RTPrintf("Guest statistics for sample %d:\n\n", statVal);
1843 }
1844
1845 rc = guest->GetStatistic(0, GuestStatisticType_CPULoad_Idle, &statVal);
1846 if (SUCCEEDED(rc))
1847 {
1848 if (details == VMINFO_MACHINEREADABLE)
1849 RTPrintf("StatGuestLoadIdleCPU%d=%d\n", 0, statVal);
1850 else
1851 RTPrintf("CPU%d: CPU Load Idle %-3d%%\n", 0, statVal);
1852 }
1853
1854 rc = guest->GetStatistic(0, GuestStatisticType_CPULoad_Kernel, &statVal);
1855 if (SUCCEEDED(rc))
1856 {
1857 if (details == VMINFO_MACHINEREADABLE)
1858 RTPrintf("StatGuestLoadKernelCPU%d=%d\n", 0, statVal);
1859 else
1860 RTPrintf("CPU%d: CPU Load Kernel %-3d%%\n", 0, statVal);
1861 }
1862
1863 rc = guest->GetStatistic(0, GuestStatisticType_CPULoad_User, &statVal);
1864 if (SUCCEEDED(rc))
1865 {
1866 if (details == VMINFO_MACHINEREADABLE)
1867 RTPrintf("StatGuestLoadUserCPU%d=%d\n", 0, statVal);
1868 else
1869 RTPrintf("CPU%d: CPU Load User %-3d%%\n", 0, statVal);
1870 }
1871
1872 rc = guest->GetStatistic(0, GuestStatisticType_Threads, &statVal);
1873 if (SUCCEEDED(rc))
1874 {
1875 if (details == VMINFO_MACHINEREADABLE)
1876 RTPrintf("StatGuestThreadsCPU%d=%d\n", 0, statVal);
1877 else
1878 RTPrintf("CPU%d: Threads %d\n", 0, statVal);
1879 }
1880
1881 rc = guest->GetStatistic(0, GuestStatisticType_Processes, &statVal);
1882 if (SUCCEEDED(rc))
1883 {
1884 if (details == VMINFO_MACHINEREADABLE)
1885 RTPrintf("StatGuestProcessesCPU%d=%d\n", 0, statVal);
1886 else
1887 RTPrintf("CPU%d: Processes %d\n", 0, statVal);
1888 }
1889
1890 rc = guest->GetStatistic(0, GuestStatisticType_Handles, &statVal);
1891 if (SUCCEEDED(rc))
1892 {
1893 if (details == VMINFO_MACHINEREADABLE)
1894 RTPrintf("StatGuestHandlesCPU%d=%d\n", 0, statVal);
1895 else
1896 RTPrintf("CPU%d: Handles %d\n", 0, statVal);
1897 }
1898
1899 rc = guest->GetStatistic(0, GuestStatisticType_MemoryLoad, &statVal);
1900 if (SUCCEEDED(rc))
1901 {
1902 if (details == VMINFO_MACHINEREADABLE)
1903 RTPrintf("StatGuestMemoryLoadCPU%d=%d\n", 0, statVal);
1904 else
1905 RTPrintf("CPU%d: Memory Load %d%%\n", 0, statVal);
1906 }
1907
1908 rc = guest->GetStatistic(0, GuestStatisticType_PhysMemTotal, &statVal);
1909 if (SUCCEEDED(rc))
1910 {
1911 if (details == VMINFO_MACHINEREADABLE)
1912 RTPrintf("StatGuestMemoryTotalPhysCPU%d=%d\n", 0, statVal);
1913 else
1914 RTPrintf("CPU%d: Total physical memory %-4d MB\n", 0, statVal);
1915 }
1916
1917 rc = guest->GetStatistic(0, GuestStatisticType_PhysMemAvailable, &statVal);
1918 if (SUCCEEDED(rc))
1919 {
1920 if (details == VMINFO_MACHINEREADABLE)
1921 RTPrintf("StatGuestMemoryFreePhysCPU%d=%d\n", 0, statVal);
1922 else
1923 RTPrintf("CPU%d: Free physical memory %-4d MB\n", 0, statVal);
1924 }
1925
1926 rc = guest->GetStatistic(0, GuestStatisticType_PhysMemBalloon, &statVal);
1927 if (SUCCEEDED(rc))
1928 {
1929 if (details == VMINFO_MACHINEREADABLE)
1930 RTPrintf("StatGuestMemoryBalloonCPU%d=%d\n", 0, statVal);
1931 else
1932 RTPrintf("CPU%d: Memory balloon size %-4d MB\n", 0, statVal);
1933 }
1934
1935 rc = guest->GetStatistic(0, GuestStatisticType_MemCommitTotal, &statVal);
1936 if (SUCCEEDED(rc))
1937 {
1938 if (details == VMINFO_MACHINEREADABLE)
1939 RTPrintf("StatGuestMemoryCommittedCPU%d=%d\n", 0, statVal);
1940 else
1941 RTPrintf("CPU%d: Committed memory %-4d MB\n", 0, statVal);
1942 }
1943
1944 rc = guest->GetStatistic(0, GuestStatisticType_MemKernelTotal, &statVal);
1945 if (SUCCEEDED(rc))
1946 {
1947 if (details == VMINFO_MACHINEREADABLE)
1948 RTPrintf("StatGuestMemoryTotalKernelCPU%d=%d\n", 0, statVal);
1949 else
1950 RTPrintf("CPU%d: Total kernel memory %-4d MB\n", 0, statVal);
1951 }
1952
1953 rc = guest->GetStatistic(0, GuestStatisticType_MemKernelPaged, &statVal);
1954 if (SUCCEEDED(rc))
1955 {
1956 if (details == VMINFO_MACHINEREADABLE)
1957 RTPrintf("StatGuestMemoryPagedKernelCPU%d=%d\n", 0, statVal);
1958 else
1959 RTPrintf("CPU%d: Paged kernel memory %-4d MB\n", 0, statVal);
1960 }
1961
1962 rc = guest->GetStatistic(0, GuestStatisticType_MemKernelNonpaged, &statVal);
1963 if (SUCCEEDED(rc))
1964 {
1965 if (details == VMINFO_MACHINEREADABLE)
1966 RTPrintf("StatGuestMemoryNonpagedKernelCPU%d=%d\n", 0, statVal);
1967 else
1968 RTPrintf("CPU%d: Nonpaged kernel memory %-4d MB\n", 0, statVal);
1969 }
1970
1971 rc = guest->GetStatistic(0, GuestStatisticType_MemSystemCache, &statVal);
1972 if (SUCCEEDED(rc))
1973 {
1974 if (details == VMINFO_MACHINEREADABLE)
1975 RTPrintf("StatGuestSystemCacheSizeCPU%d=%d\n", 0, statVal);
1976 else
1977 RTPrintf("CPU%d: System cache size %-4d MB\n", 0, statVal);
1978 }
1979
1980 rc = guest->GetStatistic(0, GuestStatisticType_PageFileSize, &statVal);
1981 if (SUCCEEDED(rc))
1982 {
1983 if (details == VMINFO_MACHINEREADABLE)
1984 RTPrintf("StatGuestPageFileSizeCPU%d=%d\n", 0, statVal);
1985 else
1986 RTPrintf("CPU%d: Page file size %-4d MB\n", 0, statVal);
1987 }
1988
1989 RTPrintf("\n");
1990 }
1991 else
1992 {
1993 if (details != VMINFO_MACHINEREADABLE)
1994 {
1995 RTPrintf("[!] FAILED calling console->getGuest at line %d!\n", __LINE__);
1996 GluePrintRCMessage(rc);
1997 }
1998 }
1999 }
2000
2001 /*
2002 * snapshots
2003 */
2004 ComPtr<ISnapshot> snapshot;
2005 rc = machine->GetSnapshot(Bstr(), snapshot.asOutParam());
2006 if (SUCCEEDED(rc) && snapshot)
2007 {
2008 ComPtr<ISnapshot> currentSnapshot;
2009 rc = machine->COMGETTER(CurrentSnapshot)(currentSnapshot.asOutParam());
2010 if (SUCCEEDED(rc))
2011 {
2012 if (details != VMINFO_MACHINEREADABLE)
2013 RTPrintf("Snapshots:\n\n");
2014 showSnapshots(snapshot, currentSnapshot, details);
2015 }
2016 }
2017
2018 if (details != VMINFO_MACHINEREADABLE)
2019 RTPrintf("\n");
2020 return S_OK;
2021}
2022
2023#if defined(_MSC_VER)
2024# pragma optimize("", on)
2025#endif
2026
2027static const RTGETOPTDEF g_aShowVMInfoOptions[] =
2028{
2029 { "--details", 'D', RTGETOPT_REQ_NOTHING },
2030 { "-details", 'D', RTGETOPT_REQ_NOTHING }, // deprecated
2031 { "--statistics", 'S', RTGETOPT_REQ_NOTHING },
2032 { "-statistics", 'S', RTGETOPT_REQ_NOTHING }, // deprecated
2033 { "--machinereadable", 'M', RTGETOPT_REQ_NOTHING },
2034 { "-machinereadable", 'M', RTGETOPT_REQ_NOTHING }, // deprecated
2035};
2036
2037int handleShowVMInfo(HandlerArg *a)
2038{
2039 HRESULT rc;
2040 const char *VMNameOrUuid = NULL;
2041 bool fDetails = false;
2042 bool fStatistics = false;
2043 bool fMachinereadable = false;
2044
2045 int c;
2046 RTGETOPTUNION ValueUnion;
2047 RTGETOPTSTATE GetState;
2048 // start at 0 because main() has hacked both the argc and argv given to us
2049 RTGetOptInit(&GetState, a->argc, a->argv, g_aShowVMInfoOptions, RT_ELEMENTS(g_aShowVMInfoOptions),
2050 0, RTGETOPTINIT_FLAGS_NO_STD_OPTS);
2051 while ((c = RTGetOpt(&GetState, &ValueUnion)))
2052 {
2053 switch (c)
2054 {
2055 case 'D': // --details
2056 fDetails = true;
2057 break;
2058
2059 case 'S': // --statistics
2060 fStatistics = true;
2061 break;
2062
2063 case 'M': // --machinereadable
2064 fMachinereadable = true;
2065 break;
2066
2067 case VINF_GETOPT_NOT_OPTION:
2068 if (!VMNameOrUuid)
2069 VMNameOrUuid = ValueUnion.psz;
2070 else
2071 return errorSyntax(USAGE_SHOWVMINFO, "Invalid parameter '%s'", ValueUnion.psz);
2072 break;
2073
2074 default:
2075 if (c > 0)
2076 {
2077 if (RT_C_IS_PRINT(c))
2078 return errorSyntax(USAGE_SHOWVMINFO, "Invalid option -%c", c);
2079 else
2080 return errorSyntax(USAGE_SHOWVMINFO, "Invalid option case %i", c);
2081 }
2082 else if (c == VERR_GETOPT_UNKNOWN_OPTION)
2083 return errorSyntax(USAGE_SHOWVMINFO, "unknown option: %s\n", ValueUnion.psz);
2084 else if (ValueUnion.pDef)
2085 return errorSyntax(USAGE_SHOWVMINFO, "%s: %Rrs", ValueUnion.pDef->pszLong, c);
2086 else
2087 return errorSyntax(USAGE_SHOWVMINFO, "error: %Rrs", c);
2088 }
2089 }
2090
2091 /* check for required options */
2092 if (!VMNameOrUuid)
2093 return errorSyntax(USAGE_SHOWVMINFO, "VM name or UUID required");
2094
2095 /* try to find the given machine */
2096 ComPtr <IMachine> machine;
2097 Bstr uuid (VMNameOrUuid);
2098 if (!Guid (VMNameOrUuid).isEmpty())
2099 {
2100 CHECK_ERROR (a->virtualBox, GetMachine (uuid, machine.asOutParam()));
2101 }
2102 else
2103 {
2104 CHECK_ERROR (a->virtualBox, FindMachine (Bstr(VMNameOrUuid), machine.asOutParam()));
2105 if (SUCCEEDED (rc))
2106 machine->COMGETTER(Id) (uuid.asOutParam());
2107 }
2108 if (FAILED (rc))
2109 return 1;
2110
2111 /* 2nd option can be -details, -statistics or -argdump */
2112 VMINFO_DETAILS details = VMINFO_NONE;
2113 if (fMachinereadable)
2114 details = VMINFO_MACHINEREADABLE;
2115 else
2116 if (fDetails && fStatistics)
2117 details = VMINFO_FULL;
2118 else
2119 if (fDetails)
2120 details = VMINFO_STANDARD;
2121 else
2122 if (fStatistics)
2123 details = VMINFO_STATISTICS;
2124
2125 ComPtr <IConsole> console;
2126
2127 /* open an existing session for the VM */
2128 rc = a->virtualBox->OpenExistingSession (a->session, uuid);
2129 if (SUCCEEDED(rc))
2130 /* get the session machine */
2131 rc = a->session->COMGETTER(Machine)(machine.asOutParam());
2132 if (SUCCEEDED(rc))
2133 /* get the session console */
2134 rc = a->session->COMGETTER(Console)(console.asOutParam());
2135
2136 rc = showVMInfo(a->virtualBox, machine, details, console);
2137
2138 if (console)
2139 a->session->Close();
2140
2141 return SUCCEEDED (rc) ? 0 : 1;
2142}
2143
2144#endif /* !VBOX_ONLY_DOCS */
2145/* vi: set tabstop=4 shiftwidth=4 expandtab: */
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