- Timestamp:
- Mar 5, 2010 6:03:49 PM (15 years ago)
- File:
-
- 1 copied
Legend:
- Unmodified
- Added
- Removed
-
trunk/src/VBox/Main/include/MediumLock.h
r25892 r27120 3 3 /** @file 4 4 * 5 * VirtualBox COM global declarations5 * VirtualBox medium object lock collections 6 6 */ 7 7 8 8 /* 9 * Copyright (C) 20 08Sun Microsystems, Inc.9 * Copyright (C) 2010 Sun Microsystems, Inc. 10 10 * 11 11 * This file is part of VirtualBox Open Source Edition (OSE), as … … 22 22 */ 23 23 24 #ifndef ____H_GLOBAL 25 #define ____H_GLOBAL 26 27 /* generated header */ 28 #include "SchemaDefs.h" 24 #ifndef ____H_MEDIUMLOCK 25 #define ____H_MEDIUMLOCK 29 26 30 27 /* interface definitions */ 31 28 #include "VBox/com/VirtualBox.h" 32 29 33 #include <VBox/ostypes.h>34 35 30 #include <iprt/types.h> 36 31 37 #define VBOXOSHINT_NONE 0 38 #define VBOXOSHINT_64BIT RT_BIT(0) 39 #define VBOXOSHINT_HWVIRTEX RT_BIT(1) 40 #define VBOXOSHINT_IOAPIC RT_BIT(2) 32 /** 33 * Single entry for medium lock lists. Has a medium object reference, 34 * information about what kind of lock should be taken, and if it is 35 * locked right now. 36 */ 37 class MediumLock 38 { 39 public: 40 /** 41 * Default medium lock constructor. 42 */ 43 MediumLock(); 44 45 /** 46 * Default medium lock destructor. 47 */ 48 ~MediumLock(); 49 50 /** 51 * Create a new medium lock description 52 * 53 * @param aMedium Reference to medium object 54 * @param aLockWrite @c true means a write lock should be taken 55 */ 56 MediumLock(ComObjPtr<Medium> aMedium, bool aLockWrite); 57 58 /** 59 * Acquire a medium lock. 60 */ 61 int Lock(); 62 63 /** 64 * Release a medium lock. 65 */ 66 int Unlock(); 67 68 private: 69 ComObjPtr<Medium> mMedium; 70 bool mLockWrite; 71 }; 72 41 73 42 74 /** 43 * Contains global static definitions that can be referenced by all COM classes44 * regardless of the apartment.75 * Medium lock list. Meant for storing the ordered locking information 76 * for a single medium chain. 45 77 */ 46 class Global78 class MediumLockList 47 79 { 48 80 public: 49 81 50 /** Represents OS Type <-> string mappings. */ 51 struct OSType 52 { 53 const char *familyId; /* utf-8 */ 54 const char *familyDescription; /* utf-8 */ 55 const char *id; /* utf-8 */ 56 const char *description; /* utf-8 */ 57 const VBOXOSTYPE osType; 58 const uint32_t osHint; 59 const uint32_t recommendedRAM; 60 const uint32_t recommendedVRAM; 61 const uint32_t recommendedHDD; 62 const NetworkAdapterType_T networkAdapterType; 63 const uint32_t numSerialEnabled; 64 }; 65 66 static const OSType sOSTypes[SchemaDefs::OSTypeId_COUNT]; 67 68 static const char *OSTypeId(VBOXOSTYPE aOSType); 82 /** 83 * Default medium lock list constructor. 84 */ 85 MediumLockList(); 69 86 70 87 /** 71 * Returns @c true if the given machine state is an online state. This is a 72 * recommended way to detect if the VM is online (being executed in a 73 * dedicated process) or not. Note that some online states are also 74 * transitional states (see #IsTransitional()). 75 * 76 * @remarks Saving may actually be an offline state according to the 77 * documentation (offline snapshot). 88 * Default medium lock list destructor. 78 89 */ 79 static bool IsOnline(MachineState_T aState) 80 { 81 #if 0 82 return aState >= MachineState_FirstOnline && 83 aState <= MachineState_LastOnline; 84 #else 85 switch (aState) 86 { 87 case MachineState_Running: 88 case MachineState_Paused: 89 case MachineState_Teleporting: 90 case MachineState_LiveSnapshotting: 91 case MachineState_Stuck: 92 case MachineState_Starting: 93 case MachineState_Stopping: 94 case MachineState_Saving: 95 case MachineState_Restoring: 96 case MachineState_TeleportingPausedVM: 97 case MachineState_TeleportingIn: 98 return true; 99 default: 100 return false; 101 } 102 #endif 103 } 90 ~MediumLockList(); 104 91 105 92 /** 106 * Returns @c true if the given machine state is a transient state. This is 107 * a recommended way to detect if the VM is performing some potentially 108 * lengthy operation (such as starting, stopping, saving, discarding 109 * snapshot, etc.). Note some (but not all) transitional states are also 110 * online states (see #IsOnline()). 93 * Add a new medium lock declaration to the end of the list. 94 * 95 * @note May be only used in unlocked state. 96 * 97 * @return VBox status code. 98 * @param aMedium Reference to medium object 99 * @param aLockWrite @c true means a write lock should be taken 111 100 */ 112 static bool IsTransient(MachineState_T aState) 113 { 114 #if 0 115 return aState >= MachineState_FirstTransient && 116 aState <= MachineState_LastTransient; 117 #else 118 switch (aState) 119 { 120 case MachineState_Teleporting: 121 case MachineState_LiveSnapshotting: 122 case MachineState_Starting: 123 case MachineState_Stopping: 124 case MachineState_Saving: 125 case MachineState_Restoring: 126 case MachineState_TeleportingPausedVM: 127 case MachineState_TeleportingIn: 128 case MachineState_RestoringSnapshot: 129 case MachineState_DeletingSnapshot: 130 case MachineState_SettingUp: 131 return true; 132 default: 133 return false; 134 } 135 #endif 136 } 101 int Append(ComObjPtr<Medium> aMedium, bool aLockWrite); 137 102 138 103 /** 139 * Shortcut to <tt>IsOnline(aState) || IsTransient(aState)</tt>. When it returns 140 * @false, the VM is turned off (no VM process) and not busy with 141 * another exclusive operation. 104 * Add a new medium lock declaration to the beginning of the list. 105 * 106 * @note May be only used in unlocked state. 107 * 108 * @return VBox status code. 109 * @param aMedium Reference to medium object 110 * @param aLockWrite @c true means a write lock should be taken 142 111 */ 143 static bool IsOnlineOrTransient(MachineState_T aState) 144 { 145 return IsOnline(aState) || IsTransient(aState); 146 } 112 int Prepend(ComObjPtr<Medium> aMedium, bool aLockWrite); 147 113 148 114 /** 149 * Stringify a machine state.115 * Update a medium lock declaration. 150 116 * 151 * @returns Pointer to a read only string. 152 * @param aState Valid machine state. 117 * @note May be only used in unlocked state. 118 * 119 * @return VBox status code. 120 * @param aMedium Reference to medium object 121 * @param aLockWrite @c true means a write lock should be taken 153 122 */ 154 static const char *stringifyMachineState(MachineState_T aState);123 int Update(ComObjPtr<Medium> aMedium, bool aLockWrite); 155 124 156 125 /** 157 * Stringify a session state.126 * Remove a medium lock declaration. 158 127 * 159 * @returns Pointer to a read only string. 160 * @param aState Valid session state. 128 * @note May be only used in unlocked state. 129 * 130 * @return VBox status code. 131 * @param aMedium Reference to medium object 161 132 */ 162 static const char *stringifySessionState(SessionState_T aState);133 int Remove(ComObjPtr<Medium> aMedium); 163 134 164 135 /** 165 * Stringify a device type. 166 * 167 * @returns Pointer to a read only string. 168 * @param aType The device type. 136 * Acquire all medium locks "atomically", i.e. all or nothing. 169 137 */ 170 static const char *stringifyDeviceType(DeviceType_T aType);138 int Lock(); 171 139 172 140 /** 173 * Try convert a COM status code to a VirtualBox status code (VBox/err.h). 174 * 175 * @returns VBox status code. 176 * @param aComStatus COM status code. 141 * Release all medium locks. 177 142 */ 178 static int vboxStatusCodeFromCOM(HRESULT aComStatus); 143 int Unlock(); 144 145 private: 146 std::list<MediumLock> mMediumLocks; 147 bool mIsLocked; 148 } 149 150 /** 151 * Medium lock list map. Meant for storing a collection of lock lists. 152 * The usual use case is creating such a map when locking all medium chains 153 * belonging to one VM, however that's not the limit. Be creative. 154 */ 155 class MediumLockListMap 156 { 157 public: 179 158 180 159 /** 181 * Try convert a VirtualBox status code (VBox/err.h) to a COM status code. 182 * 183 * This is mainly inteded for dealing with vboxStatusCodeFromCOM() return 184 * values. If used on anything else, it won't be able to cope with most of the 185 * input! 186 * 187 * @returns COM status code. 188 * @param aVBoxStatus VBox status code. 160 * Default medium lock list map constructor. 189 161 */ 190 static HRESULT vboxStatusCodeToCOM(int aVBoxStatus); 191 }; 162 MediumLockListMap(); 192 163 193 #endif /* !____H_GLOBAL */ 164 /** 165 * Default medium lock list destructor. 166 */ 167 ~MediumLockListMap(); 168 169 private: 170 std::map<ComObjPtr<Medium>, MediumLockList *> mMediumLocks; 171 } 172 173 #endif /* !____H_MEDIUMLOCK */ 194 174 /* vi: set tabstop=4 shiftwidth=4 expandtab: */
Note:
See TracChangeset
for help on using the changeset viewer.