VirtualBox

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

Last change on this file since 42372 was 42261, checked in by vboxsync, 12 years ago

enabled shared clipboard support for Linux hosts (guest=>host only)

  • Property svn:eol-style set to native
  • Property svn:keywords set to Date Revision Author Id
File size: 37.9 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 uint32_t ulLogHistoryCount;
236};
237
238struct MachineRegistryEntry
239{
240 com::Guid uuid;
241 com::Utf8Str strSettingsFile;
242};
243typedef std::list<MachineRegistryEntry> MachinesRegistry;
244
245struct DHCPServer
246{
247 DHCPServer()
248 : fEnabled(false)
249 {}
250
251 com::Utf8Str strNetworkName,
252 strIPAddress,
253 strIPNetworkMask,
254 strIPLower,
255 strIPUpper;
256 bool fEnabled;
257};
258typedef std::list<DHCPServer> DHCPServersList;
259
260class MainConfigFile : public ConfigFileBase
261{
262public:
263 MainConfigFile(const com::Utf8Str *pstrFilename);
264
265 void readMachineRegistry(const xml::ElementNode &elmMachineRegistry);
266 void readDHCPServers(const xml::ElementNode &elmDHCPServers);
267
268 void write(const com::Utf8Str strFilename);
269
270 Host host;
271 SystemProperties systemProperties;
272 MediaRegistry mediaRegistry;
273 MachinesRegistry llMachines;
274 DHCPServersList llDhcpServers;
275 StringsMap mapExtraDataItems;
276};
277
278////////////////////////////////////////////////////////////////////////////////
279//
280// Machine XML structures
281//
282////////////////////////////////////////////////////////////////////////////////
283
284/**
285 * NOTE: If you add any fields in here, you must update a) the constructor and b)
286 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
287 * your settings might never get saved.
288 */
289struct VRDESettings
290{
291 VRDESettings()
292 : fEnabled(true),
293 authType(AuthType_Null),
294 ulAuthTimeout(5000),
295 fAllowMultiConnection(false),
296 fReuseSingleConnection(false)
297 {}
298
299 bool operator==(const VRDESettings& v) const;
300
301 bool fEnabled;
302 AuthType_T authType;
303 uint32_t ulAuthTimeout;
304 com::Utf8Str strAuthLibrary;
305 bool fAllowMultiConnection,
306 fReuseSingleConnection;
307 com::Utf8Str strVrdeExtPack;
308 StringsMap mapProperties;
309};
310
311/**
312 * NOTE: If you add any fields in here, you must update a) the constructor and b)
313 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
314 * your settings might never get saved.
315 */
316struct BIOSSettings
317{
318 BIOSSettings()
319 : fACPIEnabled(true),
320 fIOAPICEnabled(false),
321 fLogoFadeIn(true),
322 fLogoFadeOut(true),
323 ulLogoDisplayTime(0),
324 biosBootMenuMode(BIOSBootMenuMode_MessageAndMenu),
325 fPXEDebugEnabled(false),
326 llTimeOffset(0)
327 {}
328
329 bool operator==(const BIOSSettings &d) const;
330
331 bool fACPIEnabled,
332 fIOAPICEnabled,
333 fLogoFadeIn,
334 fLogoFadeOut;
335 uint32_t ulLogoDisplayTime;
336 com::Utf8Str strLogoImagePath;
337 BIOSBootMenuMode_T biosBootMenuMode;
338 bool fPXEDebugEnabled;
339 int64_t llTimeOffset;
340};
341
342/**
343 * NOTE: If you add any fields in here, you must update a) the constructor and b)
344 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
345 * your settings might never get saved.
346 */
347struct USBController
348{
349 USBController()
350 : fEnabled(false),
351 fEnabledEHCI(false)
352 {}
353
354 bool operator==(const USBController &u) const;
355
356 bool fEnabled;
357 bool fEnabledEHCI;
358 USBDeviceFiltersList llDeviceFilters;
359};
360
361 struct NATRule
362 {
363 NATRule()
364 : proto(NATProtocol_TCP),
365 u16HostPort(0),
366 u16GuestPort(0)
367 {}
368
369 bool operator==(const NATRule &r) const
370 {
371 return strName == r.strName
372 && proto == r.proto
373 && u16HostPort == r.u16HostPort
374 && strHostIP == r.strHostIP
375 && u16GuestPort == r.u16GuestPort
376 && strGuestIP == r.strGuestIP;
377 }
378
379 com::Utf8Str strName;
380 NATProtocol_T proto;
381 uint16_t u16HostPort;
382 com::Utf8Str strHostIP;
383 uint16_t u16GuestPort;
384 com::Utf8Str strGuestIP;
385 };
386 typedef std::list<NATRule> NATRuleList;
387
388 struct NAT
389 {
390 NAT()
391 : u32Mtu(0),
392 u32SockRcv(0),
393 u32SockSnd(0),
394 u32TcpRcv(0),
395 u32TcpSnd(0),
396 fDnsPassDomain(true), /* historically this value is true */
397 fDnsProxy(false),
398 fDnsUseHostResolver(false),
399 fAliasLog(false),
400 fAliasProxyOnly(false),
401 fAliasUseSamePorts(false)
402 {}
403
404 bool operator==(const NAT &n) const
405 {
406 return strNetwork == n.strNetwork
407 && strBindIP == n.strBindIP
408 && u32Mtu == n.u32Mtu
409 && u32SockRcv == n.u32SockRcv
410 && u32SockSnd == n.u32SockSnd
411 && u32TcpSnd == n.u32TcpSnd
412 && u32TcpRcv == n.u32TcpRcv
413 && strTftpPrefix == n.strTftpPrefix
414 && strTftpBootFile == n.strTftpBootFile
415 && strTftpNextServer == n.strTftpNextServer
416 && fDnsPassDomain == n.fDnsPassDomain
417 && fDnsProxy == n.fDnsProxy
418 && fDnsUseHostResolver == n.fDnsUseHostResolver
419 && fAliasLog == n.fAliasLog
420 && fAliasProxyOnly == n.fAliasProxyOnly
421 && fAliasUseSamePorts == n.fAliasUseSamePorts
422 && llRules == n.llRules;
423 }
424
425 com::Utf8Str strNetwork;
426 com::Utf8Str strBindIP;
427 uint32_t u32Mtu;
428 uint32_t u32SockRcv;
429 uint32_t u32SockSnd;
430 uint32_t u32TcpRcv;
431 uint32_t u32TcpSnd;
432 com::Utf8Str strTftpPrefix;
433 com::Utf8Str strTftpBootFile;
434 com::Utf8Str strTftpNextServer;
435 bool fDnsPassDomain;
436 bool fDnsProxy;
437 bool fDnsUseHostResolver;
438 bool fAliasLog;
439 bool fAliasProxyOnly;
440 bool fAliasUseSamePorts;
441 NATRuleList llRules;
442 };
443/**
444 * NOTE: If you add any fields in here, you must update a) the constructor and b)
445 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
446 * your settings might never get saved.
447 */
448struct NetworkAdapter
449{
450 NetworkAdapter()
451 : ulSlot(0),
452 type(NetworkAdapterType_Am79C970A),
453 fEnabled(false),
454 fCableConnected(false),
455 ulLineSpeed(0),
456 enmPromiscModePolicy(NetworkAdapterPromiscModePolicy_Deny),
457 fTraceEnabled(false),
458 mode(NetworkAttachmentType_Null),
459 ulBootPriority(0)
460 {}
461
462 bool operator==(const NetworkAdapter &n) const;
463
464 uint32_t ulSlot;
465
466 NetworkAdapterType_T type;
467 bool fEnabled;
468 com::Utf8Str strMACAddress;
469 bool fCableConnected;
470 uint32_t ulLineSpeed;
471 NetworkAdapterPromiscModePolicy_T enmPromiscModePolicy;
472 bool fTraceEnabled;
473 com::Utf8Str strTraceFile;
474
475 NetworkAttachmentType_T mode;
476 NAT nat;
477 com::Utf8Str strBridgedName;
478 com::Utf8Str strHostOnlyName;
479 com::Utf8Str strInternalNetworkName;
480 com::Utf8Str strGenericDriver;
481 StringsMap genericProperties;
482 uint32_t ulBootPriority;
483 com::Utf8Str strBandwidthGroup; // requires settings version 1.13 (VirtualBox 4.2)
484};
485typedef std::list<NetworkAdapter> NetworkAdaptersList;
486
487/**
488 * NOTE: If you add any fields in here, you must update a) the constructor and b)
489 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
490 * your settings might never get saved.
491 */
492struct SerialPort
493{
494 SerialPort()
495 : ulSlot(0),
496 fEnabled(false),
497 ulIOBase(0x3f8),
498 ulIRQ(4),
499 portMode(PortMode_Disconnected),
500 fServer(false)
501 {}
502
503 bool operator==(const SerialPort &n) const;
504
505 uint32_t ulSlot;
506
507 bool fEnabled;
508 uint32_t ulIOBase;
509 uint32_t ulIRQ;
510 PortMode_T portMode;
511 com::Utf8Str strPath;
512 bool fServer;
513};
514typedef std::list<SerialPort> SerialPortsList;
515
516/**
517 * NOTE: If you add any fields in here, you must update a) the constructor and b)
518 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
519 * your settings might never get saved.
520 */
521struct ParallelPort
522{
523 ParallelPort()
524 : ulSlot(0),
525 fEnabled(false),
526 ulIOBase(0x378),
527 ulIRQ(7)
528 {}
529
530 bool operator==(const ParallelPort &d) const;
531
532 uint32_t ulSlot;
533
534 bool fEnabled;
535 uint32_t ulIOBase;
536 uint32_t ulIRQ;
537 com::Utf8Str strPath;
538};
539typedef std::list<ParallelPort> ParallelPortsList;
540
541/**
542 * NOTE: If you add any fields in here, you must update a) the constructor and b)
543 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
544 * your settings might never get saved.
545 */
546struct AudioAdapter
547{
548 AudioAdapter()
549 : fEnabled(true),
550 controllerType(AudioControllerType_AC97),
551 driverType(AudioDriverType_Null)
552 {}
553
554 bool operator==(const AudioAdapter &a) const
555 {
556 return (this == &a)
557 || ( (fEnabled == a.fEnabled)
558 && (controllerType == a.controllerType)
559 && (driverType == a.driverType)
560 );
561 }
562
563 bool fEnabled;
564 AudioControllerType_T controllerType;
565 AudioDriverType_T driverType;
566};
567
568/**
569 * NOTE: If you add any fields in here, you must update a) the constructor and b)
570 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
571 * your settings might never get saved.
572 */
573struct SharedFolder
574{
575 SharedFolder()
576 : fWritable(false)
577 , fAutoMount(false)
578 {}
579
580 bool operator==(const SharedFolder &a) const;
581
582 com::Utf8Str strName,
583 strHostPath;
584 bool fWritable;
585 bool fAutoMount;
586};
587typedef std::list<SharedFolder> SharedFoldersList;
588
589/**
590 * NOTE: If you add any fields in here, you must update a) the constructor and b)
591 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
592 * your settings might never get saved.
593 */
594struct GuestProperty
595{
596 GuestProperty()
597 : timestamp(0)
598 {};
599
600 bool operator==(const GuestProperty &g) const;
601
602 com::Utf8Str strName,
603 strValue;
604 uint64_t timestamp;
605 com::Utf8Str strFlags;
606};
607typedef std::list<GuestProperty> GuestPropertiesList;
608
609typedef std::map<uint32_t, DeviceType_T> BootOrderMap;
610
611/**
612 * NOTE: If you add any fields in here, you must update a) the constructor and b)
613 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
614 * your settings might never get saved.
615 */
616struct CpuIdLeaf
617{
618 CpuIdLeaf()
619 : ulId(UINT32_MAX),
620 ulEax(0),
621 ulEbx(0),
622 ulEcx(0),
623 ulEdx(0)
624 {}
625
626 bool operator==(const CpuIdLeaf &c) const
627 {
628 return ( (this == &c)
629 || ( (ulId == c.ulId)
630 && (ulEax == c.ulEax)
631 && (ulEbx == c.ulEbx)
632 && (ulEcx == c.ulEcx)
633 && (ulEdx == c.ulEdx)
634 )
635 );
636 }
637
638 uint32_t ulId;
639 uint32_t ulEax;
640 uint32_t ulEbx;
641 uint32_t ulEcx;
642 uint32_t ulEdx;
643};
644typedef std::list<CpuIdLeaf> CpuIdLeafsList;
645
646/**
647 * NOTE: If you add any fields in here, you must update a) the constructor and b)
648 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
649 * your settings might never get saved.
650 */
651struct Cpu
652{
653 Cpu()
654 : ulId(UINT32_MAX)
655 {}
656
657 bool operator==(const Cpu &c) const
658 {
659 return (ulId == c.ulId);
660 }
661
662 uint32_t ulId;
663};
664typedef std::list<Cpu> CpuList;
665
666/**
667 * NOTE: If you add any fields in here, you must update a) the constructor and b)
668 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
669 * your settings might never get saved.
670 */
671struct BandwidthGroup
672{
673 BandwidthGroup()
674 : cMaxBytesPerSec(0),
675 enmType(BandwidthGroupType_Null)
676 {}
677
678 bool operator==(const BandwidthGroup &i) const
679 {
680 return ( (strName == i.strName)
681 && (cMaxBytesPerSec == i.cMaxBytesPerSec)
682 && (enmType == i.enmType));
683 }
684
685 com::Utf8Str strName;
686 uint64_t cMaxBytesPerSec;
687 BandwidthGroupType_T enmType;
688};
689typedef std::list<BandwidthGroup> BandwidthGroupList;
690
691/**
692 * NOTE: If you add any fields in here, you must update a) the constructor and b)
693 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
694 * your settings might never get saved.
695 */
696struct IoSettings
697{
698 IoSettings();
699
700 bool operator==(const IoSettings &i) const
701 {
702 return ( (fIoCacheEnabled == i.fIoCacheEnabled)
703 && (ulIoCacheSize == i.ulIoCacheSize)
704 && (llBandwidthGroups == i.llBandwidthGroups));
705 }
706
707 bool fIoCacheEnabled;
708 uint32_t ulIoCacheSize;
709 BandwidthGroupList llBandwidthGroups;
710};
711
712/**
713 * NOTE: If you add any fields in here, you must update a) the constructor and b)
714 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
715 * your settings might never get saved.
716 */
717struct HostPciDeviceAttachment
718{
719 HostPciDeviceAttachment()
720 : uHostAddress(0),
721 uGuestAddress(0)
722 {}
723
724 bool operator==(const HostPciDeviceAttachment &a) const
725 {
726 return ( (uHostAddress == a.uHostAddress)
727 && (uGuestAddress == a.uGuestAddress)
728 && (strDeviceName == a.strDeviceName)
729 );
730 }
731
732 com::Utf8Str strDeviceName;
733 uint32_t uHostAddress;
734 uint32_t uGuestAddress;
735};
736typedef std::list<HostPciDeviceAttachment> HostPciDeviceAttachmentList;
737
738/**
739 * Representation of Machine hardware; this is used in the MachineConfigFile.hardwareMachine
740 * field.
741 *
742 * NOTE: If you add any fields in here, you must update a) the constructor and b)
743 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
744 * your settings might never get saved.
745 */
746struct Hardware
747{
748 Hardware();
749
750 bool operator==(const Hardware&) const;
751
752 com::Utf8Str strVersion; // hardware version, optional
753 com::Guid uuid; // hardware uuid, optional (null).
754
755 bool fHardwareVirt,
756 fHardwareVirtExclusive,
757 fNestedPaging,
758 fLargePages,
759 fVPID,
760 fHardwareVirtForce,
761 fSyntheticCpu,
762 fPAE;
763 uint32_t cCPUs;
764 bool fCpuHotPlug; // requires settings version 1.10 (VirtualBox 3.2)
765 CpuList llCpus; // requires settings version 1.10 (VirtualBox 3.2)
766 bool fHpetEnabled; // requires settings version 1.10 (VirtualBox 3.2)
767 uint32_t ulCpuExecutionCap; // requires settings version 1.11 (VirtualBox 3.3)
768
769 CpuIdLeafsList llCpuIdLeafs;
770
771 uint32_t ulMemorySizeMB;
772
773 BootOrderMap mapBootOrder; // item 0 has highest priority
774
775 uint32_t ulVRAMSizeMB;
776 uint32_t cMonitors;
777 bool fAccelerate3D,
778 fAccelerate2DVideo; // requires settings version 1.8 (VirtualBox 3.1)
779 FirmwareType_T firmwareType; // requires settings version 1.9 (VirtualBox 3.1)
780
781 PointingHidType_T pointingHidType; // requires settings version 1.10 (VirtualBox 3.2)
782 KeyboardHidType_T keyboardHidType; // requires settings version 1.10 (VirtualBox 3.2)
783
784 ChipsetType_T chipsetType; // requires settings version 1.11 (VirtualBox 4.0)
785
786 bool fEmulatedUSBCardReader; // 1.12 (VirtualBox 4.1)
787
788 VRDESettings vrdeSettings;
789
790 BIOSSettings biosSettings;
791 USBController usbController;
792 NetworkAdaptersList llNetworkAdapters;
793 SerialPortsList llSerialPorts;
794 ParallelPortsList llParallelPorts;
795 AudioAdapter audioAdapter;
796
797 // technically these two have no business in the hardware section, but for some
798 // clever reason <Hardware> is where they are in the XML....
799 SharedFoldersList llSharedFolders;
800 ClipboardMode_T clipboardMode;
801 DragAndDropMode_T dragAndDropMode;
802
803 uint32_t ulMemoryBalloonSize;
804 bool fPageFusionEnabled;
805
806 GuestPropertiesList llGuestProperties;
807 com::Utf8Str strNotificationPatterns;
808
809 IoSettings ioSettings; // requires settings version 1.10 (VirtualBox 3.2)
810 HostPciDeviceAttachmentList pciAttachments; // requires settings version 1.12 (VirtualBox 4.1)
811};
812
813/**
814 * A device attached to a storage controller. This can either be a
815 * hard disk or a DVD drive or a floppy drive and also specifies
816 * which medium is "in" the drive; as a result, this is a combination
817 * of the Main IMedium and IMediumAttachment interfaces.
818 *
819 * NOTE: If you add any fields in here, you must update a) the constructor and b)
820 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
821 * your settings might never get saved.
822 */
823struct AttachedDevice
824{
825 AttachedDevice()
826 : deviceType(DeviceType_Null),
827 fPassThrough(false),
828 fTempEject(false),
829 fNonRotational(false),
830 lPort(0),
831 lDevice(0)
832 {}
833
834 bool operator==(const AttachedDevice &a) const;
835
836 DeviceType_T deviceType; // only HardDisk, DVD or Floppy are allowed
837
838 // DVDs can be in pass-through mode:
839 bool fPassThrough;
840
841 // Whether guest-triggered eject of DVDs will keep the medium in the
842 // VM config or not:
843 bool fTempEject;
844
845 // Whether the medium is non-rotational:
846 bool fNonRotational;
847
848 // Whether the medium supports discarding unused blocks:
849 bool fDiscard;
850
851 int32_t lPort;
852 int32_t lDevice;
853
854 // if an image file is attached to the device (ISO, RAW, or hard disk image such as VDI),
855 // this is its UUID; it depends on deviceType which media registry this then needs to
856 // be looked up in. If no image file (only permitted for DVDs and floppies), then the UUID is NULL
857 com::Guid uuid;
858
859 // for DVDs and floppies, the attachment can also be a host device:
860 com::Utf8Str strHostDriveSrc; // if != NULL, value of <HostDrive>/@src
861
862 // Bandwidth group the device is attached to.
863 com::Utf8Str strBwGroup;
864};
865typedef std::list<AttachedDevice> AttachedDevicesList;
866
867/**
868 * NOTE: If you add any fields in here, you must update a) the constructor and b)
869 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
870 * your settings might never get saved.
871 */
872struct StorageController
873{
874 StorageController()
875 : storageBus(StorageBus_IDE),
876 controllerType(StorageControllerType_PIIX3),
877 ulPortCount(2),
878 ulInstance(0),
879 fUseHostIOCache(true),
880 fBootable(true),
881 lIDE0MasterEmulationPort(0),
882 lIDE0SlaveEmulationPort(0),
883 lIDE1MasterEmulationPort(0),
884 lIDE1SlaveEmulationPort(0)
885 {}
886
887 bool operator==(const StorageController &s) const;
888
889 com::Utf8Str strName;
890 StorageBus_T storageBus; // _SATA, _SCSI, _IDE, _SAS
891 StorageControllerType_T controllerType;
892 uint32_t ulPortCount;
893 uint32_t ulInstance;
894 bool fUseHostIOCache;
895 bool fBootable;
896
897 // only for when controllerType == StorageControllerType_IntelAhci:
898 int32_t lIDE0MasterEmulationPort,
899 lIDE0SlaveEmulationPort,
900 lIDE1MasterEmulationPort,
901 lIDE1SlaveEmulationPort;
902
903 AttachedDevicesList llAttachedDevices;
904};
905typedef std::list<StorageController> StorageControllersList;
906
907/**
908 * We wrap the storage controllers list into an extra struct so we can
909 * use an undefined struct without needing std::list<> in all the headers.
910 *
911 * NOTE: If you add any fields in here, you must update a) the constructor and b)
912 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
913 * your settings might never get saved.
914 */
915struct Storage
916{
917 bool operator==(const Storage &s) const;
918
919 StorageControllersList llStorageControllers;
920};
921
922/**
923 * Settings that has to do with debugging.
924 */
925struct Debugging
926{
927 Debugging()
928 : fTracingEnabled(false),
929 fAllowTracingToAccessVM(false),
930 strTracingConfig()
931 { }
932
933 bool operator==(const Debugging &rOther) const
934 {
935 return fTracingEnabled == rOther.fTracingEnabled
936 && fAllowTracingToAccessVM == rOther.fAllowTracingToAccessVM
937 && strTracingConfig == rOther.strTracingConfig;
938 }
939
940 bool areDefaultSettings() const
941 {
942 return !fTracingEnabled
943 && !fAllowTracingToAccessVM
944 && strTracingConfig.isEmpty();
945 }
946
947 bool fTracingEnabled;
948 bool fAllowTracingToAccessVM;
949 com::Utf8Str strTracingConfig;
950};
951
952/**
953 * Settings that has to do with autostart.
954 */
955struct Autostart
956{
957 Autostart()
958 : fAutostartEnabled(false),
959 uAutostartDelay(0),
960 enmAutostopType(AutostopType_Disabled)
961 { }
962
963 bool operator==(const Autostart &rOther) const
964 {
965 return fAutostartEnabled == rOther.fAutostartEnabled
966 && uAutostartDelay == rOther.uAutostartDelay
967 && enmAutostopType == rOther.enmAutostopType;
968 }
969
970 bool areDefaultSettings() const
971 {
972 return !fAutostartEnabled
973 && !uAutostartDelay
974 && enmAutostopType == AutostopType_Disabled;
975 }
976
977 bool fAutostartEnabled;
978 uint32_t uAutostartDelay;
979 AutostopType_T enmAutostopType;
980};
981
982struct Snapshot;
983typedef std::list<Snapshot> SnapshotsList;
984
985/**
986 * NOTE: If you add any fields in here, you must update a) the constructor and b)
987 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
988 * your settings might never get saved.
989 */
990struct Snapshot
991{
992 bool operator==(const Snapshot &s) const;
993
994 com::Guid uuid;
995 com::Utf8Str strName,
996 strDescription; // optional
997 RTTIMESPEC timestamp;
998
999 com::Utf8Str strStateFile; // for online snapshots only
1000
1001 Hardware hardware;
1002 Storage storage;
1003
1004 Debugging debugging;
1005 Autostart autostart;
1006
1007 SnapshotsList llChildSnapshots;
1008};
1009
1010struct MachineUserData
1011{
1012 MachineUserData()
1013 : fNameSync(true),
1014 fTeleporterEnabled(false),
1015 uTeleporterPort(0),
1016 enmFaultToleranceState(FaultToleranceState_Inactive),
1017 uFaultTolerancePort(0),
1018 uFaultToleranceInterval(0),
1019 fRTCUseUTC(false)
1020 {
1021 llGroups.push_back("/");
1022 }
1023
1024 bool operator==(const MachineUserData &c) const
1025 {
1026 return (strName == c.strName)
1027 && (fNameSync == c.fNameSync)
1028 && (strDescription == c.strDescription)
1029 && (llGroups == c.llGroups)
1030 && (strOsType == c.strOsType)
1031 && (strSnapshotFolder == c.strSnapshotFolder)
1032 && (fTeleporterEnabled == c.fTeleporterEnabled)
1033 && (uTeleporterPort == c.uTeleporterPort)
1034 && (strTeleporterAddress == c.strTeleporterAddress)
1035 && (strTeleporterPassword == c.strTeleporterPassword)
1036 && (enmFaultToleranceState == c.enmFaultToleranceState)
1037 && (uFaultTolerancePort == c.uFaultTolerancePort)
1038 && (uFaultToleranceInterval == c.uFaultToleranceInterval)
1039 && (strFaultToleranceAddress == c.strFaultToleranceAddress)
1040 && (strFaultTolerancePassword == c.strFaultTolerancePassword)
1041 && (fRTCUseUTC == c.fRTCUseUTC);
1042 }
1043
1044 com::Utf8Str strName;
1045 bool fNameSync;
1046 com::Utf8Str strDescription;
1047 StringsList llGroups;
1048 com::Utf8Str strOsType;
1049 com::Utf8Str strSnapshotFolder;
1050 bool fTeleporterEnabled;
1051 uint32_t uTeleporterPort;
1052 com::Utf8Str strTeleporterAddress;
1053 com::Utf8Str strTeleporterPassword;
1054 FaultToleranceState_T enmFaultToleranceState;
1055 uint32_t uFaultTolerancePort;
1056 com::Utf8Str strFaultToleranceAddress;
1057 com::Utf8Str strFaultTolerancePassword;
1058 uint32_t uFaultToleranceInterval;
1059 bool fRTCUseUTC;
1060};
1061
1062/**
1063 * MachineConfigFile represents an XML machine configuration. All the machine settings
1064 * that go out to the XML (or are read from it) are in here.
1065 *
1066 * NOTE: If you add any fields in here, you must update a) the constructor and b)
1067 * the operator== which is used by Machine::saveSettings(), or otherwise your settings
1068 * might never get saved.
1069 */
1070class MachineConfigFile : public ConfigFileBase
1071{
1072public:
1073 com::Guid uuid;
1074
1075 MachineUserData machineUserData;
1076
1077 com::Utf8Str strStateFile;
1078 bool fCurrentStateModified; // optional, default is true
1079 RTTIMESPEC timeLastStateChange; // optional, defaults to now
1080 bool fAborted; // optional, default is false
1081
1082 com::Guid uuidCurrentSnapshot;
1083
1084 Hardware hardwareMachine;
1085 Storage storageMachine;
1086 MediaRegistry mediaRegistry;
1087 Debugging debugging;
1088 Autostart autostart;
1089
1090 StringsMap mapExtraDataItems;
1091
1092 SnapshotsList llFirstSnapshot; // first snapshot or empty list if there's none
1093
1094 MachineConfigFile(const com::Utf8Str *pstrFilename);
1095
1096 bool operator==(const MachineConfigFile &m) const;
1097
1098 bool canHaveOwnMediaRegistry() const;
1099
1100 void importMachineXML(const xml::ElementNode &elmMachine);
1101
1102 void write(const com::Utf8Str &strFilename);
1103
1104 enum
1105 {
1106 BuildMachineXML_IncludeSnapshots = 0x01,
1107 BuildMachineXML_WriteVboxVersionAttribute = 0x02,
1108 BuildMachineXML_SkipRemovableMedia = 0x04,
1109 BuildMachineXML_MediaRegistry = 0x08,
1110 BuildMachineXML_SuppressSavedState = 0x10
1111 };
1112 void buildMachineXML(xml::ElementNode &elmMachine,
1113 uint32_t fl,
1114 std::list<xml::ElementNode*> *pllElementsWithUuidAttributes);
1115
1116 static bool isAudioDriverAllowedOnThisHost(AudioDriverType_T drv);
1117 static AudioDriverType_T getHostDefaultAudioDriver();
1118
1119private:
1120 void readNetworkAdapters(const xml::ElementNode &elmHardware, NetworkAdaptersList &ll);
1121 void readAttachedNetworkMode(const xml::ElementNode &pelmMode, bool fEnabled, NetworkAdapter &nic);
1122 void readCpuIdTree(const xml::ElementNode &elmCpuid, CpuIdLeafsList &ll);
1123 void readCpuTree(const xml::ElementNode &elmCpu, CpuList &ll);
1124 void readSerialPorts(const xml::ElementNode &elmUART, SerialPortsList &ll);
1125 void readParallelPorts(const xml::ElementNode &elmLPT, ParallelPortsList &ll);
1126 void readAudioAdapter(const xml::ElementNode &elmAudioAdapter, AudioAdapter &aa);
1127 void readGuestProperties(const xml::ElementNode &elmGuestProperties, Hardware &hw);
1128 void readStorageControllerAttributes(const xml::ElementNode &elmStorageController, StorageController &sctl);
1129 void readHardware(const xml::ElementNode &elmHardware, Hardware &hw, Storage &strg);
1130 void readHardDiskAttachments_pre1_7(const xml::ElementNode &elmHardDiskAttachments, Storage &strg);
1131 void readStorageControllers(const xml::ElementNode &elmStorageControllers, Storage &strg);
1132 void readDVDAndFloppies_pre1_9(const xml::ElementNode &elmHardware, Storage &strg);
1133 void readTeleporter(const xml::ElementNode *pElmTeleporter, MachineUserData *pUserData);
1134 void readDebugging(const xml::ElementNode *pElmDbg, Debugging *pDbg);
1135 void readAutostart(const xml::ElementNode *pElmAutostart, Autostart *pAutostart);
1136 void readGroups(const xml::ElementNode *elmGroups, StringsList *pllGroups);
1137 void readSnapshot(const xml::ElementNode &elmSnapshot, Snapshot &snap);
1138 void convertOldOSType_pre1_5(com::Utf8Str &str);
1139 void readMachine(const xml::ElementNode &elmMachine);
1140
1141 void buildHardwareXML(xml::ElementNode &elmParent, const Hardware &hw, const Storage &strg);
1142 void buildNetworkXML(NetworkAttachmentType_T mode, xml::ElementNode &elmParent, bool fEnabled, const NetworkAdapter &nic);
1143 void buildStorageControllersXML(xml::ElementNode &elmParent,
1144 const Storage &st,
1145 bool fSkipRemovableMedia,
1146 std::list<xml::ElementNode*> *pllElementsWithUuidAttributes);
1147 void buildDebuggingXML(xml::ElementNode *pElmParent, const Debugging *pDbg);
1148 void buildAutostartXML(xml::ElementNode *pElmParent, const Autostart *pAutostart);
1149 void buildGroupsXML(xml::ElementNode *pElmParent, const StringsList *pllGroups);
1150 void buildSnapshotXML(xml::ElementNode &elmParent, const Snapshot &snap);
1151
1152 void bumpSettingsVersionIfNeeded();
1153};
1154
1155} // namespace settings
1156
1157
1158#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