[101035] | 1 | /* $Id: PlatformImpl.h 106061 2024-09-16 14:03:52Z vboxsync $ */
|
---|
| 2 | /** @file
|
---|
| 3 | * VirtualBox COM class implementation - Platform settings.
|
---|
| 4 | */
|
---|
| 5 |
|
---|
| 6 | /*
|
---|
[106061] | 7 | * Copyright (C) 2023-2024 Oracle and/or its affiliates.
|
---|
[101035] | 8 | *
|
---|
| 9 | * This file is part of VirtualBox base platform packages, as
|
---|
| 10 | * available from https://www.virtualbox.org.
|
---|
| 11 | *
|
---|
| 12 | * This program is free software; you can redistribute it and/or
|
---|
| 13 | * modify it under the terms of the GNU General Public License
|
---|
| 14 | * as published by the Free Software Foundation, in version 3 of the
|
---|
| 15 | * License.
|
---|
| 16 | *
|
---|
| 17 | * This program is distributed in the hope that it will be useful, but
|
---|
| 18 | * WITHOUT ANY WARRANTY; without even the implied warranty of
|
---|
| 19 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
---|
| 20 | * General Public License for more details.
|
---|
| 21 | *
|
---|
| 22 | * You should have received a copy of the GNU General Public License
|
---|
| 23 | * along with this program; if not, see <https://www.gnu.org/licenses>.
|
---|
| 24 | *
|
---|
| 25 | * SPDX-License-Identifier: GPL-3.0-only
|
---|
| 26 | */
|
---|
| 27 |
|
---|
[101044] | 28 | #ifndef MAIN_INCLUDED_PlatformImpl_h
|
---|
| 29 | #define MAIN_INCLUDED_PlatformImpl_h
|
---|
[101035] | 30 | #ifndef RT_WITHOUT_PRAGMA_ONCE
|
---|
| 31 | # pragma once
|
---|
| 32 | #endif
|
---|
| 33 |
|
---|
| 34 | #include "PlatformWrap.h"
|
---|
| 35 | #include "PlatformBase.h"
|
---|
| 36 |
|
---|
| 37 | class GuestOSType;
|
---|
| 38 | class PlatformARM;
|
---|
| 39 | class PlatformX86;
|
---|
| 40 |
|
---|
| 41 | namespace settings
|
---|
| 42 | {
|
---|
| 43 | struct Platform;
|
---|
| 44 | }
|
---|
| 45 |
|
---|
| 46 | class ATL_NO_VTABLE Platform :
|
---|
| 47 | public PlatformWrap
|
---|
| 48 | {
|
---|
| 49 | public:
|
---|
| 50 |
|
---|
| 51 | DECLARE_COMMON_CLASS_METHODS(Platform)
|
---|
| 52 |
|
---|
| 53 | HRESULT FinalConstruct();
|
---|
| 54 | void FinalRelease();
|
---|
| 55 |
|
---|
| 56 | // public initializer/uninitializer for internal purposes only
|
---|
| 57 | HRESULT init(Machine *aParent);
|
---|
| 58 | HRESULT init(Machine *parent, Platform *that);
|
---|
| 59 | HRESULT initCopy(Machine *parent, Platform *that);
|
---|
| 60 | void uninit();
|
---|
| 61 |
|
---|
| 62 | // public internal methods
|
---|
| 63 | HRESULT i_loadSettings(const settings::Platform &data);
|
---|
| 64 | HRESULT i_saveSettings(settings::Platform &data);
|
---|
| 65 |
|
---|
| 66 | void i_rollback();
|
---|
| 67 | void i_commit();
|
---|
| 68 | void i_copyFrom(Platform *aThat);
|
---|
| 69 |
|
---|
| 70 | HRESULT i_initArchitecture(PlatformArchitecture_T aArchitecture, Platform *that = NULL, bool fCopy = false);
|
---|
| 71 | HRESULT i_applyDefaults(GuestOSType *aOsType);
|
---|
| 72 |
|
---|
[105959] | 73 | PlatformArchitecture_T i_getArchitecture();
|
---|
| 74 |
|
---|
[101063] | 75 | public:
|
---|
| 76 |
|
---|
[101035] | 77 | // wrapped IPlatform properties
|
---|
| 78 | HRESULT getArchitecture(PlatformArchitecture_T *aArchitecture);
|
---|
| 79 | HRESULT setArchitecture(PlatformArchitecture_T aArchitecture);
|
---|
| 80 | HRESULT getProperties(ComPtr<IPlatformProperties> &aProperties);
|
---|
| 81 | HRESULT getX86(ComPtr<IPlatformX86> &aX86);
|
---|
| 82 | HRESULT getARM(ComPtr<IPlatformARM> &aARM);
|
---|
| 83 | HRESULT getChipsetType(ChipsetType_T *aChipsetType);
|
---|
| 84 | HRESULT setChipsetType(ChipsetType_T aChipsetType);
|
---|
| 85 | HRESULT getIommuType(IommuType_T *aIommuType);
|
---|
| 86 | HRESULT setIommuType(IommuType_T aIommuType);
|
---|
| 87 | HRESULT getRTCUseUTC(BOOL *aRTCUseUTC);
|
---|
| 88 | HRESULT setRTCUseUTC(BOOL aRTCUseUTC);
|
---|
| 89 |
|
---|
| 90 | private:
|
---|
| 91 |
|
---|
| 92 | // private functions only used internally
|
---|
| 93 | void uninitArchitecture();
|
---|
| 94 |
|
---|
| 95 | private:
|
---|
| 96 |
|
---|
| 97 | // wrapped IPlatform methods
|
---|
| 98 |
|
---|
| 99 | Machine * const mParent;
|
---|
| 100 |
|
---|
| 101 | struct Data;
|
---|
| 102 | Data *m;
|
---|
| 103 |
|
---|
| 104 | // The following fields need special backup/rollback/commit handling,
|
---|
| 105 | // so they cannot be a part of Data above.
|
---|
| 106 |
|
---|
| 107 | /** Contains x86-specific platform data.
|
---|
| 108 | * Only created if platform architecture is x86. */
|
---|
| 109 | const ComObjPtr<PlatformX86> mX86;
|
---|
| 110 | #ifdef VBOX_WITH_VIRT_ARMV8
|
---|
| 111 | /** Contains ARM-specific platform data.
|
---|
| 112 | * Only created if platform architecture is ARM. */
|
---|
| 113 | const ComObjPtr<PlatformARM> mARM;
|
---|
| 114 | #endif
|
---|
| 115 | };
|
---|
| 116 |
|
---|
[101044] | 117 | #endif /* !MAIN_INCLUDED_PlatformImpl_h */
|
---|
[101035] | 118 |
|
---|