VirtualBox

source: vbox/trunk/src/VBox/Main/include/StorageControllerImpl.h@ 31768

Last change on this file since 31768 was 31308, checked in by vboxsync, 14 years ago

Main: storage controller/attachment cleanup

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 3.5 KB
Line 
1/* $Id: StorageControllerImpl.h 31308 2010-08-02 14:55:22Z vboxsync $ */
2
3/** @file
4 *
5 * VBox StorageController COM Class declaration.
6 */
7
8/*
9 * Copyright (C) 2008 Oracle Corporation
10 *
11 * This file is part of VirtualBox Open Source Edition (OSE), as
12 * available from http://www.virtualbox.org. This file is free software;
13 * you can redistribute it and/or modify it under the terms of the GNU
14 * General Public License (GPL) as published by the Free Software
15 * Foundation, in version 2 as it comes in the "COPYING" file of the
16 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
17 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
18 */
19
20#ifndef ____H_STORAGECONTROLLERIMPL
21#define ____H_STORAGECONTROLLERIMPL
22
23#include "VirtualBoxBase.h"
24
25class ATL_NO_VTABLE StorageController :
26 public VirtualBoxBase,
27 VBOX_SCRIPTABLE_IMPL(IStorageController)
28{
29public:
30
31 VIRTUALBOXBASE_ADD_ERRORINFO_SUPPORT(StorageController, IStorageController)
32
33 DECLARE_NOT_AGGREGATABLE (StorageController)
34
35 DECLARE_PROTECT_FINAL_CONSTRUCT()
36
37 BEGIN_COM_MAP(StorageController)
38 COM_INTERFACE_ENTRY (ISupportErrorInfo)
39 COM_INTERFACE_ENTRY (IStorageController)
40 COM_INTERFACE_ENTRY2 (IDispatch, IStorageController)
41 END_COM_MAP()
42
43 StorageController() { };
44 ~StorageController() { };
45
46 HRESULT FinalConstruct();
47 void FinalRelease();
48
49 // public initializer/uninitializer for internal purposes only
50 HRESULT init(Machine *aParent,
51 const Utf8Str &aName,
52 StorageBus_T aBus,
53 ULONG aInstance);
54 HRESULT init(Machine *aParent,
55 StorageController *aThat,
56 bool aReshare = false);
57 HRESULT initCopy(Machine *aParent,
58 StorageController *aThat);
59 void uninit();
60
61 // IStorageController properties
62 STDMETHOD(COMGETTER(Name)) (BSTR *aName);
63 STDMETHOD(COMGETTER(Bus)) (StorageBus_T *aBus);
64 STDMETHOD(COMGETTER(ControllerType)) (StorageControllerType_T *aControllerType);
65 STDMETHOD(COMSETTER(ControllerType)) (StorageControllerType_T aControllerType);
66 STDMETHOD(COMGETTER(MaxDevicesPerPortCount)) (ULONG *aMaxDevices);
67 STDMETHOD(COMGETTER(MinPortCount)) (ULONG *aMinPortCount);
68 STDMETHOD(COMGETTER(MaxPortCount)) (ULONG *aMaxPortCount);
69 STDMETHOD(COMGETTER(PortCount)) (ULONG *aPortCount);
70 STDMETHOD(COMSETTER(PortCount)) (ULONG aPortCount);
71 STDMETHOD(COMGETTER(Instance)) (ULONG *aInstance);
72 STDMETHOD(COMSETTER(Instance)) (ULONG aInstance);
73 STDMETHOD(COMGETTER(UseHostIOCache)) (BOOL *fUseHostIOCache);
74 STDMETHOD(COMSETTER(UseHostIOCache)) (BOOL fUseHostIOCache);
75
76 // StorageController methods
77 STDMETHOD(GetIDEEmulationPort) (LONG DevicePosition, LONG *aPortNumber);
78 STDMETHOD(SetIDEEmulationPort) (LONG DevicePosition, LONG aPortNumber);
79
80 // public methods only for internal purposes
81
82 const Utf8Str &getName() const;
83 StorageControllerType_T getControllerType() const;
84 StorageBus_T getStorageBus() const;
85 ULONG getInstance() const;
86
87 HRESULT checkPortAndDeviceValid(LONG aControllerPort,
88 LONG aDevice);
89
90 void rollback();
91 void commit();
92
93 // public methods for internal purposes only
94 // (ensure there is a caller and a read lock before calling them!)
95
96 void unshare();
97
98 /** @note this doesn't require a read lock since mParent is constant. */
99 Machine* getMachine();
100
101 ComObjPtr<StorageController> getPeer();
102
103private:
104
105 void printList();
106
107 struct Data;
108 Data *m;
109};
110
111#endif //!____H_STORAGECONTROLLERIMPL
112/* 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