VirtualBox

source: vbox/trunk/src/VBox/Main/include/DisplayImpl.h@ 105006

Last change on this file since 105006 was 105006, checked in by vboxsync, 3 months ago

Video Recording: Big revamp to improve overall performance. We now don't rely on the periodic display refresh callback anymore to render the entire framebuffer but now rely on delta updates ("dirty rectangles"). Also, we now only encode new frames when an area has changed. This also needed cursor position + change change notifications, as we render the cursor on the host side if mouse integration is enabled (requires 7.1 Guest Additions as of now). Optimized the BGRA32->YUV IV420 color space conversion as well as the overall amount of pixel data shuffled forth and back. Added a new testcase for the cropping/centering code. bugref:10650

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 24.4 KB
Line 
1/* $Id: DisplayImpl.h 105006 2024-06-24 17:43:00Z vboxsync $ */
2/** @file
3 * VirtualBox COM class implementation
4 */
5
6/*
7 * Copyright (C) 2006-2023 Oracle and/or its affiliates.
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
28#ifndef MAIN_INCLUDED_DisplayImpl_h
29#define MAIN_INCLUDED_DisplayImpl_h
30#ifndef RT_WITHOUT_PRAGMA_ONCE
31# pragma once
32#endif
33
34#include "SchemaDefs.h"
35
36#include <iprt/semaphore.h>
37#include <VBox/vmm/pdmdrv.h>
38#include <VBoxVideo.h>
39#include <VBox/vmm/pdmifs.h>
40#include <VBox/VMMDev.h> /* For struct VMMDevDisplayDef - why is it in that file? */
41#include "DisplayWrap.h"
42
43#include "DisplaySourceBitmapWrap.h"
44#include "GuestScreenInfoWrap.h"
45
46#ifdef VBOX_WITH_RECORDING
47# include "RecordingInternals.h"
48#endif
49
50class Console;
51
52typedef struct _DISPLAYFBINFO
53{
54 /* The following 3 fields (u32Offset, u32MaxFramebufferSize and u32InformationSize)
55 * are not used by the current HGSMI. They are needed for backward compatibility with
56 * pre-HGSMI additions.
57 */
58 uint32_t u32Offset;
59 uint32_t u32MaxFramebufferSize;
60 uint32_t u32InformationSize;
61
62 ComPtr<IFramebuffer> pFramebuffer;
63 com::Guid framebufferId;
64 ComPtr<IDisplaySourceBitmap> pSourceBitmap;
65 bool fDisabled;
66
67 uint32_t u32Caps;
68
69 struct
70 {
71 ComPtr<IDisplaySourceBitmap> pSourceBitmap;
72 uint8_t *pu8Address;
73 uint32_t cbLine;
74 } updateImage;
75
76 LONG xOrigin;
77 LONG yOrigin;
78
79 ULONG w;
80 ULONG h;
81
82 uint16_t u16BitsPerPixel;
83 uint8_t *pu8FramebufferVRAM;
84 uint32_t u32LineSize;
85
86 uint16_t flags;
87
88 VBOXVIDEOINFOHOSTEVENTS *pHostEvents;
89
90 /** The framebuffer has default format and must be updates immediately. */
91 bool fDefaultFormat;
92
93#ifdef VBOX_WITH_HGSMI
94 bool fVBVAEnabled;
95 bool fVBVAForceResize;
96 VBVAHOSTFLAGS RT_UNTRUSTED_VOLATILE_GUEST *pVBVAHostFlags;
97#endif /* VBOX_WITH_HGSMI */
98
99 /** Description of the currently plugged monitor with preferred mode,
100 * a.k.a the last mode hint sent. */
101 struct VMMDevDisplayDef monitorDesc;
102} DISPLAYFBINFO;
103
104/* The legacy VBVA (VideoAccel) data.
105 *
106 * Backward compatibility with the Guest Additions 3.x or older.
107 */
108typedef struct VIDEOACCEL
109{
110 VBVAMEMORY *pVbvaMemory;
111 bool fVideoAccelEnabled;
112
113 uint8_t *pu8VbvaPartial;
114 uint32_t cbVbvaPartial;
115
116 /* Old Guest Additions (3.x and older) use both VMMDev and DevVGA refresh timer
117 * to process the VBVABUFFER memory. Therefore the legacy VBVA (VideoAccel) host
118 * code can be executed concurrently by VGA refresh timer and the guest VMMDev
119 * request in SMP VMs. The semaphore serialized this.
120 */
121 RTSEMXROADS hXRoadsVideoAccel;
122
123} VIDEOACCEL;
124
125class DisplayMouseInterface
126{
127public:
128 virtual ~DisplayMouseInterface() { }
129 virtual HRESULT i_getScreenResolution(ULONG cScreen, ULONG *pcx,
130 ULONG *pcy, ULONG *pcBPP, LONG *pXOrigin, LONG *pYOrigin) = 0;
131 virtual void i_getFramebufferDimensions(int32_t *px1, int32_t *py1,
132 int32_t *px2, int32_t *py2) = 0;
133 virtual HRESULT i_reportHostCursorCapabilities(uint32_t fCapabilitiesAdded, uint32_t fCapabilitiesRemoved) = 0;
134 virtual HRESULT i_reportHostCursorPosition(int32_t x, int32_t y, bool fOutOfRange) = 0;
135 virtual bool i_isInputMappingSet(void) = 0;
136};
137
138class VMMDev;
139
140class ATL_NO_VTABLE Display :
141 public DisplayWrap,
142 public DisplayMouseInterface
143{
144public:
145
146 DECLARE_COMMON_CLASS_METHODS(Display)
147
148 HRESULT FinalConstruct();
149 void FinalRelease();
150
151 // public initializer/uninitializer for internal purposes only
152 HRESULT init(Console *aParent);
153 void uninit();
154 int i_registerSSM(PUVM pUVM);
155
156 // public methods only for internal purposes
157 unsigned i_getMonitorCount() { return mcMonitors; }
158 int i_handleDisplayResize(unsigned uScreenId, uint32_t bpp, void *pvVRAM,
159 uint32_t cbLine, uint32_t w, uint32_t h, uint16_t flags,
160 int32_t xOrigin, int32_t yOrigin, bool fVGAResize);
161 void i_handleDisplayUpdate(unsigned uScreenId, int x, int y, int w, int h);
162 void i_handleUpdateVMMDevSupportsGraphics(bool fSupportsGraphics);
163 void i_handleUpdateGuestVBVACapabilities(uint32_t fNewCapabilities);
164 void i_handleUpdateVBVAInputMapping(int32_t xOrigin, int32_t yOrigin, uint32_t cx, uint32_t cy);
165#ifdef VBOX_WITH_VIDEOHWACCEL
166 int i_handleVHWACommandProcess(int enmCmd, bool fGuestCmd, VBOXVHWACMD RT_UNTRUSTED_VOLATILE_GUEST *pCommand);
167#endif
168 int i_handle3DNotifyProcess(VBOX3DNOTIFY *p3DNotify);
169
170 int i_saveVisibleRegion(uint32_t cRect, PRTRECT pRect);
171 int i_handleSetVisibleRegion(uint32_t cRect, PRTRECT pRect);
172 int i_handleUpdateMonitorPositions(uint32_t cPositions, PCRTPOINT paPositions);
173 int i_handleQueryVisibleRegion(uint32_t *pcRects, PRTRECT paRects);
174
175 void i_VRDPConnectionEvent(bool fConnect);
176 void i_VideoAccelVRDP(bool fEnable, int c);
177
178 /* Legacy video acceleration requests coming from the VGA refresh timer. */
179 int VideoAccelEnableVGA(bool fEnable, VBVAMEMORY *pVbvaMemory);
180
181 /* Legacy video acceleration requests coming from VMMDev. */
182 int VideoAccelEnableVMMDev(bool fEnable, VBVAMEMORY *pVbvaMemory);
183 void VideoAccelFlushVMMDev(void);
184
185 void i_updateDeviceCursorCapabilities(void);
186
187#ifdef VBOX_WITH_RECORDING
188 int i_recordingStart(void);
189 int i_recordingStop(void);
190 int i_recordingInvalidate(bool fForce = false);
191 int i_recordingScreenChanged(unsigned uScreenId, const DISPLAYFBINFO *pFBInfo);
192 int i_recordingScreenUpdate(unsigned uScreenId, PRECORDINGVIDEOFRAME pFrame);
193 int i_recordingCursorPositionChange(unsigned uScreenId, uint32_t fFlags, int32_t x, int32_t y);
194#endif
195
196 void i_notifyPowerDown(void);
197
198 // DisplayMouseInterface methods
199 virtual HRESULT i_getScreenResolution(ULONG cScreen, ULONG *pcx,
200 ULONG *pcy, ULONG *pcBPP, LONG *pXOrigin, LONG *pYOrigin)
201 {
202 return getScreenResolution(cScreen, pcx, pcy, pcBPP, pXOrigin, pYOrigin, NULL);
203 }
204 virtual void i_getFramebufferDimensions(int32_t *px1, int32_t *py1,
205 int32_t *px2, int32_t *py2);
206 virtual HRESULT i_reportHostCursorCapabilities(uint32_t fCapabilitiesAdded, uint32_t fCapabilitiesRemoved);
207 virtual HRESULT i_reportHostCursorPosition(int32_t x, int32_t y, bool fOutOfRange);
208 virtual bool i_isInputMappingSet(void)
209 {
210 return cxInputMapping != 0 && cyInputMapping != 0;
211 }
212
213 static const PDMDRVREG DrvReg;
214
215private:
216 // Wrapped IDisplay properties
217 virtual HRESULT getGuestScreenLayout(std::vector<ComPtr<IGuestScreenInfo> > &aGuestScreenLayout);
218
219 // Wrapped IDisplay methods
220 virtual HRESULT getScreenResolution(ULONG aScreenId,
221 ULONG *aWidth,
222 ULONG *aHeight,
223 ULONG *aBitsPerPixel,
224 LONG *aXOrigin,
225 LONG *aYOrigin,
226 GuestMonitorStatus_T *aGuestMonitorStatus);
227 virtual HRESULT attachFramebuffer(ULONG aScreenId,
228 const ComPtr<IFramebuffer> &aFramebuffer,
229 com::Guid &aId);
230 virtual HRESULT detachFramebuffer(ULONG aScreenId,
231 const com::Guid &aId);
232 virtual HRESULT queryFramebuffer(ULONG aScreenId,
233 ComPtr<IFramebuffer> &aFramebuffer);
234 virtual HRESULT setVideoModeHint(ULONG aDisplay,
235 BOOL aEnabled,
236 BOOL aChangeOrigin,
237 LONG aOriginX,
238 LONG aOriginY,
239 ULONG aWidth,
240 ULONG aHeight,
241 ULONG aBitsPerPixel,
242 BOOL aNotify);
243 virtual HRESULT getVideoModeHint(ULONG aDisplay,
244 BOOL *aEnabled,
245 BOOL *aChangeOrigin,
246 LONG *aOriginX,
247 LONG *aOriginY,
248 ULONG *aWidth,
249 ULONG *aHeight,
250 ULONG *aBitsPerPixel);
251 virtual HRESULT setSeamlessMode(BOOL aEnabled);
252 virtual HRESULT takeScreenShot(ULONG aScreenId,
253 BYTE *aAddress,
254 ULONG aWidth,
255 ULONG aHeight,
256 BitmapFormat_T aBitmapFormat);
257 virtual HRESULT takeScreenShotToArray(ULONG aScreenId,
258 ULONG aWidth,
259 ULONG aHeight,
260 BitmapFormat_T aBitmapFormat,
261 std::vector<BYTE> &aScreenData);
262 virtual HRESULT drawToScreen(ULONG aScreenId,
263 BYTE *aAddress,
264 ULONG aX,
265 ULONG aY,
266 ULONG aWidth,
267 ULONG aHeight);
268 virtual HRESULT invalidateAndUpdate();
269 virtual HRESULT invalidateAndUpdateScreen(ULONG aScreenId);
270 virtual HRESULT completeVHWACommand(BYTE *aCommand);
271 virtual HRESULT viewportChanged(ULONG aScreenId,
272 ULONG aX,
273 ULONG aY,
274 ULONG aWidth,
275 ULONG aHeight);
276 virtual HRESULT querySourceBitmap(ULONG aScreenId,
277 ComPtr<IDisplaySourceBitmap> &aDisplaySourceBitmap);
278 virtual HRESULT notifyScaleFactorChange(ULONG aScreenId,
279 ULONG aScaleFactorWMultiplied,
280 ULONG aScaleFactorHMultiplied);
281 virtual HRESULT notifyHiDPIOutputPolicyChange(BOOL fUnscaledHiDPI);
282 virtual HRESULT setScreenLayout(ScreenLayoutMode_T aScreenLayoutMode,
283 const std::vector<ComPtr<IGuestScreenInfo> > &aGuestScreenInfo);
284 virtual HRESULT detachScreens(const std::vector<LONG> &aScreenIds);
285 virtual HRESULT createGuestScreenInfo(ULONG aDisplay,
286 GuestMonitorStatus_T aStatus,
287 BOOL aPrimary,
288 BOOL aChangeOrigin,
289 LONG aOriginX,
290 LONG aOriginY,
291 ULONG aWidth,
292 ULONG aHeight,
293 ULONG aBitsPerPixel,
294 ComPtr<IGuestScreenInfo> &aGuestScreenInfo);
295
296 // Wrapped IEventListener properties
297
298 // Wrapped IEventListener methods
299 virtual HRESULT handleEvent(const ComPtr<IEvent> &aEvent);
300
301 // other internal methods
302 HRESULT takeScreenShotWorker(ULONG aScreenId,
303 BYTE *aAddress,
304 ULONG aWidth,
305 ULONG aHeight,
306 BitmapFormat_T aBitmapFormat,
307 ULONG *pcbOut);
308 int processVBVAResize(PCVBVAINFOVIEW pView, PCVBVAINFOSCREEN pScreen, void *pvVRAM, bool fResetInputMapping);
309
310 static DECLCALLBACK(void*) i_drvQueryInterface(PPDMIBASE pInterface, const char *pszIID);
311 static DECLCALLBACK(int) i_drvConstruct(PPDMDRVINS pDrvIns, PCFGMNODE pCfg, uint32_t fFlags);
312 static DECLCALLBACK(void) i_drvDestruct(PPDMDRVINS pDrvIns);
313 static DECLCALLBACK(void) i_drvPowerOff(PPDMDRVINS pDrvIns);
314 static DECLCALLBACK(int) i_displayResizeCallback(PPDMIDISPLAYCONNECTOR pInterface, uint32_t bpp, void *pvVRAM,
315 uint32_t cbLine, uint32_t cx, uint32_t cy);
316 static DECLCALLBACK(void) i_displayUpdateCallback(PPDMIDISPLAYCONNECTOR pInterface,
317 uint32_t x, uint32_t y, uint32_t cx, uint32_t cy);
318 static DECLCALLBACK(void) i_displayRefreshCallback(PPDMIDISPLAYCONNECTOR pInterface);
319 static DECLCALLBACK(void) i_displayResetCallback(PPDMIDISPLAYCONNECTOR pInterface);
320 static DECLCALLBACK(void) i_displayLFBModeChangeCallback(PPDMIDISPLAYCONNECTOR pInterface, bool fEnabled);
321 static DECLCALLBACK(void) i_displayProcessAdapterDataCallback(PPDMIDISPLAYCONNECTOR pInterface,
322 void *pvVRAM, uint32_t u32VRAMSize);
323 static DECLCALLBACK(void) i_displayProcessDisplayDataCallback(PPDMIDISPLAYCONNECTOR pInterface,
324 void *pvVRAM, unsigned uScreenId);
325
326#ifdef VBOX_WITH_VIDEOHWACCEL
327 static DECLCALLBACK(int) i_displayVHWACommandProcess(PPDMIDISPLAYCONNECTOR pInterface, int enmCmd, bool fGuestCmd,
328 VBOXVHWACMD RT_UNTRUSTED_VOLATILE_GUEST *pCommand);
329#endif
330 static DECLCALLBACK(int) i_display3DNotifyProcess(PPDMIDISPLAYCONNECTOR pInterface,
331 VBOX3DNOTIFY *p3DNotify);
332
333#ifdef VBOX_WITH_HGSMI
334 static DECLCALLBACK(int) i_displayVBVAEnable(PPDMIDISPLAYCONNECTOR pInterface, unsigned uScreenId,
335 VBVAHOSTFLAGS RT_UNTRUSTED_VOLATILE_GUEST *pHostFlags);
336 static DECLCALLBACK(void) i_displayVBVADisable(PPDMIDISPLAYCONNECTOR pInterface, unsigned uScreenId);
337 static DECLCALLBACK(void) i_displayVBVAUpdateBegin(PPDMIDISPLAYCONNECTOR pInterface, unsigned uScreenId);
338 static DECLCALLBACK(void) i_displayVBVAUpdateProcess(PPDMIDISPLAYCONNECTOR pInterface, unsigned uScreenId,
339 struct VBVACMDHDR const RT_UNTRUSTED_VOLATILE_GUEST *pCmd, size_t cbCmd);
340 static DECLCALLBACK(void) i_displayVBVAUpdateEnd(PPDMIDISPLAYCONNECTOR pInterface, unsigned uScreenId, int32_t x, int32_t y,
341 uint32_t cx, uint32_t cy);
342 static DECLCALLBACK(int) i_displayVBVAResize(PPDMIDISPLAYCONNECTOR pInterface, PCVBVAINFOVIEW pView,
343 PCVBVAINFOSCREEN pScreen, void *pvVRAM,
344 bool fResetInputMapping);
345 static DECLCALLBACK(int) i_displayVBVAMousePointerShape(PPDMIDISPLAYCONNECTOR pInterface, bool fVisible, bool fAlpha,
346 uint32_t xHot, uint32_t yHot, uint32_t cx, uint32_t cy,
347 const void *pvShape);
348 static DECLCALLBACK(void) i_displayVBVAGuestCapabilityUpdate(PPDMIDISPLAYCONNECTOR pInterface, uint32_t fCapabilities);
349
350 static DECLCALLBACK(void) i_displayVBVAInputMappingUpdate(PPDMIDISPLAYCONNECTOR pInterface, int32_t xOrigin, int32_t yOrigin,
351 uint32_t cx, uint32_t cy);
352 static DECLCALLBACK(void) i_displayVBVAReportCursorPosition(PPDMIDISPLAYCONNECTOR pInterface, uint32_t fFlags, uint32_t uScreen, uint32_t x, uint32_t y);
353#endif
354
355 static DECLCALLBACK(int) i_displaySSMSaveScreenshot(PSSMHANDLE pSSM, PCVMMR3VTABLE pVMM, void *pvUser);
356 static DECLCALLBACK(int) i_displaySSMLoadScreenshot(PSSMHANDLE pSSM, PCVMMR3VTABLE pVMM, void *pvUser,
357 uint32_t uVersion, uint32_t uPass);
358 static DECLCALLBACK(int) i_displaySSMSave(PSSMHANDLE pSSM, PCVMMR3VTABLE pVMM, void *pvUser);
359 static DECLCALLBACK(int) i_displaySSMLoad(PSSMHANDLE pSSM, PCVMMR3VTABLE pVMM, void *pvUser,
360 uint32_t uVersion, uint32_t uPass);
361
362 Console * const mParent;
363 /** Pointer to the associated display driver. */
364 struct DRVMAINDISPLAY *mpDrv;
365
366 unsigned mcMonitors;
367 /** Input mapping rectangle top left X relative to the first screen. */
368 int32_t xInputMappingOrigin;
369 /** Input mapping rectangle top left Y relative to the first screen. */
370 int32_t yInputMappingOrigin;
371 uint32_t cxInputMapping; /**< Input mapping rectangle width. */
372 uint32_t cyInputMapping; /**< Input mapping rectangle height. */
373 DISPLAYFBINFO maFramebuffers[SchemaDefs::MaxGuestMonitors];
374 /** Does the VMM device have the "supports graphics" capability set?
375 * Does not go into the saved state as it is refreshed on restore. */
376 bool mfVMMDevSupportsGraphics;
377 /** Mirror of the current guest VBVA capabilities. */
378 uint32_t mfGuestVBVACapabilities;
379 /** Mirror of the current host cursor capabilities. */
380 uint32_t mfHostCursorCapabilities;
381
382 bool mfSourceBitmapEnabled;
383 bool volatile fVGAResizing;
384
385 /** Are we in seamless mode? Not saved, as we exit seamless on saving. */
386 bool mfSeamlessEnabled;
387 /** Last set seamless visible region, number of rectangles. */
388 uint32_t mcRectVisibleRegion;
389 /** Last set seamless visible region, data. Freed on final clean-up. */
390 PRTRECT mpRectVisibleRegion;
391
392 bool mfVideoAccelVRDP;
393 uint32_t mfu32SupportedOrders;
394 /** Number of currently connected VRDP clients. */
395 int32_t volatile mcVRDPRefs;
396
397 /* The legacy VBVA data and methods. */
398 VIDEOACCEL mVideoAccelLegacy;
399
400 int i_VideoAccelEnable(bool fEnable, VBVAMEMORY *pVbvaMemory, PPDMIDISPLAYPORT pUpPort);
401 void i_VideoAccelFlush(PPDMIDISPLAYPORT pUpPort);
402 bool i_VideoAccelAllowed(void);
403
404 int i_videoAccelRefreshProcess(PPDMIDISPLAYPORT pUpPort);
405 int i_videoAccelEnable(bool fEnable, VBVAMEMORY *pVbvaMemory, PPDMIDISPLAYPORT pUpPort);
406 int i_videoAccelFlush(PPDMIDISPLAYPORT pUpPort);
407
408 /* Legacy pre-HGSMI handlers. */
409 void processAdapterData(void *pvVRAM, uint32_t u32VRAMSize);
410 void processDisplayData(void *pvVRAM, unsigned uScreenId);
411
412 /** Serializes access to mVideoAccelLegacy and mfVideoAccelVRDP, etc between VRDP and Display. */
413 RTCRITSECT mVideoAccelLock;
414
415#ifdef VBOX_WITH_RECORDING
416 /* Serializes access to video recording source bitmaps. */
417 RTCRITSECT mVideoRecLock;
418 /** Array which defines which screens are being enabled for recording. */
419 bool maRecordingEnabled[SchemaDefs::MaxGuestMonitors];
420#endif
421
422#ifdef VBOX_WITH_STATISTICS
423 struct
424 {
425 /** Profiling Display::i_displayRefreshCallback(). */
426 STAMPROFILE profileDisplayRefreshCallback;
427 /** Statistics for monitor N. */
428 struct
429 {
430 /** Statistics for recording of monitor N. */
431 struct
432 {
433 /** Profiling recording code of monitor N. */
434 STAMPROFILE profileRecording;
435 } Recording;
436 } Monitor[SchemaDefs::MaxGuestMonitors];
437 /** Statistics for audio/video recording. */
438 struct
439 {
440 /** Profiling recording code of all active monitors. */
441 STAMPROFILE profileRecording;
442 } Recording;
443 } Stats;
444#endif
445
446public:
447
448 static DECLCALLBACK(int) i_displayTakeScreenshotEMT(Display *pDisplay, ULONG aScreenId, uint8_t **ppbData, size_t *pcbData,
449 uint32_t *pcx, uint32_t *pcy, bool *pfMemFree);
450
451private:
452 static DECLCALLBACK(int) i_InvalidateAndUpdateEMT(Display *pDisplay, unsigned uId, bool fUpdateAll);
453 static DECLCALLBACK(int) i_drawToScreenEMT(Display *pDisplay, ULONG aScreenId, BYTE *address, ULONG x, ULONG y,
454 ULONG width, ULONG height);
455
456 void i_updateGuestGraphicsFacility(void);
457
458#ifdef VBOX_WITH_HGSMI
459 volatile uint32_t mu32UpdateVBVAFlags;
460#endif
461
462private:
463 DECLARE_CLS_COPY_CTOR_ASSIGN_NOOP(Display); /* Shuts up MSC warning C4625. */
464};
465
466/* The legacy VBVA helpers. */
467int videoAccelConstruct(VIDEOACCEL *pVideoAccel);
468void videoAccelDestroy(VIDEOACCEL *pVideoAccel);
469void i_vbvaSetMemoryFlags(VBVAMEMORY *pVbvaMemory,
470 bool fVideoAccelEnabled,
471 bool fVideoAccelVRDP,
472 uint32_t fu32SupportedOrders,
473 DISPLAYFBINFO *paFBInfos,
474 unsigned cFBInfos);
475int videoAccelEnterVGA(VIDEOACCEL *pVideoAccel);
476void videoAccelLeaveVGA(VIDEOACCEL *pVideoAccel);
477int videoAccelEnterVMMDev(VIDEOACCEL *pVideoAccel);
478void videoAccelLeaveVMMDev(VIDEOACCEL *pVideoAccel);
479
480
481/* helper function, code in DisplayResampleImage.cpp */
482void BitmapScale32(uint8_t *dst, int dstW, int dstH,
483 const uint8_t *src, int iDeltaLine, int srcW, int srcH);
484
485/* helper function, code in DisplayPNGUtul.cpp */
486int DisplayMakePNG(uint8_t *pbData, uint32_t cx, uint32_t cy,
487 uint8_t **ppu8PNG, uint32_t *pcbPNG, uint32_t *pcxPNG, uint32_t *pcyPNG,
488 uint8_t fLimitSize);
489
490class ATL_NO_VTABLE DisplaySourceBitmap:
491 public DisplaySourceBitmapWrap
492{
493public:
494
495 DECLARE_COMMON_CLASS_METHODS(DisplaySourceBitmap)
496
497 HRESULT FinalConstruct();
498 void FinalRelease();
499
500 /* Public initializer/uninitializer for internal purposes only. */
501 HRESULT init(ComObjPtr<Display> pDisplay, unsigned uScreenId, DISPLAYFBINFO *pFBInfo);
502 void uninit();
503
504 bool i_usesVRAM(void) { return m.pu8Allocated == NULL; }
505
506private:
507 // wrapped IDisplaySourceBitmap properties
508 virtual HRESULT getScreenId(ULONG *aScreenId);
509
510 // wrapped IDisplaySourceBitmap methods
511 virtual HRESULT queryBitmapInfo(BYTE **aAddress,
512 ULONG *aWidth,
513 ULONG *aHeight,
514 ULONG *aBitsPerPixel,
515 ULONG *aBytesPerLine,
516 BitmapFormat_T *aBitmapFormat);
517
518 int initSourceBitmap(unsigned aScreenId, DISPLAYFBINFO *pFBInfo);
519
520 struct Data
521 {
522 ComObjPtr<Display> pDisplay;
523 unsigned uScreenId;
524 DISPLAYFBINFO *pFBInfo;
525
526 uint8_t *pu8Allocated;
527
528 uint8_t *pu8Address;
529 ULONG ulWidth;
530 ULONG ulHeight;
531 ULONG ulBitsPerPixel;
532 ULONG ulBytesPerLine;
533 BitmapFormat_T bitmapFormat;
534 };
535
536 Data m;
537};
538
539class ATL_NO_VTABLE GuestScreenInfo:
540 public GuestScreenInfoWrap
541{
542public:
543
544 DECLARE_COMMON_CLASS_METHODS(GuestScreenInfo)
545
546 HRESULT FinalConstruct();
547 void FinalRelease();
548
549 /* Public initializer/uninitializer for internal purposes only. */
550 HRESULT init(ULONG aDisplay,
551 GuestMonitorStatus_T aGuestMonitorStatus,
552 BOOL aPrimary,
553 BOOL aChangeOrigin,
554 LONG aOriginX,
555 LONG aOriginY,
556 ULONG aWidth,
557 ULONG aHeight,
558 ULONG aBitsPerPixel);
559 void uninit();
560
561private:
562 // wrapped IGuestScreenInfo properties
563 virtual HRESULT getScreenId(ULONG *aScreenId);
564 virtual HRESULT getGuestMonitorStatus(GuestMonitorStatus_T *aGuestMonitorStatus);
565 virtual HRESULT getPrimary(BOOL *aPrimary);
566 virtual HRESULT getOrigin(BOOL *aOrigin);
567 virtual HRESULT getOriginX(LONG *aOriginX);
568 virtual HRESULT getOriginY(LONG *aOriginY);
569 virtual HRESULT getWidth(ULONG *aWidth);
570 virtual HRESULT getHeight(ULONG *aHeight);
571 virtual HRESULT getBitsPerPixel(ULONG *aBitsPerPixel);
572 virtual HRESULT getExtendedInfo(com::Utf8Str &aExtendedInfo);
573
574 ULONG mScreenId;
575 GuestMonitorStatus_T mGuestMonitorStatus;
576 BOOL mPrimary;
577 BOOL mOrigin;
578 LONG mOriginX;
579 LONG mOriginY;
580 ULONG mWidth;
581 ULONG mHeight;
582 ULONG mBitsPerPixel;
583};
584
585#endif /* !MAIN_INCLUDED_DisplayImpl_h */
586/* vi: set tabstop=4 shiftwidth=4 expandtab: */
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle
ContactPrivacy/Do Not Sell My InfoTerms of Use