VirtualBox

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

Last change on this file since 51299 was 50996, checked in by vboxsync, 11 years ago

Main: Added paravirt. provider APIs.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Date Revision Author Id
File size: 43.1 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-2014 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(true),
371 fAdvertiseDefaultIPv6Route(false),
372 fNeedDhcpServer(true)
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 bool areParavirtDefaultSettings() const
869 {
870 return paravirtProvider == ParavirtProvider_Legacy;
871 }
872
873 com::Utf8Str strVersion; // hardware version, optional
874 com::Guid uuid; // hardware uuid, optional (null).
875
876 bool fHardwareVirt,
877 fNestedPaging,
878 fLargePages,
879 fVPID,
880 fUnrestrictedExecution,
881 fHardwareVirtForce,
882 fSyntheticCpu,
883 fTripleFaultReset,
884 fPAE;
885 typedef enum LongModeType { LongMode_Enabled, LongMode_Disabled, LongMode_Legacy } LongModeType;
886 LongModeType enmLongMode;
887 uint32_t cCPUs;
888 bool fCpuHotPlug; // requires settings version 1.10 (VirtualBox 3.2)
889 CpuList llCpus; // requires settings version 1.10 (VirtualBox 3.2)
890 bool fHPETEnabled; // requires settings version 1.10 (VirtualBox 3.2)
891 uint32_t ulCpuExecutionCap; // requires settings version 1.11 (VirtualBox 3.3)
892
893 CpuIdLeafsList llCpuIdLeafs;
894
895 uint32_t ulMemorySizeMB;
896
897 BootOrderMap mapBootOrder; // item 0 has highest priority
898
899 GraphicsControllerType_T graphicsControllerType;
900 uint32_t ulVRAMSizeMB;
901 uint32_t cMonitors;
902 bool fAccelerate3D,
903 fAccelerate2DVideo; // requires settings version 1.8 (VirtualBox 3.1)
904
905 uint32_t ulVideoCaptureHorzRes; // requires settings version 1.14 (VirtualBox 4.3)
906 uint32_t ulVideoCaptureVertRes; // requires settings version 1.14 (VirtualBox 4.3)
907 uint32_t ulVideoCaptureRate; // requires settings version 1.14 (VirtualBox 4.3)
908 uint32_t ulVideoCaptureFPS; // requires settings version 1.14 (VirtualBox 4.3)
909 bool fVideoCaptureEnabled; // requires settings version 1.14 (VirtualBox 4.3)
910 uint64_t u64VideoCaptureScreens; // requires settings version 1.14 (VirtualBox 4.3)
911 com::Utf8Str strVideoCaptureFile; // requires settings version 1.14 (VirtualBox 4.3)
912
913 FirmwareType_T firmwareType; // requires settings version 1.9 (VirtualBox 3.1)
914
915 PointingHIDType_T pointingHIDType; // requires settings version 1.10 (VirtualBox 3.2)
916 KeyboardHIDType_T keyboardHIDType; // requires settings version 1.10 (VirtualBox 3.2)
917
918 ChipsetType_T chipsetType; // requires settings version 1.11 (VirtualBox 4.0)
919 ParavirtProvider_T paravirtProvider; // requires settings version 1.15 (VirtualBox 4.4)
920
921 bool fEmulatedUSBCardReader; // 1.12 (VirtualBox 4.1)
922
923 VRDESettings vrdeSettings;
924
925 BIOSSettings biosSettings;
926 USB usbSettings;
927 NetworkAdaptersList llNetworkAdapters;
928 SerialPortsList llSerialPorts;
929 ParallelPortsList llParallelPorts;
930 AudioAdapter audioAdapter;
931
932 // technically these two have no business in the hardware section, but for some
933 // clever reason <Hardware> is where they are in the XML....
934 SharedFoldersList llSharedFolders;
935 ClipboardMode_T clipboardMode;
936 DragAndDropMode_T dragAndDropMode;
937
938 uint32_t ulMemoryBalloonSize;
939 bool fPageFusionEnabled;
940
941 GuestPropertiesList llGuestProperties;
942 com::Utf8Str strNotificationPatterns;
943
944 IOSettings ioSettings; // requires settings version 1.10 (VirtualBox 3.2)
945 HostPCIDeviceAttachmentList pciAttachments; // requires settings version 1.12 (VirtualBox 4.1)
946
947 com::Utf8Str strDefaultFrontend; // requires settings version 1.14 (VirtualBox 4.3)
948};
949
950/**
951 * A device attached to a storage controller. This can either be a
952 * hard disk or a DVD drive or a floppy drive and also specifies
953 * which medium is "in" the drive; as a result, this is a combination
954 * of the Main IMedium and IMediumAttachment interfaces.
955 *
956 * NOTE: If you add any fields in here, you must update a) the constructor and b)
957 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
958 * your settings might never get saved.
959 */
960struct AttachedDevice
961{
962 AttachedDevice()
963 : deviceType(DeviceType_Null),
964 fPassThrough(false),
965 fTempEject(false),
966 fNonRotational(false),
967 fDiscard(false),
968 fHotPluggable(false),
969 lPort(0),
970 lDevice(0)
971 {}
972
973 bool operator==(const AttachedDevice &a) const;
974
975 DeviceType_T deviceType; // only HardDisk, DVD or Floppy are allowed
976
977 // DVDs can be in pass-through mode:
978 bool fPassThrough;
979
980 // Whether guest-triggered eject of DVDs will keep the medium in the
981 // VM config or not:
982 bool fTempEject;
983
984 // Whether the medium is non-rotational:
985 bool fNonRotational;
986
987 // Whether the medium supports discarding unused blocks:
988 bool fDiscard;
989
990 // Whether the medium is hot-pluggable:
991 bool fHotPluggable;
992
993 int32_t lPort;
994 int32_t lDevice;
995
996 // if an image file is attached to the device (ISO, RAW, or hard disk image such as VDI),
997 // this is its UUID; it depends on deviceType which media registry this then needs to
998 // be looked up in. If no image file (only permitted for DVDs and floppies), then the UUID is NULL
999 com::Guid uuid;
1000
1001 // for DVDs and floppies, the attachment can also be a host device:
1002 com::Utf8Str strHostDriveSrc; // if != NULL, value of <HostDrive>/@src
1003
1004 // Bandwidth group the device is attached to.
1005 com::Utf8Str strBwGroup;
1006};
1007typedef std::list<AttachedDevice> AttachedDevicesList;
1008
1009/**
1010 * NOTE: If you add any fields in here, you must update a) the constructor and b)
1011 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
1012 * your settings might never get saved.
1013 */
1014struct StorageController
1015{
1016 StorageController()
1017 : storageBus(StorageBus_IDE),
1018 controllerType(StorageControllerType_PIIX3),
1019 ulPortCount(2),
1020 ulInstance(0),
1021 fUseHostIOCache(true),
1022 fBootable(true),
1023 lIDE0MasterEmulationPort(0),
1024 lIDE0SlaveEmulationPort(0),
1025 lIDE1MasterEmulationPort(0),
1026 lIDE1SlaveEmulationPort(0)
1027 {}
1028
1029 bool operator==(const StorageController &s) const;
1030
1031 com::Utf8Str strName;
1032 StorageBus_T storageBus; // _SATA, _SCSI, _IDE, _SAS
1033 StorageControllerType_T controllerType;
1034 uint32_t ulPortCount;
1035 uint32_t ulInstance;
1036 bool fUseHostIOCache;
1037 bool fBootable;
1038
1039 // only for when controllerType == StorageControllerType_IntelAhci:
1040 int32_t lIDE0MasterEmulationPort,
1041 lIDE0SlaveEmulationPort,
1042 lIDE1MasterEmulationPort,
1043 lIDE1SlaveEmulationPort;
1044
1045 AttachedDevicesList llAttachedDevices;
1046};
1047typedef std::list<StorageController> StorageControllersList;
1048
1049/**
1050 * We wrap the storage controllers list into an extra struct so we can
1051 * use an undefined struct without needing std::list<> in all the headers.
1052 *
1053 * NOTE: If you add any fields in here, you must update a) the constructor and b)
1054 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
1055 * your settings might never get saved.
1056 */
1057struct Storage
1058{
1059 bool operator==(const Storage &s) const;
1060
1061 StorageControllersList llStorageControllers;
1062};
1063
1064/**
1065 * Settings that has to do with debugging.
1066 */
1067struct Debugging
1068{
1069 Debugging()
1070 : fTracingEnabled(false),
1071 fAllowTracingToAccessVM(false),
1072 strTracingConfig()
1073 { }
1074
1075 bool operator==(const Debugging &rOther) const
1076 {
1077 return fTracingEnabled == rOther.fTracingEnabled
1078 && fAllowTracingToAccessVM == rOther.fAllowTracingToAccessVM
1079 && strTracingConfig == rOther.strTracingConfig;
1080 }
1081
1082 bool areDefaultSettings() const
1083 {
1084 return !fTracingEnabled
1085 && !fAllowTracingToAccessVM
1086 && strTracingConfig.isEmpty();
1087 }
1088
1089 bool fTracingEnabled;
1090 bool fAllowTracingToAccessVM;
1091 com::Utf8Str strTracingConfig;
1092};
1093
1094/**
1095 * Settings that has to do with autostart.
1096 */
1097struct Autostart
1098{
1099 Autostart()
1100 : fAutostartEnabled(false),
1101 uAutostartDelay(0),
1102 enmAutostopType(AutostopType_Disabled)
1103 { }
1104
1105 bool operator==(const Autostart &rOther) const
1106 {
1107 return fAutostartEnabled == rOther.fAutostartEnabled
1108 && uAutostartDelay == rOther.uAutostartDelay
1109 && enmAutostopType == rOther.enmAutostopType;
1110 }
1111
1112 bool areDefaultSettings() const
1113 {
1114 return !fAutostartEnabled
1115 && !uAutostartDelay
1116 && enmAutostopType == AutostopType_Disabled;
1117 }
1118
1119 bool fAutostartEnabled;
1120 uint32_t uAutostartDelay;
1121 AutostopType_T enmAutostopType;
1122};
1123
1124struct Snapshot;
1125typedef std::list<Snapshot> SnapshotsList;
1126
1127/**
1128 * NOTE: If you add any fields in here, you must update a) the constructor and b)
1129 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
1130 * your settings might never get saved.
1131 */
1132struct Snapshot
1133{
1134 bool operator==(const Snapshot &s) const;
1135
1136 com::Guid uuid;
1137 com::Utf8Str strName,
1138 strDescription; // optional
1139 RTTIMESPEC timestamp;
1140
1141 com::Utf8Str strStateFile; // for online snapshots only
1142
1143 Hardware hardware;
1144 Storage storage;
1145
1146 Debugging debugging;
1147 Autostart autostart;
1148
1149 SnapshotsList llChildSnapshots;
1150};
1151
1152struct MachineUserData
1153{
1154 MachineUserData()
1155 : fDirectoryIncludesUUID(false),
1156 fNameSync(true),
1157 fTeleporterEnabled(false),
1158 uTeleporterPort(0),
1159 enmFaultToleranceState(FaultToleranceState_Inactive),
1160 uFaultTolerancePort(0),
1161 uFaultToleranceInterval(0),
1162 fRTCUseUTC(false)
1163 {
1164 llGroups.push_back("/");
1165 }
1166
1167 bool operator==(const MachineUserData &c) const
1168 {
1169 return (strName == c.strName)
1170 && (fDirectoryIncludesUUID == c.fDirectoryIncludesUUID)
1171 && (fNameSync == c.fNameSync)
1172 && (strDescription == c.strDescription)
1173 && (llGroups == c.llGroups)
1174 && (strOsType == c.strOsType)
1175 && (strSnapshotFolder == c.strSnapshotFolder)
1176 && (fTeleporterEnabled == c.fTeleporterEnabled)
1177 && (uTeleporterPort == c.uTeleporterPort)
1178 && (strTeleporterAddress == c.strTeleporterAddress)
1179 && (strTeleporterPassword == c.strTeleporterPassword)
1180 && (enmFaultToleranceState == c.enmFaultToleranceState)
1181 && (uFaultTolerancePort == c.uFaultTolerancePort)
1182 && (uFaultToleranceInterval == c.uFaultToleranceInterval)
1183 && (strFaultToleranceAddress == c.strFaultToleranceAddress)
1184 && (strFaultTolerancePassword == c.strFaultTolerancePassword)
1185 && (fRTCUseUTC == c.fRTCUseUTC)
1186 && (ovIcon == c.ovIcon);
1187 }
1188
1189 com::Utf8Str strName;
1190 bool fDirectoryIncludesUUID;
1191 bool fNameSync;
1192 com::Utf8Str strDescription;
1193 StringsList llGroups;
1194 com::Utf8Str strOsType;
1195 com::Utf8Str strSnapshotFolder;
1196 bool fTeleporterEnabled;
1197 uint32_t uTeleporterPort;
1198 com::Utf8Str strTeleporterAddress;
1199 com::Utf8Str strTeleporterPassword;
1200 FaultToleranceState_T enmFaultToleranceState;
1201 uint32_t uFaultTolerancePort;
1202 com::Utf8Str strFaultToleranceAddress;
1203 com::Utf8Str strFaultTolerancePassword;
1204 uint32_t uFaultToleranceInterval;
1205 bool fRTCUseUTC;
1206 com::Utf8Str ovIcon;
1207};
1208
1209/**
1210 * MachineConfigFile represents an XML machine configuration. All the machine settings
1211 * that go out to the XML (or are read from it) are in here.
1212 *
1213 * NOTE: If you add any fields in here, you must update a) the constructor and b)
1214 * the operator== which is used by Machine::saveSettings(), or otherwise your settings
1215 * might never get saved.
1216 */
1217class MachineConfigFile : public ConfigFileBase
1218{
1219public:
1220 com::Guid uuid;
1221
1222 MachineUserData machineUserData;
1223
1224 com::Utf8Str strStateFile;
1225 bool fCurrentStateModified; // optional, default is true
1226 RTTIMESPEC timeLastStateChange; // optional, defaults to now
1227 bool fAborted; // optional, default is false
1228
1229 com::Guid uuidCurrentSnapshot;
1230
1231 Hardware hardwareMachine;
1232 Storage storageMachine;
1233 MediaRegistry mediaRegistry;
1234 Debugging debugging;
1235 Autostart autostart;
1236
1237 StringsMap mapExtraDataItems;
1238
1239 SnapshotsList llFirstSnapshot; // first snapshot or empty list if there's none
1240
1241 MachineConfigFile(const com::Utf8Str *pstrFilename);
1242
1243 bool operator==(const MachineConfigFile &m) const;
1244
1245 bool canHaveOwnMediaRegistry() const;
1246
1247 void importMachineXML(const xml::ElementNode &elmMachine);
1248
1249 void write(const com::Utf8Str &strFilename);
1250
1251 enum
1252 {
1253 BuildMachineXML_IncludeSnapshots = 0x01,
1254 BuildMachineXML_WriteVBoxVersionAttribute = 0x02,
1255 BuildMachineXML_SkipRemovableMedia = 0x04,
1256 BuildMachineXML_MediaRegistry = 0x08,
1257 BuildMachineXML_SuppressSavedState = 0x10
1258 };
1259 void buildMachineXML(xml::ElementNode &elmMachine,
1260 uint32_t fl,
1261 std::list<xml::ElementNode*> *pllElementsWithUuidAttributes);
1262
1263 static bool isAudioDriverAllowedOnThisHost(AudioDriverType_T drv);
1264 static AudioDriverType_T getHostDefaultAudioDriver();
1265
1266private:
1267 void readNetworkAdapters(const xml::ElementNode &elmHardware, NetworkAdaptersList &ll);
1268 void readAttachedNetworkMode(const xml::ElementNode &pelmMode, bool fEnabled, NetworkAdapter &nic);
1269 void readCpuIdTree(const xml::ElementNode &elmCpuid, CpuIdLeafsList &ll);
1270 void readCpuTree(const xml::ElementNode &elmCpu, CpuList &ll);
1271 void readSerialPorts(const xml::ElementNode &elmUART, SerialPortsList &ll);
1272 void readParallelPorts(const xml::ElementNode &elmLPT, ParallelPortsList &ll);
1273 void readAudioAdapter(const xml::ElementNode &elmAudioAdapter, AudioAdapter &aa);
1274 void readGuestProperties(const xml::ElementNode &elmGuestProperties, Hardware &hw);
1275 void readStorageControllerAttributes(const xml::ElementNode &elmStorageController, StorageController &sctl);
1276 void readHardware(const xml::ElementNode &elmHardware, Hardware &hw, Storage &strg);
1277 void readHardDiskAttachments_pre1_7(const xml::ElementNode &elmHardDiskAttachments, Storage &strg);
1278 void readStorageControllers(const xml::ElementNode &elmStorageControllers, Storage &strg);
1279 void readDVDAndFloppies_pre1_9(const xml::ElementNode &elmHardware, Storage &strg);
1280 void readTeleporter(const xml::ElementNode *pElmTeleporter, MachineUserData *pUserData);
1281 void readDebugging(const xml::ElementNode *pElmDbg, Debugging *pDbg);
1282 void readAutostart(const xml::ElementNode *pElmAutostart, Autostart *pAutostart);
1283 void readGroups(const xml::ElementNode *elmGroups, StringsList *pllGroups);
1284 bool readSnapshot(const com::Guid &curSnapshotUuid, uint32_t depth, const xml::ElementNode &elmSnapshot, Snapshot &snap);
1285 void convertOldOSType_pre1_5(com::Utf8Str &str);
1286 void readMachine(const xml::ElementNode &elmMachine);
1287
1288 void buildHardwareXML(xml::ElementNode &elmParent, const Hardware &hw, const Storage &strg);
1289 void buildNetworkXML(NetworkAttachmentType_T mode, xml::ElementNode &elmParent, bool fEnabled, const NetworkAdapter &nic);
1290 void buildStorageControllersXML(xml::ElementNode &elmParent,
1291 const Storage &st,
1292 bool fSkipRemovableMedia,
1293 std::list<xml::ElementNode*> *pllElementsWithUuidAttributes);
1294 void buildDebuggingXML(xml::ElementNode *pElmParent, const Debugging *pDbg);
1295 void buildAutostartXML(xml::ElementNode *pElmParent, const Autostart *pAutostart);
1296 void buildGroupsXML(xml::ElementNode *pElmParent, const StringsList *pllGroups);
1297 void buildSnapshotXML(uint32_t depth, xml::ElementNode &elmParent, const Snapshot &snap);
1298
1299 void bumpSettingsVersionIfNeeded();
1300};
1301
1302} // namespace settings
1303
1304
1305#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