VirtualBox

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

Last change on this file since 49165 was 49058, checked in by vboxsync, 11 years ago

Main: Added a TripleFaultReset switch.

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