VirtualBox

source: vbox/trunk/src/VBox/Main/include/MediumAttachmentImpl.h@ 49240

Last change on this file since 49240 was 48879, checked in by vboxsync, 11 years ago

Main/MediumAttachment+Machine: stub attribute/method for an explicit hot-pluggable medium attachment flag, to be used by AHCI soon

  • Property svn:eol-style set to native
File size: 4.5 KB
Line 
1/** @file
2 *
3 * VirtualBox COM class implementation
4 */
5
6/*
7 * Copyright (C) 2006-2013 Oracle Corporation
8 *
9 * This file is part of VirtualBox Open Source Edition (OSE), as
10 * available from http://www.virtualbox.org. This file is free software;
11 * you can redistribute it and/or modify it under the terms of the GNU
12 * General Public License (GPL) as published by the Free Software
13 * Foundation, in version 2 as it comes in the "COPYING" file of the
14 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16 */
17
18#ifndef ____H_MEDIUMATTACHMENTIMPL
19#define ____H_MEDIUMATTACHMENTIMPL
20
21#include "VirtualBoxBase.h"
22#include "BandwidthGroupImpl.h"
23
24class ATL_NO_VTABLE MediumAttachment :
25 public VirtualBoxBase,
26 VBOX_SCRIPTABLE_IMPL(IMediumAttachment)
27{
28public:
29 VIRTUALBOXBASE_ADD_ERRORINFO_SUPPORT(MediumAttachment, IMediumAttachment)
30
31 DECLARE_NOT_AGGREGATABLE(MediumAttachment)
32
33 DECLARE_PROTECT_FINAL_CONSTRUCT()
34
35 BEGIN_COM_MAP(MediumAttachment)
36 VBOX_DEFAULT_INTERFACE_ENTRIES(IMediumAttachment)
37 END_COM_MAP()
38
39 MediumAttachment() { };
40 ~MediumAttachment() { };
41
42 // public initializer/uninitializer for internal purposes only
43 HRESULT init(Machine *aParent,
44 Medium *aMedium,
45 const Bstr &aControllerName,
46 LONG aPort,
47 LONG aDevice,
48 DeviceType_T aType,
49 bool fImplicit,
50 bool fPassthrough,
51 bool fTempEject,
52 bool fNonRotational,
53 bool fDiscard,
54 bool fHotPluggable,
55 const Utf8Str &strBandwidthGroup);
56 HRESULT initCopy(Machine *aParent, MediumAttachment *aThat);
57 void uninit();
58
59 HRESULT FinalConstruct();
60 void FinalRelease();
61
62 // IMediumAttachment properties
63 STDMETHOD(COMGETTER(Medium))(IMedium **aMedium);
64 STDMETHOD(COMGETTER(Controller))(BSTR *aController);
65 STDMETHOD(COMGETTER(Port))(LONG *aPort);
66 STDMETHOD(COMGETTER(Device))(LONG *aDevice);
67 STDMETHOD(COMGETTER(Type))(DeviceType_T *aType);
68 STDMETHOD(COMGETTER(Passthrough))(BOOL *aPassthrough);
69 STDMETHOD(COMGETTER(TemporaryEject))(BOOL *aTemporaryEject);
70 STDMETHOD(COMGETTER(IsEjected))(BOOL *aIsEjected);
71 STDMETHOD(COMGETTER(NonRotational))(BOOL *aNonRotational);
72 STDMETHOD(COMGETTER(Discard))(BOOL *aDiscard);
73 STDMETHOD(COMGETTER(BandwidthGroup))(IBandwidthGroup **aBwGroup);
74 STDMETHOD(COMGETTER(HotPluggable))(BOOL *aHotPluggable);
75
76 // public internal methods
77 void rollback();
78 void commit();
79
80 // unsafe public methods for internal purposes only (ensure there is
81 // a caller and a read lock before calling them!)
82 bool isImplicit() const;
83 void setImplicit(bool aImplicit);
84
85 const ComObjPtr<Medium>& getMedium() const;
86 Bstr getControllerName() const;
87 LONG getPort() const;
88 LONG getDevice() const;
89 DeviceType_T getType() const;
90 bool getPassthrough() const;
91 bool getTempEject() const;
92 bool getNonRotational() const;
93 bool getDiscard() const;
94 const Utf8Str& getBandwidthGroup() const;
95 bool getHotPluggable() const;
96
97 bool matches(CBSTR aControllerName, LONG aPort, LONG aDevice);
98
99 /** Must be called from under this object's write lock. */
100 void updateMedium(const ComObjPtr<Medium> &aMedium);
101
102 /** Must be called from under this object's write lock. */
103 void updatePassthrough(bool aPassthrough);
104
105 /** Must be called from under this object's write lock. */
106 void updateTempEject(bool aTempEject);
107
108 /** Must be called from under this object's write lock. */
109 void updateNonRotational(bool aNonRotational);
110
111 /** Must be called from under this object's write lock. */
112 void updateDiscard(bool aDiscard);
113
114 /** Must be called from under this object's write lock. */
115 void updateEjected();
116
117 /** Must be called from under this object's write lock. */
118 void updateBandwidthGroup(const Utf8Str &aBandwidthGroup);
119
120 void updateParentMachine(Machine * const pMachine);
121
122 /** Must be called from under this object's write lock. */
123 void updateHotPluggable(bool aHotPluggable);
124
125 /** Get a unique and somewhat descriptive name for logging. */
126 const char* getLogName(void) const { return mLogName.c_str(); }
127
128private:
129 struct Data;
130 Data *m;
131
132 Utf8Str mLogName; /**< For logging purposes */
133};
134
135#endif // ____H_MEDIUMATTACHMENTIMPL
136/* vi: set tabstop=4 shiftwidth=4 expandtab: */
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