VirtualBox

source: vbox/trunk/include/VBox/settings.h@ 43414

Last change on this file since 43414 was 43041, checked in by vboxsync, 12 years ago

Main/VirtualBox: final API change, cleans up optional parameters to IVirtualBox::createMachine, preparing for adding more flags.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Date Revision Author Id
File size: 38.3 KB
Line 
1/** @file
2 * Settings file data structures.
3 *
4 * These structures are created by the settings file loader and filled with values
5 * copied from the raw XML data. This was all new with VirtualBox 3.1 and allows us
6 * to finally make the XML reader version-independent and read VirtualBox XML files
7 * from earlier and even newer (future) versions without requiring complicated,
8 * tedious and error-prone XSLT conversions.
9 *
10 * It is this file that defines all structures that map VirtualBox global and
11 * machine settings to XML files. These structures are used by the rest of Main,
12 * even though this header file does not require anything else in Main.
13 *
14 * Note: Headers in Main code have been tweaked to only declare the structures
15 * defined here so that this header need only be included from code files that
16 * actually use these structures.
17 */
18
19/*
20 * Copyright (C) 2007-2012 Oracle Corporation
21 *
22 * This file is part of VirtualBox Open Source Edition (OSE), as
23 * available from http://www.virtualbox.org. This file is free software;
24 * you can redistribute it and/or modify it under the terms of the GNU
25 * General Public License (GPL) as published by the Free Software
26 * Foundation, in version 2 as it comes in the "COPYING" file of the
27 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
28 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
29 *
30 * The contents of this file may alternatively be used under the terms
31 * of the Common Development and Distribution License Version 1.0
32 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
33 * VirtualBox OSE distribution, in which case the provisions of the
34 * CDDL are applicable instead of those of the GPL.
35 *
36 * You may elect to license modified versions of this file under the
37 * terms and conditions of either the GPL or the CDDL or both.
38 */
39
40#ifndef ___VBox_settings_h
41#define ___VBox_settings_h
42
43#include <iprt/time.h>
44
45#include "VBox/com/VirtualBox.h"
46
47#include <VBox/com/Guid.h>
48#include <VBox/com/string.h>
49
50#include <list>
51#include <map>
52
53namespace xml
54{
55 class ElementNode;
56}
57
58namespace settings
59{
60
61class ConfigFileError;
62
63////////////////////////////////////////////////////////////////////////////////
64//
65// Structures shared between Machine XML and VirtualBox.xml
66//
67////////////////////////////////////////////////////////////////////////////////
68
69/**
70 * USB device filter definition. This struct is used both in MainConfigFile
71 * (for global USB filters) and MachineConfigFile (for machine filters).
72 *
73 * NOTE: If you add any fields in here, you must update a) the constructor and b)
74 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
75 * your settings might never get saved.
76 */
77struct USBDeviceFilter
78{
79 USBDeviceFilter()
80 : fActive(false),
81 action(USBDeviceFilterAction_Null),
82 ulMaskedInterfaces(0)
83 {}
84
85 bool operator==(const USBDeviceFilter&u) const;
86
87 com::Utf8Str strName;
88 bool fActive;
89 com::Utf8Str strVendorId,
90 strProductId,
91 strRevision,
92 strManufacturer,
93 strProduct,
94 strSerialNumber,
95 strPort;
96 USBDeviceFilterAction_T action; // only used with host USB filters
97 com::Utf8Str strRemote; // irrelevant for host USB objects
98 uint32_t ulMaskedInterfaces; // irrelevant for host USB objects
99};
100
101typedef std::map<com::Utf8Str, com::Utf8Str> StringsMap;
102typedef std::list<com::Utf8Str> StringsList;
103
104// ExtraDataItem (used by both VirtualBox.xml and machines XML)
105struct USBDeviceFilter;
106typedef std::list<USBDeviceFilter> USBDeviceFiltersList;
107
108struct Medium;
109typedef std::list<Medium> MediaList;
110
111/**
112 * NOTE: If you add any fields in here, you must update a) the constructor and b)
113 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
114 * your settings might never get saved.
115 */
116struct Medium
117{
118 Medium()
119 : fAutoReset(false),
120 hdType(MediumType_Normal)
121 {}
122
123 com::Guid uuid;
124 com::Utf8Str strLocation;
125 com::Utf8Str strDescription;
126
127 // the following are for hard disks only:
128 com::Utf8Str strFormat;
129 bool fAutoReset; // optional, only for diffs, default is false
130 StringsMap properties;
131 MediumType_T hdType;
132
133 MediaList llChildren; // only used with hard disks
134
135 bool operator==(const Medium &m) const;
136};
137
138/**
139 * A media registry. Starting with VirtualBox 3.3, this can appear in both the
140 * VirtualBox.xml file as well as machine XML files with settings version 1.11
141 * or higher, so these lists are now in ConfigFileBase.
142 *
143 * NOTE: If you add any fields in here, you must update a) the constructor and b)
144 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
145 * your settings might never get saved.
146 */
147struct MediaRegistry
148{
149 MediaList llHardDisks,
150 llDvdImages,
151 llFloppyImages;
152
153 bool operator==(const MediaRegistry &m) const;
154};
155
156/**
157 * Common base class for both MainConfigFile and MachineConfigFile
158 * which contains some common logic for both.
159 */
160class ConfigFileBase
161{
162public:
163 bool fileExists();
164
165 void copyBaseFrom(const ConfigFileBase &b);
166
167protected:
168 ConfigFileBase(const com::Utf8Str *pstrFilename);
169 /* Note: this copy constructor doesn't create a full copy of other, cause
170 * the file based stuff (xml doc) could not be copied. */
171 ConfigFileBase(const ConfigFileBase &other);
172
173 ~ConfigFileBase();
174
175 void parseUUID(com::Guid &guid,
176 const com::Utf8Str &strUUID) const;
177 void parseTimestamp(RTTIMESPEC &timestamp,
178 const com::Utf8Str &str) const;
179
180 com::Utf8Str makeString(const RTTIMESPEC &tm);
181
182 void readExtraData(const xml::ElementNode &elmExtraData,
183 StringsMap &map);
184 void readUSBDeviceFilters(const xml::ElementNode &elmDeviceFilters,
185 USBDeviceFiltersList &ll);
186 typedef enum {Error, HardDisk, DVDImage, FloppyImage} MediaType;
187 void readMedium(MediaType t, const xml::ElementNode &elmMedium, MediaList &llMedia);
188 void readMediaRegistry(const xml::ElementNode &elmMediaRegistry, MediaRegistry &mr);
189
190 void setVersionAttribute(xml::ElementNode &elm);
191 void createStubDocument();
192
193 void buildExtraData(xml::ElementNode &elmParent, const StringsMap &me);
194 void buildUSBDeviceFilters(xml::ElementNode &elmParent,
195 const USBDeviceFiltersList &ll,
196 bool fHostMode);
197 void buildMedium(xml::ElementNode &elmMedium,
198 DeviceType_T devType,
199 const Medium &m,
200 uint32_t level);
201 void buildMediaRegistry(xml::ElementNode &elmParent,
202 const MediaRegistry &mr);
203 void clearDocument();
204
205 struct Data;
206 Data *m;
207
208 friend class ConfigFileError;
209};
210
211////////////////////////////////////////////////////////////////////////////////
212//
213// VirtualBox.xml structures
214//
215////////////////////////////////////////////////////////////////////////////////
216
217struct Host
218{
219 USBDeviceFiltersList llUSBDeviceFilters;
220};
221
222struct SystemProperties
223{
224 SystemProperties()
225 : ulLogHistoryCount(3)
226 {}
227
228 com::Utf8Str strDefaultMachineFolder;
229 com::Utf8Str strDefaultHardDiskFolder;
230 com::Utf8Str strDefaultHardDiskFormat;
231 com::Utf8Str strVRDEAuthLibrary;
232 com::Utf8Str strWebServiceAuthLibrary;
233 com::Utf8Str strDefaultVRDEExtPack;
234 com::Utf8Str strAutostartDatabasePath;
235 com::Utf8Str strDefaultAdditionsISO;
236 uint32_t ulLogHistoryCount;
237};
238
239struct MachineRegistryEntry
240{
241 com::Guid uuid;
242 com::Utf8Str strSettingsFile;
243};
244typedef std::list<MachineRegistryEntry> MachinesRegistry;
245
246struct DHCPServer
247{
248 DHCPServer()
249 : fEnabled(false)
250 {}
251
252 com::Utf8Str strNetworkName,
253 strIPAddress,
254 strIPNetworkMask,
255 strIPLower,
256 strIPUpper;
257 bool fEnabled;
258};
259typedef std::list<DHCPServer> DHCPServersList;
260
261class MainConfigFile : public ConfigFileBase
262{
263public:
264 MainConfigFile(const com::Utf8Str *pstrFilename);
265
266 void readMachineRegistry(const xml::ElementNode &elmMachineRegistry);
267 void readDHCPServers(const xml::ElementNode &elmDHCPServers);
268
269 void write(const com::Utf8Str strFilename);
270
271 Host host;
272 SystemProperties systemProperties;
273 MediaRegistry mediaRegistry;
274 MachinesRegistry llMachines;
275 DHCPServersList llDhcpServers;
276 StringsMap mapExtraDataItems;
277};
278
279////////////////////////////////////////////////////////////////////////////////
280//
281// Machine XML structures
282//
283////////////////////////////////////////////////////////////////////////////////
284
285/**
286 * NOTE: If you add any fields in here, you must update a) the constructor and b)
287 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
288 * your settings might never get saved.
289 */
290struct VRDESettings
291{
292 VRDESettings()
293 : fEnabled(true),
294 authType(AuthType_Null),
295 ulAuthTimeout(5000),
296 fAllowMultiConnection(false),
297 fReuseSingleConnection(false)
298 {}
299
300 bool operator==(const VRDESettings& v) const;
301
302 bool fEnabled;
303 AuthType_T authType;
304 uint32_t ulAuthTimeout;
305 com::Utf8Str strAuthLibrary;
306 bool fAllowMultiConnection,
307 fReuseSingleConnection;
308 com::Utf8Str strVrdeExtPack;
309 StringsMap mapProperties;
310};
311
312/**
313 * NOTE: If you add any fields in here, you must update a) the constructor and b)
314 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
315 * your settings might never get saved.
316 */
317struct BIOSSettings
318{
319 BIOSSettings()
320 : fACPIEnabled(true),
321 fIOAPICEnabled(false),
322 fLogoFadeIn(true),
323 fLogoFadeOut(true),
324 ulLogoDisplayTime(0),
325 biosBootMenuMode(BIOSBootMenuMode_MessageAndMenu),
326 fPXEDebugEnabled(false),
327 llTimeOffset(0)
328 {}
329
330 bool operator==(const BIOSSettings &d) const;
331
332 bool fACPIEnabled,
333 fIOAPICEnabled,
334 fLogoFadeIn,
335 fLogoFadeOut;
336 uint32_t ulLogoDisplayTime;
337 com::Utf8Str strLogoImagePath;
338 BIOSBootMenuMode_T biosBootMenuMode;
339 bool fPXEDebugEnabled;
340 int64_t llTimeOffset;
341};
342
343/**
344 * NOTE: If you add any fields in here, you must update a) the constructor and b)
345 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
346 * your settings might never get saved.
347 */
348struct USBController
349{
350 USBController()
351 : fEnabled(false),
352 fEnabledEHCI(false)
353 {}
354
355 bool operator==(const USBController &u) const;
356
357 bool fEnabled;
358 bool fEnabledEHCI;
359 USBDeviceFiltersList llDeviceFilters;
360};
361
362 struct NATRule
363 {
364 NATRule()
365 : proto(NATProtocol_TCP),
366 u16HostPort(0),
367 u16GuestPort(0)
368 {}
369
370 bool operator==(const NATRule &r) const
371 {
372 return strName == r.strName
373 && proto == r.proto
374 && u16HostPort == r.u16HostPort
375 && strHostIP == r.strHostIP
376 && u16GuestPort == r.u16GuestPort
377 && strGuestIP == r.strGuestIP;
378 }
379
380 com::Utf8Str strName;
381 NATProtocol_T proto;
382 uint16_t u16HostPort;
383 com::Utf8Str strHostIP;
384 uint16_t u16GuestPort;
385 com::Utf8Str strGuestIP;
386 };
387 typedef std::list<NATRule> NATRuleList;
388
389 struct NAT
390 {
391 NAT()
392 : u32Mtu(0),
393 u32SockRcv(0),
394 u32SockSnd(0),
395 u32TcpRcv(0),
396 u32TcpSnd(0),
397 fDNSPassDomain(true), /* historically this value is true */
398 fDNSProxy(false),
399 fDNSUseHostResolver(false),
400 fAliasLog(false),
401 fAliasProxyOnly(false),
402 fAliasUseSamePorts(false)
403 {}
404
405 bool operator==(const NAT &n) const
406 {
407 return strNetwork == n.strNetwork
408 && strBindIP == n.strBindIP
409 && u32Mtu == n.u32Mtu
410 && u32SockRcv == n.u32SockRcv
411 && u32SockSnd == n.u32SockSnd
412 && u32TcpSnd == n.u32TcpSnd
413 && u32TcpRcv == n.u32TcpRcv
414 && strTFTPPrefix == n.strTFTPPrefix
415 && strTFTPBootFile == n.strTFTPBootFile
416 && strTFTPNextServer == n.strTFTPNextServer
417 && fDNSPassDomain == n.fDNSPassDomain
418 && fDNSProxy == n.fDNSProxy
419 && fDNSUseHostResolver == n.fDNSUseHostResolver
420 && fAliasLog == n.fAliasLog
421 && fAliasProxyOnly == n.fAliasProxyOnly
422 && fAliasUseSamePorts == n.fAliasUseSamePorts
423 && llRules == n.llRules;
424 }
425
426 com::Utf8Str strNetwork;
427 com::Utf8Str strBindIP;
428 uint32_t u32Mtu;
429 uint32_t u32SockRcv;
430 uint32_t u32SockSnd;
431 uint32_t u32TcpRcv;
432 uint32_t u32TcpSnd;
433 com::Utf8Str strTFTPPrefix;
434 com::Utf8Str strTFTPBootFile;
435 com::Utf8Str strTFTPNextServer;
436 bool fDNSPassDomain;
437 bool fDNSProxy;
438 bool fDNSUseHostResolver;
439 bool fAliasLog;
440 bool fAliasProxyOnly;
441 bool fAliasUseSamePorts;
442 NATRuleList llRules;
443 };
444/**
445 * NOTE: If you add any fields in here, you must update a) the constructor and b)
446 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
447 * your settings might never get saved.
448 */
449struct NetworkAdapter
450{
451 NetworkAdapter()
452 : ulSlot(0),
453 type(NetworkAdapterType_Am79C970A),
454 fEnabled(false),
455 fCableConnected(false),
456 ulLineSpeed(0),
457 enmPromiscModePolicy(NetworkAdapterPromiscModePolicy_Deny),
458 fTraceEnabled(false),
459 mode(NetworkAttachmentType_Null),
460 ulBootPriority(0)
461 {}
462
463 bool operator==(const NetworkAdapter &n) const;
464
465 uint32_t ulSlot;
466
467 NetworkAdapterType_T type;
468 bool fEnabled;
469 com::Utf8Str strMACAddress;
470 bool fCableConnected;
471 uint32_t ulLineSpeed;
472 NetworkAdapterPromiscModePolicy_T enmPromiscModePolicy;
473 bool fTraceEnabled;
474 com::Utf8Str strTraceFile;
475
476 NetworkAttachmentType_T mode;
477 NAT nat;
478 com::Utf8Str strBridgedName;
479 com::Utf8Str strHostOnlyName;
480 com::Utf8Str strInternalNetworkName;
481 com::Utf8Str strGenericDriver;
482 StringsMap genericProperties;
483 uint32_t ulBootPriority;
484 com::Utf8Str strBandwidthGroup; // requires settings version 1.13 (VirtualBox 4.2)
485};
486typedef std::list<NetworkAdapter> NetworkAdaptersList;
487
488/**
489 * NOTE: If you add any fields in here, you must update a) the constructor and b)
490 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
491 * your settings might never get saved.
492 */
493struct SerialPort
494{
495 SerialPort()
496 : ulSlot(0),
497 fEnabled(false),
498 ulIOBase(0x3f8),
499 ulIRQ(4),
500 portMode(PortMode_Disconnected),
501 fServer(false)
502 {}
503
504 bool operator==(const SerialPort &n) const;
505
506 uint32_t ulSlot;
507
508 bool fEnabled;
509 uint32_t ulIOBase;
510 uint32_t ulIRQ;
511 PortMode_T portMode;
512 com::Utf8Str strPath;
513 bool fServer;
514};
515typedef std::list<SerialPort> SerialPortsList;
516
517/**
518 * NOTE: If you add any fields in here, you must update a) the constructor and b)
519 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
520 * your settings might never get saved.
521 */
522struct ParallelPort
523{
524 ParallelPort()
525 : ulSlot(0),
526 fEnabled(false),
527 ulIOBase(0x378),
528 ulIRQ(7)
529 {}
530
531 bool operator==(const ParallelPort &d) const;
532
533 uint32_t ulSlot;
534
535 bool fEnabled;
536 uint32_t ulIOBase;
537 uint32_t ulIRQ;
538 com::Utf8Str strPath;
539};
540typedef std::list<ParallelPort> ParallelPortsList;
541
542/**
543 * NOTE: If you add any fields in here, you must update a) the constructor and b)
544 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
545 * your settings might never get saved.
546 */
547struct AudioAdapter
548{
549 AudioAdapter()
550 : fEnabled(true),
551 controllerType(AudioControllerType_AC97),
552 driverType(AudioDriverType_Null)
553 {}
554
555 bool operator==(const AudioAdapter &a) const
556 {
557 return (this == &a)
558 || ( (fEnabled == a.fEnabled)
559 && (controllerType == a.controllerType)
560 && (driverType == a.driverType)
561 );
562 }
563
564 bool fEnabled;
565 AudioControllerType_T controllerType;
566 AudioDriverType_T driverType;
567};
568
569/**
570 * NOTE: If you add any fields in here, you must update a) the constructor and b)
571 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
572 * your settings might never get saved.
573 */
574struct SharedFolder
575{
576 SharedFolder()
577 : fWritable(false)
578 , fAutoMount(false)
579 {}
580
581 bool operator==(const SharedFolder &a) const;
582
583 com::Utf8Str strName,
584 strHostPath;
585 bool fWritable;
586 bool fAutoMount;
587};
588typedef std::list<SharedFolder> SharedFoldersList;
589
590/**
591 * NOTE: If you add any fields in here, you must update a) the constructor and b)
592 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
593 * your settings might never get saved.
594 */
595struct GuestProperty
596{
597 GuestProperty()
598 : timestamp(0)
599 {};
600
601 bool operator==(const GuestProperty &g) const;
602
603 com::Utf8Str strName,
604 strValue;
605 uint64_t timestamp;
606 com::Utf8Str strFlags;
607};
608typedef std::list<GuestProperty> GuestPropertiesList;
609
610typedef std::map<uint32_t, DeviceType_T> BootOrderMap;
611
612/**
613 * NOTE: If you add any fields in here, you must update a) the constructor and b)
614 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
615 * your settings might never get saved.
616 */
617struct CpuIdLeaf
618{
619 CpuIdLeaf()
620 : ulId(UINT32_MAX),
621 ulEax(0),
622 ulEbx(0),
623 ulEcx(0),
624 ulEdx(0)
625 {}
626
627 bool operator==(const CpuIdLeaf &c) const
628 {
629 return ( (this == &c)
630 || ( (ulId == c.ulId)
631 && (ulEax == c.ulEax)
632 && (ulEbx == c.ulEbx)
633 && (ulEcx == c.ulEcx)
634 && (ulEdx == c.ulEdx)
635 )
636 );
637 }
638
639 uint32_t ulId;
640 uint32_t ulEax;
641 uint32_t ulEbx;
642 uint32_t ulEcx;
643 uint32_t ulEdx;
644};
645typedef std::list<CpuIdLeaf> CpuIdLeafsList;
646
647/**
648 * NOTE: If you add any fields in here, you must update a) the constructor and b)
649 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
650 * your settings might never get saved.
651 */
652struct Cpu
653{
654 Cpu()
655 : ulId(UINT32_MAX)
656 {}
657
658 bool operator==(const Cpu &c) const
659 {
660 return (ulId == c.ulId);
661 }
662
663 uint32_t ulId;
664};
665typedef std::list<Cpu> CpuList;
666
667/**
668 * NOTE: If you add any fields in here, you must update a) the constructor and b)
669 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
670 * your settings might never get saved.
671 */
672struct BandwidthGroup
673{
674 BandwidthGroup()
675 : cMaxBytesPerSec(0),
676 enmType(BandwidthGroupType_Null)
677 {}
678
679 bool operator==(const BandwidthGroup &i) const
680 {
681 return ( (strName == i.strName)
682 && (cMaxBytesPerSec == i.cMaxBytesPerSec)
683 && (enmType == i.enmType));
684 }
685
686 com::Utf8Str strName;
687 uint64_t cMaxBytesPerSec;
688 BandwidthGroupType_T enmType;
689};
690typedef std::list<BandwidthGroup> BandwidthGroupList;
691
692/**
693 * NOTE: If you add any fields in here, you must update a) the constructor and b)
694 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
695 * your settings might never get saved.
696 */
697struct IOSettings
698{
699 IOSettings();
700
701 bool operator==(const IOSettings &i) const
702 {
703 return ( (fIOCacheEnabled == i.fIOCacheEnabled)
704 && (ulIOCacheSize == i.ulIOCacheSize)
705 && (llBandwidthGroups == i.llBandwidthGroups));
706 }
707
708 bool fIOCacheEnabled;
709 uint32_t ulIOCacheSize;
710 BandwidthGroupList llBandwidthGroups;
711};
712
713/**
714 * NOTE: If you add any fields in here, you must update a) the constructor and b)
715 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
716 * your settings might never get saved.
717 */
718struct HostPCIDeviceAttachment
719{
720 HostPCIDeviceAttachment()
721 : uHostAddress(0),
722 uGuestAddress(0)
723 {}
724
725 bool operator==(const HostPCIDeviceAttachment &a) const
726 {
727 return ( (uHostAddress == a.uHostAddress)
728 && (uGuestAddress == a.uGuestAddress)
729 && (strDeviceName == a.strDeviceName)
730 );
731 }
732
733 com::Utf8Str strDeviceName;
734 uint32_t uHostAddress;
735 uint32_t uGuestAddress;
736};
737typedef std::list<HostPCIDeviceAttachment> HostPCIDeviceAttachmentList;
738
739/**
740 * Representation of Machine hardware; this is used in the MachineConfigFile.hardwareMachine
741 * field.
742 *
743 * NOTE: If you add any fields in here, you must update a) the constructor and b)
744 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
745 * your settings might never get saved.
746 */
747struct Hardware
748{
749 Hardware();
750
751 bool operator==(const Hardware&) const;
752
753 com::Utf8Str strVersion; // hardware version, optional
754 com::Guid uuid; // hardware uuid, optional (null).
755
756 bool fHardwareVirt,
757 fHardwareVirtExclusive,
758 fNestedPaging,
759 fLargePages,
760 fVPID,
761 fHardwareVirtForce,
762 fSyntheticCpu,
763 fPAE;
764 uint32_t cCPUs;
765 bool fCpuHotPlug; // requires settings version 1.10 (VirtualBox 3.2)
766 CpuList llCpus; // requires settings version 1.10 (VirtualBox 3.2)
767 bool fHPETEnabled; // requires settings version 1.10 (VirtualBox 3.2)
768 uint32_t ulCpuExecutionCap; // requires settings version 1.11 (VirtualBox 3.3)
769
770 CpuIdLeafsList llCpuIdLeafs;
771
772 uint32_t ulMemorySizeMB;
773
774 BootOrderMap mapBootOrder; // item 0 has highest priority
775
776 uint32_t ulVRAMSizeMB;
777 uint32_t cMonitors;
778 bool fAccelerate3D,
779 fAccelerate2DVideo; // requires settings version 1.8 (VirtualBox 3.1)
780 uint32_t ulVideoCaptureHorzRes;
781 uint32_t ulVideoCaptureVertRes;
782 bool fVideoCaptureEnabled;
783 com::Utf8Str strVideoCaptureFile;
784 FirmwareType_T firmwareType; // requires settings version 1.9 (VirtualBox 3.1)
785
786 PointingHIDType_T pointingHIDType; // requires settings version 1.10 (VirtualBox 3.2)
787 KeyboardHIDType_T keyboardHIDType; // requires settings version 1.10 (VirtualBox 3.2)
788
789 ChipsetType_T chipsetType; // requires settings version 1.11 (VirtualBox 4.0)
790
791 bool fEmulatedUSBCardReader; // 1.12 (VirtualBox 4.1)
792
793 VRDESettings vrdeSettings;
794
795 BIOSSettings biosSettings;
796 USBController usbController;
797 NetworkAdaptersList llNetworkAdapters;
798 SerialPortsList llSerialPorts;
799 ParallelPortsList llParallelPorts;
800 AudioAdapter audioAdapter;
801
802 // technically these two have no business in the hardware section, but for some
803 // clever reason <Hardware> is where they are in the XML....
804 SharedFoldersList llSharedFolders;
805 ClipboardMode_T clipboardMode;
806 DragAndDropMode_T dragAndDropMode;
807
808 uint32_t ulMemoryBalloonSize;
809 bool fPageFusionEnabled;
810
811 GuestPropertiesList llGuestProperties;
812 com::Utf8Str strNotificationPatterns;
813
814 IOSettings ioSettings; // requires settings version 1.10 (VirtualBox 3.2)
815 HostPCIDeviceAttachmentList pciAttachments; // requires settings version 1.12 (VirtualBox 4.1)
816};
817
818/**
819 * A device attached to a storage controller. This can either be a
820 * hard disk or a DVD drive or a floppy drive and also specifies
821 * which medium is "in" the drive; as a result, this is a combination
822 * of the Main IMedium and IMediumAttachment interfaces.
823 *
824 * NOTE: If you add any fields in here, you must update a) the constructor and b)
825 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
826 * your settings might never get saved.
827 */
828struct AttachedDevice
829{
830 AttachedDevice()
831 : deviceType(DeviceType_Null),
832 fPassThrough(false),
833 fTempEject(false),
834 fNonRotational(false),
835 lPort(0),
836 lDevice(0)
837 {}
838
839 bool operator==(const AttachedDevice &a) const;
840
841 DeviceType_T deviceType; // only HardDisk, DVD or Floppy are allowed
842
843 // DVDs can be in pass-through mode:
844 bool fPassThrough;
845
846 // Whether guest-triggered eject of DVDs will keep the medium in the
847 // VM config or not:
848 bool fTempEject;
849
850 // Whether the medium is non-rotational:
851 bool fNonRotational;
852
853 // Whether the medium supports discarding unused blocks:
854 bool fDiscard;
855
856 int32_t lPort;
857 int32_t lDevice;
858
859 // if an image file is attached to the device (ISO, RAW, or hard disk image such as VDI),
860 // this is its UUID; it depends on deviceType which media registry this then needs to
861 // be looked up in. If no image file (only permitted for DVDs and floppies), then the UUID is NULL
862 com::Guid uuid;
863
864 // for DVDs and floppies, the attachment can also be a host device:
865 com::Utf8Str strHostDriveSrc; // if != NULL, value of <HostDrive>/@src
866
867 // Bandwidth group the device is attached to.
868 com::Utf8Str strBwGroup;
869};
870typedef std::list<AttachedDevice> AttachedDevicesList;
871
872/**
873 * NOTE: If you add any fields in here, you must update a) the constructor and b)
874 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
875 * your settings might never get saved.
876 */
877struct StorageController
878{
879 StorageController()
880 : storageBus(StorageBus_IDE),
881 controllerType(StorageControllerType_PIIX3),
882 ulPortCount(2),
883 ulInstance(0),
884 fUseHostIOCache(true),
885 fBootable(true),
886 lIDE0MasterEmulationPort(0),
887 lIDE0SlaveEmulationPort(0),
888 lIDE1MasterEmulationPort(0),
889 lIDE1SlaveEmulationPort(0)
890 {}
891
892 bool operator==(const StorageController &s) const;
893
894 com::Utf8Str strName;
895 StorageBus_T storageBus; // _SATA, _SCSI, _IDE, _SAS
896 StorageControllerType_T controllerType;
897 uint32_t ulPortCount;
898 uint32_t ulInstance;
899 bool fUseHostIOCache;
900 bool fBootable;
901
902 // only for when controllerType == StorageControllerType_IntelAhci:
903 int32_t lIDE0MasterEmulationPort,
904 lIDE0SlaveEmulationPort,
905 lIDE1MasterEmulationPort,
906 lIDE1SlaveEmulationPort;
907
908 AttachedDevicesList llAttachedDevices;
909};
910typedef std::list<StorageController> StorageControllersList;
911
912/**
913 * We wrap the storage controllers list into an extra struct so we can
914 * use an undefined struct without needing std::list<> in all the headers.
915 *
916 * NOTE: If you add any fields in here, you must update a) the constructor and b)
917 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
918 * your settings might never get saved.
919 */
920struct Storage
921{
922 bool operator==(const Storage &s) const;
923
924 StorageControllersList llStorageControllers;
925};
926
927/**
928 * Settings that has to do with debugging.
929 */
930struct Debugging
931{
932 Debugging()
933 : fTracingEnabled(false),
934 fAllowTracingToAccessVM(false),
935 strTracingConfig()
936 { }
937
938 bool operator==(const Debugging &rOther) const
939 {
940 return fTracingEnabled == rOther.fTracingEnabled
941 && fAllowTracingToAccessVM == rOther.fAllowTracingToAccessVM
942 && strTracingConfig == rOther.strTracingConfig;
943 }
944
945 bool areDefaultSettings() const
946 {
947 return !fTracingEnabled
948 && !fAllowTracingToAccessVM
949 && strTracingConfig.isEmpty();
950 }
951
952 bool fTracingEnabled;
953 bool fAllowTracingToAccessVM;
954 com::Utf8Str strTracingConfig;
955};
956
957/**
958 * Settings that has to do with autostart.
959 */
960struct Autostart
961{
962 Autostart()
963 : fAutostartEnabled(false),
964 uAutostartDelay(0),
965 enmAutostopType(AutostopType_Disabled)
966 { }
967
968 bool operator==(const Autostart &rOther) const
969 {
970 return fAutostartEnabled == rOther.fAutostartEnabled
971 && uAutostartDelay == rOther.uAutostartDelay
972 && enmAutostopType == rOther.enmAutostopType;
973 }
974
975 bool areDefaultSettings() const
976 {
977 return !fAutostartEnabled
978 && !uAutostartDelay
979 && enmAutostopType == AutostopType_Disabled;
980 }
981
982 bool fAutostartEnabled;
983 uint32_t uAutostartDelay;
984 AutostopType_T enmAutostopType;
985};
986
987struct Snapshot;
988typedef std::list<Snapshot> SnapshotsList;
989
990/**
991 * NOTE: If you add any fields in here, you must update a) the constructor and b)
992 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
993 * your settings might never get saved.
994 */
995struct Snapshot
996{
997 bool operator==(const Snapshot &s) const;
998
999 com::Guid uuid;
1000 com::Utf8Str strName,
1001 strDescription; // optional
1002 RTTIMESPEC timestamp;
1003
1004 com::Utf8Str strStateFile; // for online snapshots only
1005
1006 Hardware hardware;
1007 Storage storage;
1008
1009 Debugging debugging;
1010 Autostart autostart;
1011
1012 SnapshotsList llChildSnapshots;
1013};
1014
1015struct MachineUserData
1016{
1017 MachineUserData()
1018 : fDirectoryIncludesUUID(false),
1019 fNameSync(true),
1020 fTeleporterEnabled(false),
1021 uTeleporterPort(0),
1022 enmFaultToleranceState(FaultToleranceState_Inactive),
1023 uFaultTolerancePort(0),
1024 uFaultToleranceInterval(0),
1025 fRTCUseUTC(false)
1026 {
1027 llGroups.push_back("/");
1028 }
1029
1030 bool operator==(const MachineUserData &c) const
1031 {
1032 return (strName == c.strName)
1033 && (fDirectoryIncludesUUID == c.fDirectoryIncludesUUID)
1034 && (fNameSync == c.fNameSync)
1035 && (strDescription == c.strDescription)
1036 && (llGroups == c.llGroups)
1037 && (strOsType == c.strOsType)
1038 && (strSnapshotFolder == c.strSnapshotFolder)
1039 && (fTeleporterEnabled == c.fTeleporterEnabled)
1040 && (uTeleporterPort == c.uTeleporterPort)
1041 && (strTeleporterAddress == c.strTeleporterAddress)
1042 && (strTeleporterPassword == c.strTeleporterPassword)
1043 && (enmFaultToleranceState == c.enmFaultToleranceState)
1044 && (uFaultTolerancePort == c.uFaultTolerancePort)
1045 && (uFaultToleranceInterval == c.uFaultToleranceInterval)
1046 && (strFaultToleranceAddress == c.strFaultToleranceAddress)
1047 && (strFaultTolerancePassword == c.strFaultTolerancePassword)
1048 && (fRTCUseUTC == c.fRTCUseUTC);
1049 }
1050
1051 com::Utf8Str strName;
1052 bool fDirectoryIncludesUUID;
1053 bool fNameSync;
1054 com::Utf8Str strDescription;
1055 StringsList llGroups;
1056 com::Utf8Str strOsType;
1057 com::Utf8Str strSnapshotFolder;
1058 bool fTeleporterEnabled;
1059 uint32_t uTeleporterPort;
1060 com::Utf8Str strTeleporterAddress;
1061 com::Utf8Str strTeleporterPassword;
1062 FaultToleranceState_T enmFaultToleranceState;
1063 uint32_t uFaultTolerancePort;
1064 com::Utf8Str strFaultToleranceAddress;
1065 com::Utf8Str strFaultTolerancePassword;
1066 uint32_t uFaultToleranceInterval;
1067 bool fRTCUseUTC;
1068};
1069
1070/**
1071 * MachineConfigFile represents an XML machine configuration. All the machine settings
1072 * that go out to the XML (or are read from it) are in here.
1073 *
1074 * NOTE: If you add any fields in here, you must update a) the constructor and b)
1075 * the operator== which is used by Machine::saveSettings(), or otherwise your settings
1076 * might never get saved.
1077 */
1078class MachineConfigFile : public ConfigFileBase
1079{
1080public:
1081 com::Guid uuid;
1082
1083 MachineUserData machineUserData;
1084
1085 com::Utf8Str strStateFile;
1086 bool fCurrentStateModified; // optional, default is true
1087 RTTIMESPEC timeLastStateChange; // optional, defaults to now
1088 bool fAborted; // optional, default is false
1089
1090 com::Guid uuidCurrentSnapshot;
1091
1092 Hardware hardwareMachine;
1093 Storage storageMachine;
1094 MediaRegistry mediaRegistry;
1095 Debugging debugging;
1096 Autostart autostart;
1097
1098 StringsMap mapExtraDataItems;
1099
1100 SnapshotsList llFirstSnapshot; // first snapshot or empty list if there's none
1101
1102 MachineConfigFile(const com::Utf8Str *pstrFilename);
1103
1104 bool operator==(const MachineConfigFile &m) const;
1105
1106 bool canHaveOwnMediaRegistry() const;
1107
1108 void importMachineXML(const xml::ElementNode &elmMachine);
1109
1110 void write(const com::Utf8Str &strFilename);
1111
1112 enum
1113 {
1114 BuildMachineXML_IncludeSnapshots = 0x01,
1115 BuildMachineXML_WriteVboxVersionAttribute = 0x02,
1116 BuildMachineXML_SkipRemovableMedia = 0x04,
1117 BuildMachineXML_MediaRegistry = 0x08,
1118 BuildMachineXML_SuppressSavedState = 0x10
1119 };
1120 void buildMachineXML(xml::ElementNode &elmMachine,
1121 uint32_t fl,
1122 std::list<xml::ElementNode*> *pllElementsWithUuidAttributes);
1123
1124 static bool isAudioDriverAllowedOnThisHost(AudioDriverType_T drv);
1125 static AudioDriverType_T getHostDefaultAudioDriver();
1126
1127private:
1128 void readNetworkAdapters(const xml::ElementNode &elmHardware, NetworkAdaptersList &ll);
1129 void readAttachedNetworkMode(const xml::ElementNode &pelmMode, bool fEnabled, NetworkAdapter &nic);
1130 void readCpuIdTree(const xml::ElementNode &elmCpuid, CpuIdLeafsList &ll);
1131 void readCpuTree(const xml::ElementNode &elmCpu, CpuList &ll);
1132 void readSerialPorts(const xml::ElementNode &elmUART, SerialPortsList &ll);
1133 void readParallelPorts(const xml::ElementNode &elmLPT, ParallelPortsList &ll);
1134 void readAudioAdapter(const xml::ElementNode &elmAudioAdapter, AudioAdapter &aa);
1135 void readGuestProperties(const xml::ElementNode &elmGuestProperties, Hardware &hw);
1136 void readStorageControllerAttributes(const xml::ElementNode &elmStorageController, StorageController &sctl);
1137 void readHardware(const xml::ElementNode &elmHardware, Hardware &hw, Storage &strg);
1138 void readHardDiskAttachments_pre1_7(const xml::ElementNode &elmHardDiskAttachments, Storage &strg);
1139 void readStorageControllers(const xml::ElementNode &elmStorageControllers, Storage &strg);
1140 void readDVDAndFloppies_pre1_9(const xml::ElementNode &elmHardware, Storage &strg);
1141 void readTeleporter(const xml::ElementNode *pElmTeleporter, MachineUserData *pUserData);
1142 void readDebugging(const xml::ElementNode *pElmDbg, Debugging *pDbg);
1143 void readAutostart(const xml::ElementNode *pElmAutostart, Autostart *pAutostart);
1144 void readGroups(const xml::ElementNode *elmGroups, StringsList *pllGroups);
1145 void readSnapshot(const xml::ElementNode &elmSnapshot, Snapshot &snap);
1146 void convertOldOSType_pre1_5(com::Utf8Str &str);
1147 void readMachine(const xml::ElementNode &elmMachine);
1148
1149 void buildHardwareXML(xml::ElementNode &elmParent, const Hardware &hw, const Storage &strg);
1150 void buildNetworkXML(NetworkAttachmentType_T mode, xml::ElementNode &elmParent, bool fEnabled, const NetworkAdapter &nic);
1151 void buildStorageControllersXML(xml::ElementNode &elmParent,
1152 const Storage &st,
1153 bool fSkipRemovableMedia,
1154 std::list<xml::ElementNode*> *pllElementsWithUuidAttributes);
1155 void buildDebuggingXML(xml::ElementNode *pElmParent, const Debugging *pDbg);
1156 void buildAutostartXML(xml::ElementNode *pElmParent, const Autostart *pAutostart);
1157 void buildGroupsXML(xml::ElementNode *pElmParent, const StringsList *pllGroups);
1158 void buildSnapshotXML(xml::ElementNode &elmParent, const Snapshot &snap);
1159
1160 void bumpSettingsVersionIfNeeded();
1161};
1162
1163} // namespace settings
1164
1165
1166#endif /* ___VBox_settings_h */
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