VirtualBox

source: vbox/trunk/src/VBox/Main/include/ConsoleImpl.h@ 43023

Last change on this file since 43023 was 42551, checked in by vboxsync, 12 years ago

Main: big API naming cleanup, use all caps acronyms everywhere, including SDK docs
Frontends/VBoxManage: implement guestcontrol execute for new API, disabled by default

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 36.5 KB
Line 
1/* $Id: ConsoleImpl.h 42551 2012-08-02 16:44:39Z vboxsync $ */
2/** @file
3 * VBox Console COM Class definition
4 */
5
6/*
7 * Copyright (C) 2005-2012 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_CONSOLEIMPL
19#define ____H_CONSOLEIMPL
20
21#include "VirtualBoxBase.h"
22#include "VBox/com/array.h"
23#include "EventImpl.h"
24
25class Guest;
26class Keyboard;
27class Mouse;
28class Display;
29class MachineDebugger;
30class TeleporterStateSrc;
31class OUSBDevice;
32class RemoteUSBDevice;
33class SharedFolder;
34class VRDEServerInfo;
35class AudioSniffer;
36#ifdef VBOX_WITH_USB_VIDEO
37class UsbWebcamInterface;
38#endif
39#ifdef VBOX_WITH_USB_CARDREADER
40class UsbCardReader;
41#endif
42class ConsoleVRDPServer;
43class VMMDev;
44class Progress;
45class BusAssignmentManager;
46COM_STRUCT_OR_CLASS(IEventListener);
47#ifdef VBOX_WITH_EXTPACK
48class ExtPackManager;
49#endif
50
51#include <VBox/RemoteDesktop/VRDE.h>
52#include <VBox/vmm/pdmdrv.h>
53#ifdef VBOX_WITH_GUEST_PROPS
54# include <VBox/HostServices/GuestPropertySvc.h> /* For the property notification callback */
55#endif
56
57#ifdef RT_OS_WINDOWS
58# include "../src-server/win/VBoxComEvents.h"
59#endif
60
61struct VUSBIRHCONFIG;
62typedef struct VUSBIRHCONFIG *PVUSBIRHCONFIG;
63
64#include <list>
65#include <vector>
66
67// defines
68///////////////////////////////////////////////////////////////////////////////
69
70/**
71 * Checks the availability of the underlying VM device driver corresponding
72 * to the COM interface (IKeyboard, IMouse, IDisplay, etc.). When the driver is
73 * not available (NULL), sets error info and returns returns E_ACCESSDENIED.
74 * The translatable error message is defined in null context.
75 *
76 * Intended to used only within Console children (i.e. Keyboard, Mouse,
77 * Display, etc.).
78 *
79 * @param drv driver pointer to check (compare it with NULL)
80 */
81#define CHECK_CONSOLE_DRV(drv) \
82 do { \
83 if (!(drv)) \
84 return setError(E_ACCESSDENIED, tr("The console is not powered up")); \
85 } while (0)
86
87// Console
88///////////////////////////////////////////////////////////////////////////////
89
90/** IConsole implementation class */
91class ATL_NO_VTABLE Console :
92 public VirtualBoxBase,
93 VBOX_SCRIPTABLE_IMPL(IConsole)
94{
95 Q_OBJECT
96
97public:
98
99 VIRTUALBOXBASE_ADD_ERRORINFO_SUPPORT(Console, IConsole)
100
101 DECLARE_NOT_AGGREGATABLE(Console)
102
103 DECLARE_PROTECT_FINAL_CONSTRUCT()
104
105 BEGIN_COM_MAP(Console)
106 VBOX_DEFAULT_INTERFACE_ENTRIES(IConsole)
107 END_COM_MAP()
108
109 Console();
110 ~Console();
111
112 HRESULT FinalConstruct();
113 void FinalRelease();
114
115 // public initializers/uninitializers for internal purposes only
116 HRESULT init(IMachine *aMachine, IInternalMachineControl *aControl, LockType_T aLockType);
117 void uninit();
118
119 // IConsole properties
120 STDMETHOD(COMGETTER(Machine))(IMachine **aMachine);
121 STDMETHOD(COMGETTER(State))(MachineState_T *aMachineState);
122 STDMETHOD(COMGETTER(Guest))(IGuest **aGuest);
123 STDMETHOD(COMGETTER(Keyboard))(IKeyboard **aKeyboard);
124 STDMETHOD(COMGETTER(Mouse))(IMouse **aMouse);
125 STDMETHOD(COMGETTER(Display))(IDisplay **aDisplay);
126 STDMETHOD(COMGETTER(Debugger))(IMachineDebugger **aDebugger);
127 STDMETHOD(COMGETTER(USBDevices))(ComSafeArrayOut(IUSBDevice *, aUSBDevices));
128 STDMETHOD(COMGETTER(RemoteUSBDevices))(ComSafeArrayOut(IHostUSBDevice *, aRemoteUSBDevices));
129 STDMETHOD(COMGETTER(VRDEServerInfo))(IVRDEServerInfo **aVRDEServerInfo);
130 STDMETHOD(COMGETTER(SharedFolders))(ComSafeArrayOut(ISharedFolder *, aSharedFolders));
131 STDMETHOD(COMGETTER(EventSource)) (IEventSource ** aEventSource);
132 STDMETHOD(COMGETTER(AttachedPCIDevices))(ComSafeArrayOut(IPCIDeviceAttachment *, aAttachments));
133 STDMETHOD(COMGETTER(UseHostClipboard))(BOOL *aUseHostClipboard);
134 STDMETHOD(COMSETTER(UseHostClipboard))(BOOL aUseHostClipboard);
135
136 // IConsole methods
137 STDMETHOD(PowerUp)(IProgress **aProgress);
138 STDMETHOD(PowerUpPaused)(IProgress **aProgress);
139 STDMETHOD(PowerDown)(IProgress **aProgress);
140 STDMETHOD(Reset)();
141 STDMETHOD(Pause)();
142 STDMETHOD(Resume)();
143 STDMETHOD(PowerButton)();
144 STDMETHOD(SleepButton)();
145 STDMETHOD(GetPowerButtonHandled)(BOOL *aHandled);
146 STDMETHOD(GetGuestEnteredACPIMode)(BOOL *aEntered);
147 STDMETHOD(SaveState)(IProgress **aProgress);
148 STDMETHOD(AdoptSavedState)(IN_BSTR aSavedStateFile);
149 STDMETHOD(DiscardSavedState)(BOOL aRemoveFile);
150 STDMETHOD(GetDeviceActivity)(DeviceType_T aDeviceType,
151 DeviceActivity_T *aDeviceActivity);
152 STDMETHOD(AttachUSBDevice)(IN_BSTR aId);
153 STDMETHOD(DetachUSBDevice)(IN_BSTR aId, IUSBDevice **aDevice);
154 STDMETHOD(FindUSBDeviceByAddress)(IN_BSTR aAddress, IUSBDevice **aDevice);
155 STDMETHOD(FindUSBDeviceById)(IN_BSTR aId, IUSBDevice **aDevice);
156 STDMETHOD(CreateSharedFolder)(IN_BSTR aName, IN_BSTR aHostPath, BOOL aWritable, BOOL aAutoMount);
157 STDMETHOD(RemoveSharedFolder)(IN_BSTR aName);
158 STDMETHOD(TakeSnapshot)(IN_BSTR aName, IN_BSTR aDescription,
159 IProgress **aProgress);
160 STDMETHOD(DeleteSnapshot)(IN_BSTR aId, IProgress **aProgress);
161 STDMETHOD(DeleteSnapshotAndAllChildren)(IN_BSTR aId, IProgress **aProgress);
162 STDMETHOD(DeleteSnapshotRange)(IN_BSTR aStartId, IN_BSTR aEndId, IProgress **aProgress);
163 STDMETHOD(RestoreSnapshot)(ISnapshot *aSnapshot, IProgress **aProgress);
164 STDMETHOD(Teleport)(IN_BSTR aHostname, ULONG aPort, IN_BSTR aPassword, ULONG aMaxDowntime, IProgress **aProgress);
165
166 // public methods for internal purposes only
167
168 /*
169 * Note: the following methods do not increase refcount. intended to be
170 * called only by the VM execution thread.
171 */
172
173 Guest *getGuest() const { return mGuest; }
174 Keyboard *getKeyboard() const { return mKeyboard; }
175 Mouse *getMouse() const { return mMouse; }
176 Display *getDisplay() const { return mDisplay; }
177 MachineDebugger *getMachineDebugger() const { return mDebugger; }
178 AudioSniffer *getAudioSniffer() const { return mAudioSniffer; }
179
180 const ComPtr<IMachine> &machine() const { return mMachine; }
181
182 bool useHostClipboard() { return mfUseHostClipboard; }
183
184 /** Method is called only from ConsoleVRDPServer */
185 IVRDEServer *getVRDEServer() const { return mVRDEServer; }
186
187 ConsoleVRDPServer *consoleVRDPServer() const { return mConsoleVRDPServer; }
188
189 HRESULT updateMachineState(MachineState_T aMachineState);
190
191 // events from IInternalSessionControl
192 HRESULT onNetworkAdapterChange(INetworkAdapter *aNetworkAdapter, BOOL changeAdapter);
193 HRESULT onSerialPortChange(ISerialPort *aSerialPort);
194 HRESULT onParallelPortChange(IParallelPort *aParallelPort);
195 HRESULT onStorageControllerChange();
196 HRESULT onMediumChange(IMediumAttachment *aMediumAttachment, BOOL aForce);
197 HRESULT onCPUChange(ULONG aCPU, BOOL aRemove);
198 HRESULT onCPUExecutionCapChange(ULONG aExecutionCap);
199 HRESULT onClipboardModeChange(ClipboardMode_T aClipboardMode);
200 HRESULT onDragAndDropModeChange(DragAndDropMode_T aDragAndDropMode);
201 HRESULT onVRDEServerChange(BOOL aRestart);
202 HRESULT onUSBControllerChange();
203 HRESULT onSharedFolderChange(BOOL aGlobal);
204 HRESULT onUSBDeviceAttach(IUSBDevice *aDevice, IVirtualBoxErrorInfo *aError, ULONG aMaskedIfs);
205 HRESULT onUSBDeviceDetach(IN_BSTR aId, IVirtualBoxErrorInfo *aError);
206 HRESULT onBandwidthGroupChange(IBandwidthGroup *aBandwidthGroup);
207 HRESULT onStorageDeviceChange(IMediumAttachment *aMediumAttachment, BOOL aRemove);
208 HRESULT getGuestProperty(IN_BSTR aKey, BSTR *aValue, LONG64 *aTimestamp, BSTR *aFlags);
209 HRESULT setGuestProperty(IN_BSTR aKey, IN_BSTR aValue, IN_BSTR aFlags);
210 HRESULT enumerateGuestProperties(IN_BSTR aPatterns,
211 ComSafeArrayOut(BSTR, aNames),
212 ComSafeArrayOut(BSTR, aValues),
213 ComSafeArrayOut(LONG64, aTimestamps),
214 ComSafeArrayOut(BSTR, aFlags));
215 HRESULT onlineMergeMedium(IMediumAttachment *aMediumAttachment,
216 ULONG aSourceIdx, ULONG aTargetIdx,
217 IMedium *aSource, IMedium *aTarget,
218 BOOL aMergeForward, IMedium *aParentForTarget,
219 ComSafeArrayIn(IMedium *, aChildrenToReparent),
220 IProgress *aProgress);
221 VMMDev *getVMMDev() { return m_pVMMDev; }
222 AudioSniffer *getAudioSniffer() { return mAudioSniffer; }
223#ifdef VBOX_WITH_EXTPACK
224 ExtPackManager *getExtPackManager();
225#endif
226 EventSource *getEventSource() { return mEventSource; }
227#ifdef VBOX_WITH_USB_CARDREADER
228 UsbCardReader *getUsbCardReader() { return mUsbCardReader; }
229#endif
230
231 int VRDPClientLogon(uint32_t u32ClientId, const char *pszUser, const char *pszPassword, const char *pszDomain);
232 void VRDPClientStatusChange(uint32_t u32ClientId, const char *pszStatus);
233 void VRDPClientConnect(uint32_t u32ClientId);
234 void VRDPClientDisconnect(uint32_t u32ClientId, uint32_t fu32Intercepted);
235 void VRDPInterceptAudio(uint32_t u32ClientId);
236 void VRDPInterceptUSB(uint32_t u32ClientId, void **ppvIntercept);
237 void VRDPInterceptClipboard(uint32_t u32ClientId);
238
239 void processRemoteUSBDevices(uint32_t u32ClientId, VRDEUSBDEVICEDESC *pDevList, uint32_t cbDevList, bool fDescExt);
240 void reportGuestStatistics(ULONG aValidStats, ULONG aCpuUser,
241 ULONG aCpuKernel, ULONG aCpuIdle,
242 ULONG aMemTotal, ULONG aMemFree,
243 ULONG aMemBalloon, ULONG aMemShared,
244 ULONG aMemCache, ULONG aPageTotal,
245 ULONG aAllocVMM, ULONG aFreeVMM,
246 ULONG aBalloonedVMM, ULONG aSharedVMM)
247 {
248 mControl->ReportGuestStatistics(aValidStats, aCpuUser, aCpuKernel, aCpuIdle,
249 aMemTotal, aMemFree, aMemBalloon, aMemShared,
250 aMemCache, aPageTotal, aAllocVMM, aFreeVMM,
251 aBalloonedVMM, aSharedVMM);
252 }
253 void enableVMMStatistics(BOOL aEnable);
254
255 // callback callers (partly; for some events console callbacks are notified
256 // directly from IInternalSessionControl event handlers declared above)
257 void onMousePointerShapeChange(bool fVisible, bool fAlpha,
258 uint32_t xHot, uint32_t yHot,
259 uint32_t width, uint32_t height,
260 ComSafeArrayIn(uint8_t, aShape));
261 void onMouseCapabilityChange(BOOL supportsAbsolute, BOOL supportsRelative, BOOL needsHostCursor);
262 void onStateChange(MachineState_T aMachineState);
263 void onAdditionsStateChange();
264 void onAdditionsOutdated();
265 void onKeyboardLedsChange(bool fNumLock, bool fCapsLock, bool fScrollLock);
266 void onUSBDeviceStateChange(IUSBDevice *aDevice, bool aAttached,
267 IVirtualBoxErrorInfo *aError);
268 void onRuntimeError(BOOL aFatal, IN_BSTR aErrorID, IN_BSTR aMessage);
269 HRESULT onShowWindow(BOOL aCheck, BOOL *aCanShow, LONG64 *aWinId);
270 void onVRDEServerInfoChange();
271
272 static const PDMDRVREG DrvStatusReg;
273
274 static HRESULT setErrorStatic(HRESULT aResultCode, const char *pcsz, ...);
275 HRESULT setInvalidMachineStateError();
276
277 static const char *convertControllerTypeToDev(StorageControllerType_T enmCtrlType);
278 static HRESULT convertBusPortDeviceToLun(StorageBus_T enmBus, LONG port, LONG device, unsigned &uLun);
279 // Called from event listener
280 HRESULT onNATRedirectRuleChange(ULONG ulInstance, BOOL aNatRuleRemove,
281 NATProtocol_T aProto, IN_BSTR aHostIp, LONG aHostPort, IN_BSTR aGuestIp, LONG aGuestPort);
282
283private:
284
285 /**
286 * Base template for AutoVMCaller and SaveVMPtr. Template arguments
287 * have the same meaning as arguments of Console::addVMCaller().
288 */
289 template <bool taQuiet = false, bool taAllowNullVM = false>
290 class AutoVMCallerBase
291 {
292 public:
293 AutoVMCallerBase(Console *aThat) : mThat(aThat), mRC(S_OK)
294 {
295 Assert(aThat);
296 mRC = aThat->addVMCaller(taQuiet, taAllowNullVM);
297 }
298 ~AutoVMCallerBase()
299 {
300 if (SUCCEEDED(mRC))
301 mThat->releaseVMCaller();
302 }
303 /** Decreases the number of callers before the instance is destroyed. */
304 void releaseCaller()
305 {
306 AssertReturnVoid(SUCCEEDED(mRC));
307 mThat->releaseVMCaller();
308 mRC = E_FAIL;
309 }
310 /** Restores the number of callers after by #release(). #rc() must be
311 * rechecked to ensure the operation succeeded. */
312 void addYY()
313 {
314 AssertReturnVoid(!SUCCEEDED(mRC));
315 mRC = mThat->addVMCaller(taQuiet, taAllowNullVM);
316 }
317 /** Returns the result of Console::addVMCaller() */
318 HRESULT rc() const { return mRC; }
319 /** Shortcut to SUCCEEDED(rc()) */
320 bool isOk() const { return SUCCEEDED(mRC); }
321 protected:
322 Console *mThat;
323 HRESULT mRC;
324 private:
325 DECLARE_CLS_COPY_CTOR_ASSIGN_NOOP(AutoVMCallerBase)
326 };
327
328#if 0
329 /**
330 * Helper class that protects sections of code using the mpVM pointer by
331 * automatically calling addVMCaller() on construction and
332 * releaseVMCaller() on destruction. Intended for Console methods dealing
333 * with mpVM. The usage pattern is:
334 * <code>
335 * AutoVMCaller autoVMCaller(this);
336 * if (FAILED(autoVMCaller.rc())) return autoVMCaller.rc();
337 * ...
338 * VMR3ReqCall (mpVM, ...
339 * </code>
340 *
341 * @note Temporarily locks the argument for writing.
342 *
343 * @sa SafeVMPtr, SafeVMPtrQuiet
344 * @obsolete Use SafeVMPtr
345 */
346 typedef AutoVMCallerBase<false, false> AutoVMCaller;
347#endif
348
349 /**
350 * Same as AutoVMCaller but doesn't set extended error info on failure.
351 *
352 * @note Temporarily locks the argument for writing.
353 * @obsolete Use SafeVMPtrQuiet
354 */
355 typedef AutoVMCallerBase<true, false> AutoVMCallerQuiet;
356
357 /**
358 * Same as AutoVMCaller but allows a null VM pointer (to trigger an error
359 * instead of assertion).
360 *
361 * @note Temporarily locks the argument for writing.
362 * @obsolete Use SafeVMPtr
363 */
364 typedef AutoVMCallerBase<false, true> AutoVMCallerWeak;
365
366 /**
367 * Same as AutoVMCaller but doesn't set extended error info on failure
368 * and allows a null VM pointer (to trigger an error instead of
369 * assertion).
370 *
371 * @note Temporarily locks the argument for writing.
372 * @obsolete Use SafeVMPtrQuiet
373 */
374 typedef AutoVMCallerBase<true, true> AutoVMCallerQuietWeak;
375
376 /**
377 * Base template for SaveVMPtr and SaveVMPtrQuiet.
378 */
379 template<bool taQuiet = false>
380 class SafeVMPtrBase : public AutoVMCallerBase<taQuiet, true>
381 {
382 typedef AutoVMCallerBase<taQuiet, true> Base;
383 public:
384 SafeVMPtrBase(Console *aThat) : Base(aThat), mpVM(NULL), mpUVM(NULL)
385 {
386 if (SUCCEEDED(Base::mRC))
387 Base::mRC = aThat->safeVMPtrRetainer(&mpVM, &mpUVM, taQuiet);
388 }
389 ~SafeVMPtrBase()
390 {
391 if (SUCCEEDED(Base::mRC))
392 release();
393 }
394 /** Smart SaveVMPtr to PVM cast operator */
395 operator PVM() const { return mpVM; }
396 /** Direct PVM access for printf()-like functions */
397 PVM raw() const { return mpVM; }
398 /** Direct PUVM access for printf()-like functions */
399 PUVM rawUVM() const { return mpUVM; }
400 /** Release the handles. */
401 void release()
402 {
403 AssertReturnVoid(SUCCEEDED(Base::mRC));
404 Base::mThat->safeVMPtrReleaser(&mpVM, &mpUVM);
405 Base::releaseCaller();
406 }
407
408 private:
409 PVM mpVM;
410 PUVM mpUVM;
411 DECLARE_CLS_COPY_CTOR_ASSIGN_NOOP(SafeVMPtrBase)
412 };
413
414public:
415
416 /**
417 * Helper class that safely manages the Console::mpVM pointer
418 * by calling addVMCaller() on construction and releaseVMCaller() on
419 * destruction. Intended for Console children. The usage pattern is:
420 * <code>
421 * Console::SaveVMPtr pVM(mParent);
422 * if (FAILED(pVM.rc())) return pVM.rc();
423 * ...
424 * VMR3ReqCall(pVM, ...
425 * ...
426 * printf("%p\n", pVM.raw());
427 * </code>
428 *
429 * @note Temporarily locks the argument for writing.
430 *
431 * @sa SafeVMPtrQuiet, AutoVMCaller
432 */
433 typedef SafeVMPtrBase<false> SafeVMPtr;
434
435 /**
436 * A deviation of SaveVMPtr that doesn't set the error info on failure.
437 * Intended for pieces of code that don't need to return the VM access
438 * failure to the caller. The usage pattern is:
439 * <code>
440 * Console::SaveVMPtrQuiet pVM(mParent);
441 * if (pVM.rc())
442 * VMR3ReqCall(pVM, ...
443 * return S_OK;
444 * </code>
445 *
446 * @note Temporarily locks the argument for writing.
447 *
448 * @sa SafeVMPtr, AutoVMCaller
449 */
450 typedef SafeVMPtrBase<true> SafeVMPtrQuiet;
451
452 class SharedFolderData
453 {
454 public:
455 SharedFolderData()
456 { }
457
458 SharedFolderData(const Utf8Str &aHostPath,
459 bool aWritable,
460 bool aAutoMount)
461 : m_strHostPath(aHostPath),
462 m_fWritable(aWritable),
463 m_fAutoMount(aAutoMount)
464 { }
465
466 // copy constructor
467 SharedFolderData(const SharedFolderData& aThat)
468 : m_strHostPath(aThat.m_strHostPath),
469 m_fWritable(aThat.m_fWritable),
470 m_fAutoMount(aThat.m_fAutoMount)
471 { }
472
473 Utf8Str m_strHostPath;
474 bool m_fWritable;
475 bool m_fAutoMount;
476 };
477
478 typedef std::map<Utf8Str, ComObjPtr<SharedFolder> > SharedFolderMap;
479 typedef std::map<Utf8Str, SharedFolderData> SharedFolderDataMap;
480 typedef std::map<Utf8Str, ComPtr<IMediumAttachment> > MediumAttachmentMap;
481
482private:
483
484 typedef std::list <ComObjPtr<OUSBDevice> > USBDeviceList;
485 typedef std::list <ComObjPtr<RemoteUSBDevice> > RemoteUSBDeviceList;
486
487 HRESULT addVMCaller(bool aQuiet = false, bool aAllowNullVM = false);
488 void releaseVMCaller();
489 HRESULT safeVMPtrRetainer(PVM *a_ppVM, PUVM *a_ppUVM, bool aQuiet);
490 void safeVMPtrReleaser(PVM *a_ppVM, PUVM *a_ppUVM);
491
492 HRESULT consoleInitReleaseLog(const ComPtr<IMachine> aMachine);
493
494 HRESULT powerUp(IProgress **aProgress, bool aPaused);
495 HRESULT powerDown(IProgress *aProgress = NULL);
496
497/* Note: FreeBSD needs this whether netflt is used or not. */
498#if ((defined(RT_OS_LINUX) && !defined(VBOX_WITH_NETFLT)) || defined(RT_OS_FREEBSD))
499 HRESULT attachToTapInterface(INetworkAdapter *networkAdapter);
500 HRESULT detachFromTapInterface(INetworkAdapter *networkAdapter);
501#endif
502 HRESULT powerDownHostInterfaces();
503
504 HRESULT setMachineState(MachineState_T aMachineState, bool aUpdateServer = true);
505 HRESULT setMachineStateLocally(MachineState_T aMachineState)
506 {
507 return setMachineState(aMachineState, false /* aUpdateServer */);
508 }
509
510 HRESULT findSharedFolder(const Utf8Str &strName,
511 ComObjPtr<SharedFolder> &aSharedFolder,
512 bool aSetError = false);
513
514 HRESULT fetchSharedFolders(BOOL aGlobal);
515 bool findOtherSharedFolder(const Utf8Str &straName,
516 SharedFolderDataMap::const_iterator &aIt);
517
518 HRESULT createSharedFolder(const Utf8Str &strName, const SharedFolderData &aData);
519 HRESULT removeSharedFolder(const Utf8Str &strName);
520
521 static DECLCALLBACK(int) configConstructor(PVM pVM, void *pvConsole);
522 int configConstructorInner(PVM pVM, AutoWriteLock *pAlock);
523 int configCfgmOverlay(PVM pVM, IVirtualBox *pVirtualBox, IMachine *pMachine);
524
525 int configMediumAttachment(PCFGMNODE pCtlInst,
526 const char *pcszDevice,
527 unsigned uInstance,
528 StorageBus_T enmBus,
529 bool fUseHostIOCache,
530 bool fBuiltinIoCache,
531 bool fSetupMerge,
532 unsigned uMergeSource,
533 unsigned uMergeTarget,
534 IMediumAttachment *pMediumAtt,
535 MachineState_T aMachineState,
536 HRESULT *phrc,
537 bool fAttachDetach,
538 bool fForceUnmount,
539 bool fHotplug,
540 PVM pVM,
541 DeviceType_T *paLedDevType);
542 int configMedium(PCFGMNODE pLunL0,
543 bool fPassthrough,
544 DeviceType_T enmType,
545 bool fUseHostIOCache,
546 bool fBuiltinIoCache,
547 bool fSetupMerge,
548 unsigned uMergeSource,
549 unsigned uMergeTarget,
550 const char *pcszBwGroup,
551 bool fDiscard,
552 IMedium *pMedium,
553 MachineState_T aMachineState,
554 HRESULT *phrc);
555 static DECLCALLBACK(int) reconfigureMediumAttachment(Console *pConsole,
556 PVM pVM,
557 const char *pcszDevice,
558 unsigned uInstance,
559 StorageBus_T enmBus,
560 bool fUseHostIOCache,
561 bool fBuiltinIoCache,
562 bool fSetupMerge,
563 unsigned uMergeSource,
564 unsigned uMergeTarget,
565 IMediumAttachment *aMediumAtt,
566 MachineState_T aMachineState,
567 HRESULT *phrc);
568 static DECLCALLBACK(int) changeRemovableMedium(Console *pThis,
569 PVM pVM,
570 const char *pcszDevice,
571 unsigned uInstance,
572 StorageBus_T enmBus,
573 bool fUseHostIOCache,
574 IMediumAttachment *aMediumAtt,
575 bool fForce);
576
577 HRESULT attachRawPCIDevices(PVM pVM, BusAssignmentManager *BusMgr, PCFGMNODE pDevices);
578 void attachStatusDriver(PCFGMNODE pCtlInst, PPDMLED *papLeds,
579 uint64_t uFirst, uint64_t uLast,
580 Console::MediumAttachmentMap *pmapMediumAttachments,
581 const char *pcszDevice, unsigned uInstance);
582
583 int configNetwork(const char *pszDevice, unsigned uInstance, unsigned uLun,
584 INetworkAdapter *aNetworkAdapter, PCFGMNODE pCfg,
585 PCFGMNODE pLunL0, PCFGMNODE pInst,
586 bool fAttachDetach, bool fIgnoreConnectFailure);
587
588 static DECLCALLBACK(int) configGuestProperties(void *pvConsole, PVM pVM);
589 static DECLCALLBACK(int) configGuestControl(void *pvConsole);
590 static DECLCALLBACK(void) vmstateChangeCallback(PVM aVM, VMSTATE aState,
591 VMSTATE aOldState, void *aUser);
592 static DECLCALLBACK(int) unplugCpu(Console *pThis, PVM pVM, unsigned uCpu);
593 static DECLCALLBACK(int) plugCpu(Console *pThis, PVM pVM, unsigned uCpu);
594 HRESULT doMediumChange(IMediumAttachment *aMediumAttachment, bool fForce, PVM pVM);
595 HRESULT doCPURemove(ULONG aCpu, PVM pVM);
596 HRESULT doCPUAdd(ULONG aCpu, PVM pVM);
597
598 HRESULT doNetworkAdapterChange(PVM pVM, const char *pszDevice, unsigned uInstance,
599 unsigned uLun, INetworkAdapter *aNetworkAdapter);
600 static DECLCALLBACK(int) changeNetworkAttachment(Console *pThis, PVM pVM, const char *pszDevice,
601 unsigned uInstance, unsigned uLun,
602 INetworkAdapter *aNetworkAdapter);
603
604 void changeClipboardMode(ClipboardMode_T aClipboardMode);
605 void changeDragAndDropMode(DragAndDropMode_T aDragAndDropMode);
606
607#ifdef VBOX_WITH_USB
608 HRESULT attachUSBDevice(IUSBDevice *aHostDevice, ULONG aMaskedIfs);
609 HRESULT detachUSBDevice(const ComObjPtr<OUSBDevice> &aHostDevice);
610
611 static DECLCALLBACK(int) usbAttachCallback(Console *that, PVM pVM, IUSBDevice *aHostDevice, PCRTUUID aUuid,
612 bool aRemote, const char *aAddress, void *pvRemoteBackend, USHORT aPortVersion, ULONG aMaskedIfs);
613 static DECLCALLBACK(int) usbDetachCallback(Console *that, PVM pVM, PCRTUUID aUuid);
614#endif
615
616 static DECLCALLBACK(int) attachStorageDevice(Console *pThis,
617 PVM pVM,
618 const char *pcszDevice,
619 unsigned uInstance,
620 StorageBus_T enmBus,
621 bool fUseHostIOCache,
622 IMediumAttachment *aMediumAtt);
623 static DECLCALLBACK(int) detachStorageDevice(Console *pThis,
624 PVM pVM,
625 const char *pcszDevice,
626 unsigned uInstance,
627 StorageBus_T enmBus,
628 IMediumAttachment *aMediumAtt);
629 HRESULT doStorageDeviceAttach(IMediumAttachment *aMediumAttachment, PVM pVM);
630 HRESULT doStorageDeviceDetach(IMediumAttachment *aMediumAttachment, PVM pVM);
631
632 static DECLCALLBACK(int) fntTakeSnapshotWorker(RTTHREAD Thread, void *pvUser);
633
634 static DECLCALLBACK(int) stateProgressCallback(PVM pVM, unsigned uPercent, void *pvUser);
635
636 static DECLCALLBACK(void) genericVMSetErrorCallback(PVM pVM, void *pvUser, int rc, RT_SRC_POS_DECL,
637 const char *pszErrorFmt, va_list va);
638
639 static void setVMRuntimeErrorCallbackF(PVM pVM, void *pvUser, uint32_t fFatal,
640 const char *pszErrorId, const char *pszFormat, ...);
641 static DECLCALLBACK(void) setVMRuntimeErrorCallback(PVM pVM, void *pvUser, uint32_t fFatal,
642 const char *pszErrorId, const char *pszFormat, va_list va);
643
644 HRESULT captureUSBDevices(PVM pVM);
645 void detachAllUSBDevices(bool aDone);
646
647 static DECLCALLBACK(int) powerUpThread(RTTHREAD Thread, void *pvUser);
648 static DECLCALLBACK(int) saveStateThread(RTTHREAD Thread, void *pvUser);
649 static DECLCALLBACK(int) powerDownThread(RTTHREAD Thread, void *pvUser);
650
651 static DECLCALLBACK(int) vmm2User_SaveState(PCVMM2USERMETHODS pThis, PUVM pUVM);
652 static DECLCALLBACK(void) vmm2User_NotifyEmtInit(PCVMM2USERMETHODS pThis, PUVM pUVM, PUVMCPU pUVCpu);
653 static DECLCALLBACK(void) vmm2User_NotifyEmtTerm(PCVMM2USERMETHODS pThis, PUVM pUVM, PUVMCPU pUVCpu);
654 static DECLCALLBACK(void) vmm2User_NotifyPdmtInit(PCVMM2USERMETHODS pThis, PUVM pUVM);
655 static DECLCALLBACK(void) vmm2User_NotifyPdmtTerm(PCVMM2USERMETHODS pThis, PUVM pUVM);
656
657 static DECLCALLBACK(void *) drvStatus_QueryInterface(PPDMIBASE pInterface, const char *pszIID);
658 static DECLCALLBACK(void) drvStatus_UnitChanged(PPDMILEDCONNECTORS pInterface, unsigned iLUN);
659 static DECLCALLBACK(int) drvStatus_MediumEjected(PPDMIMEDIANOTIFY pInterface, unsigned iLUN);
660 static DECLCALLBACK(void) drvStatus_Destruct(PPDMDRVINS pDrvIns);
661 static DECLCALLBACK(int) drvStatus_Construct(PPDMDRVINS pDrvIns, PCFGMNODE pCfg, uint32_t fFlags);
662
663 int mcAudioRefs;
664 volatile uint32_t mcVRDPClients;
665 uint32_t mu32SingleRDPClientId; /* The id of a connected client in the single connection mode. */
666 volatile bool mcGuestCredentialsProvided;
667
668 static const char *sSSMConsoleUnit;
669 static uint32_t sSSMConsoleVer;
670
671 HRESULT loadDataFromSavedState();
672 int loadStateFileExecInternal(PSSMHANDLE pSSM, uint32_t u32Version);
673
674 static DECLCALLBACK(void) saveStateFileExec(PSSMHANDLE pSSM, void *pvUser);
675 static DECLCALLBACK(int) loadStateFileExec(PSSMHANDLE pSSM, void *pvUser, uint32_t uVersion, uint32_t uPass);
676
677#ifdef VBOX_WITH_GUEST_PROPS
678 static DECLCALLBACK(int) doGuestPropNotification(void *pvExtension, uint32_t, void *pvParms, uint32_t cbParms);
679 HRESULT doEnumerateGuestProperties(CBSTR aPatterns,
680 ComSafeArrayOut(BSTR, aNames),
681 ComSafeArrayOut(BSTR, aValues),
682 ComSafeArrayOut(LONG64, aTimestamps),
683 ComSafeArrayOut(BSTR, aFlags));
684
685 void guestPropertiesHandleVMReset(void);
686 bool guestPropertiesVRDPEnabled(void);
687 void guestPropertiesVRDPUpdateLogon(uint32_t u32ClientId, const char *pszUser, const char *pszDomain);
688 void guestPropertiesVRDPUpdateActiveClient(uint32_t u32ClientId);
689 void guestPropertiesVRDPUpdateClientAttach(uint32_t u32ClientId, bool fAttached);
690 void guestPropertiesVRDPUpdateNameChange(uint32_t u32ClientId, const char *pszName);
691 void guestPropertiesVRDPUpdateDisconnect(uint32_t u32ClientId);
692#endif
693
694 /** @name Teleporter support
695 * @{ */
696 static DECLCALLBACK(int) teleporterSrcThreadWrapper(RTTHREAD hThread, void *pvUser);
697 HRESULT teleporterSrc(TeleporterStateSrc *pState);
698 HRESULT teleporterSrcReadACK(TeleporterStateSrc *pState, const char *pszWhich, const char *pszNAckMsg = NULL);
699 HRESULT teleporterSrcSubmitCommand(TeleporterStateSrc *pState, const char *pszCommand, bool fWaitForAck = true);
700 HRESULT teleporterTrg(PUVM pUVM, IMachine *pMachine, Utf8Str *pErrorMsg, bool fStartPaused,
701 Progress *pProgress, bool *pfPowerOffOnFailure);
702 static DECLCALLBACK(int) teleporterTrgServeConnection(RTSOCKET Sock, void *pvUser);
703 /** @} */
704
705 bool mSavedStateDataLoaded : 1;
706
707 const ComPtr<IMachine> mMachine;
708 const ComPtr<IInternalMachineControl> mControl;
709
710 const ComPtr<IVRDEServer> mVRDEServer;
711
712 ConsoleVRDPServer * const mConsoleVRDPServer;
713
714 const ComObjPtr<Guest> mGuest;
715 const ComObjPtr<Keyboard> mKeyboard;
716 const ComObjPtr<Mouse> mMouse;
717 const ComObjPtr<Display> mDisplay;
718 const ComObjPtr<MachineDebugger> mDebugger;
719 const ComObjPtr<VRDEServerInfo> mVRDEServerInfo;
720 /** This can safely be used without holding any locks.
721 * An AutoCaller suffices to prevent it being destroy while in use and
722 * internally there is a lock providing the necessary serialization. */
723 const ComObjPtr<EventSource> mEventSource;
724#ifdef VBOX_WITH_EXTPACK
725 const ComObjPtr<ExtPackManager> mptrExtPackManager;
726#endif
727
728 USBDeviceList mUSBDevices;
729 RemoteUSBDeviceList mRemoteUSBDevices;
730
731 SharedFolderDataMap m_mapGlobalSharedFolders;
732 SharedFolderDataMap m_mapMachineSharedFolders;
733 SharedFolderMap m_mapSharedFolders; // the console instances
734
735 /** The user mode VM handle. */
736 PUVM mpUVM;
737 /** Holds the number of "readonly" mpVM callers (users) */
738 uint32_t mVMCallers;
739 /** Semaphore posted when the number of mpVM callers drops to zero */
740 RTSEMEVENT mVMZeroCallersSem;
741 /** true when Console has entered the mpVM destruction phase */
742 bool mVMDestroying : 1;
743 /** true when power down is initiated by vmstateChangeCallback (EMT) */
744 bool mVMPoweredOff : 1;
745 /** true when vmstateChangeCallback shouldn't initiate a power down. */
746 bool mVMIsAlreadyPoweringOff : 1;
747 /** true if we already showed the snapshot folder size warning. */
748 bool mfSnapshotFolderSizeWarningShown : 1;
749 /** true if we already showed the snapshot folder ext4/xfs bug warning. */
750 bool mfSnapshotFolderExt4WarningShown : 1;
751 /** true if we already listed the disk type of the snapshot folder. */
752 bool mfSnapshotFolderDiskTypeShown : 1;
753
754 /** Pointer to the VMM -> User (that's us) callbacks. */
755 struct MYVMM2USERMETHODS : public VMM2USERMETHODS
756 {
757 Console *pConsole;
758 } *mpVmm2UserMethods;
759
760 /** The current network attachment type in the VM.
761 * This doesn't have to match the network attachment type maintained in the
762 * NetworkAdapter. This is needed to change the network attachment
763 * dynamically.
764 */
765 typedef std::vector<NetworkAttachmentType_T> NetworkAttachmentTypeVector;
766 NetworkAttachmentTypeVector meAttachmentType;
767
768 VMMDev * m_pVMMDev;
769 AudioSniffer * const mAudioSniffer;
770#ifdef VBOX_WITH_USB_VIDEO
771 UsbWebcamInterface * const mUsbWebcamInterface;
772#endif
773#ifdef VBOX_WITH_USB_CARDREADER
774 UsbCardReader * const mUsbCardReader;
775#endif
776 BusAssignmentManager* mBusMgr;
777
778 enum
779 {
780 iLedFloppy = 0,
781 cLedFloppy = 2,
782 iLedIde = iLedFloppy + cLedFloppy,
783 cLedIde = 4,
784 iLedSata = iLedIde + cLedIde,
785 cLedSata = 30,
786 iLedScsi = iLedSata + cLedSata,
787 cLedScsi = 16,
788 iLedSas = iLedScsi + cLedScsi,
789 cLedSas = 8,
790 cLedStorage = cLedFloppy + cLedIde + cLedSata + cLedScsi + cLedSas
791 };
792 DeviceType_T maStorageDevType[cLedStorage];
793 PPDMLED mapStorageLeds[cLedStorage];
794 PPDMLED mapNetworkLeds[36]; /**< @todo adapt this to the maximum network card count */
795 PPDMLED mapSharedFolderLed;
796 PPDMLED mapUSBLed[2];
797
798 MediumAttachmentMap mapMediumAttachments;
799
800/* Note: FreeBSD needs this whether netflt is used or not. */
801#if ((defined(RT_OS_LINUX) && !defined(VBOX_WITH_NETFLT)) || defined(RT_OS_FREEBSD))
802 Utf8Str maTAPDeviceName[8];
803 RTFILE maTapFD[8];
804#endif
805
806 bool mVMStateChangeCallbackDisabled;
807
808 bool mfUseHostClipboard;
809
810 /** Local machine state value. */
811 MachineState_T mMachineState;
812
813 /** Pointer to the progress object of a live cancelable task.
814 *
815 * This is currently only used by Console::Teleport(), but is intended to later
816 * be used by the live snapshot code path as well. Actions like
817 * Console::PowerDown, which automatically cancels out the running snapshot /
818 * teleportation operation, will cancel the teleportation / live snapshot
819 * operation before starting. */
820 ComObjPtr<Progress> mptrCancelableProgress;
821
822 /* The purpose of caching of some events is probably in order to
823 automatically fire them at new event listeners. However, there is no
824 (longer?) any code making use of this... */
825#ifdef CONSOLE_WITH_EVENT_CACHE
826 struct
827 {
828 /** OnMousePointerShapeChange() cache */
829 struct
830 {
831 bool valid;
832 bool visible;
833 bool alpha;
834 uint32_t xHot;
835 uint32_t yHot;
836 uint32_t width;
837 uint32_t height;
838 com::SafeArray<BYTE> shape;
839 } mpsc;
840
841 /** OnMouseCapabilityChange() cache */
842 struct
843 {
844 bool valid;
845 BOOL supportsAbsolute;
846 BOOL supportsRelative;
847 BOOL needsHostCursor;
848 } mcc;
849
850 /** OnKeyboardLedsChange() cache */
851 struct
852 {
853 bool valid;
854 bool numLock;
855 bool capsLock;
856 bool scrollLock;
857 } klc;
858
859 void clear()
860 {
861 RT_ZERO(mcc);
862 RT_ZERO(klc);
863
864 /* We cannot RT_ZERO mpsc because of shape's vtable. */
865 mpsc.shape.setNull();
866 mpsc.valid = mpsc.visible = mpsc.alpha = false;
867 mpsc.xHot = mpsc.yHot = mpsc.width = mpsc.height = 0;
868 }
869 } mCallbackData;
870#endif
871 ComPtr<IEventListener> mVmListener;
872
873 friend struct VMTask;
874};
875
876#endif // !____H_CONSOLEIMPL
877/* 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