DisplayImpl.h revision 8d0e08b1554426514051150bb804899260631334
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync/* $Id$ */
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync/** @file
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync * VirtualBox COM class implementation
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync */
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync/*
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync * Copyright (C) 2006-2013 Oracle Corporation
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync *
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync * This file is part of VirtualBox Open Source Edition (OSE), as
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync * available from http://www.virtualbox.org. This file is free software;
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync * you can redistribute it and/or modify it under the terms of the GNU
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync * General Public License (GPL) as published by the Free Software
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync * Foundation, in version 2 as it comes in the "COPYING" file of the
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync */
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync#ifndef ____H_DISPLAYIMPL
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync#define ____H_DISPLAYIMPL
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync#include "VirtualBoxBase.h"
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync#include "SchemaDefs.h"
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync#include <iprt/semaphore.h>
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync#include <VBox/vmm/pdmdrv.h>
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync#include <VBox/VMMDev.h>
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync#include <VBox/VBoxVideo.h>
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsyncclass Console;
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsyncstruct VIDEORECCONTEXT;
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsyncenum
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync{
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync ResizeStatus_Void,
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync ResizeStatus_InProgress,
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync ResizeStatus_UpdateDisplayData
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync};
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsynctypedef struct _DISPLAYFBINFO
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync{
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync uint32_t u32Offset;
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync uint32_t u32MaxFramebufferSize;
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync uint32_t u32InformationSize;
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync ComPtr<IFramebuffer> pFramebuffer;
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync bool fDisabled;
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync
17ef1920962b3df57bf6d2704ced1586396d96f0vboxsync LONG xOrigin;
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync LONG yOrigin;
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync ULONG w;
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync ULONG h;
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync uint16_t u16BitsPerPixel;
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync uint8_t *pu8FramebufferVRAM;
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync uint32_t u32LineSize;
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync uint16_t flags;
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync /* for saving the rectangles arrived during fb resize is in progress. */
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync PRTRECT mpSavedVisibleRegion;
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync uint32_t mcSavedVisibleRegion;
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync VBOXVIDEOINFOHOSTEVENTS *pHostEvents;
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync volatile uint32_t u32ResizeStatus;
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync /* The Framebuffer has default format and must be updates immediately. */
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync bool fDefaultFormat;
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync struct
8867771015571c5542d39e393d7fe6304421a928vboxsync {
8867771015571c5542d39e393d7fe6304421a928vboxsync /* The rectangle that includes all dirty rectangles. */
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync int32_t xLeft;
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync int32_t xRight;
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync int32_t yTop;
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync int32_t yBottom;
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync } dirtyRect;
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync struct
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync {
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync bool fPending;
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync ULONG pixelFormat;
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync void *pvVRAM;
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync uint32_t bpp;
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync uint32_t cbLine;
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync int w;
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync int h;
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync uint16_t flags;
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync } pendingResize;
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync
8867771015571c5542d39e393d7fe6304421a928vboxsync#ifdef VBOX_WITH_HGSMI
8867771015571c5542d39e393d7fe6304421a928vboxsync bool fVBVAEnabled;
8867771015571c5542d39e393d7fe6304421a928vboxsync uint32_t cVBVASkipUpdate;
8867771015571c5542d39e393d7fe6304421a928vboxsync struct
8867771015571c5542d39e393d7fe6304421a928vboxsync {
8867771015571c5542d39e393d7fe6304421a928vboxsync int32_t xLeft;
8867771015571c5542d39e393d7fe6304421a928vboxsync int32_t yTop;
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync int32_t xRight;
8867771015571c5542d39e393d7fe6304421a928vboxsync int32_t yBottom;
8867771015571c5542d39e393d7fe6304421a928vboxsync } vbvaSkippedRect;
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync PVBVAHOSTFLAGS pVBVAHostFlags;
8867771015571c5542d39e393d7fe6304421a928vboxsync#endif /* VBOX_WITH_HGSMI */
8867771015571c5542d39e393d7fe6304421a928vboxsync} DISPLAYFBINFO;
8867771015571c5542d39e393d7fe6304421a928vboxsync
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsyncclass DisplayMouseInterface
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync{
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsyncpublic:
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync virtual int getScreenResolution(uint32_t cScreen, ULONG *pcx,
f5edc444546b57af847ae33f2bd1e10442496e47vboxsync ULONG *pcy, ULONG *pcBPP) = 0;
f5edc444546b57af847ae33f2bd1e10442496e47vboxsync virtual void getFramebufferDimensions(int32_t *px1, int32_t *py1,
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync int32_t *px2, int32_t *py2) = 0;
9de47c4ec7b0fc9a384e4b815153de399da7b8devboxsync};
9de47c4ec7b0fc9a384e4b815153de399da7b8devboxsync
8867771015571c5542d39e393d7fe6304421a928vboxsyncclass ATL_NO_VTABLE Display :
8867771015571c5542d39e393d7fe6304421a928vboxsync public VirtualBoxBase,
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync VBOX_SCRIPTABLE_IMPL(IEventListener),
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync VBOX_SCRIPTABLE_IMPL(IDisplay),
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync public DisplayMouseInterface
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync{
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsyncpublic:
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync VIRTUALBOXBASE_ADD_ERRORINFO_SUPPORT(Display, IDisplay)
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync DECLARE_NOT_AGGREGATABLE(Display)
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync DECLARE_PROTECT_FINAL_CONSTRUCT()
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync BEGIN_COM_MAP(Display)
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync VBOX_DEFAULT_INTERFACE_ENTRIES(IDisplay)
8867771015571c5542d39e393d7fe6304421a928vboxsync COM_INTERFACE_ENTRY(IEventListener)
8867771015571c5542d39e393d7fe6304421a928vboxsync END_COM_MAP()
8867771015571c5542d39e393d7fe6304421a928vboxsync
8867771015571c5542d39e393d7fe6304421a928vboxsync DECLARE_EMPTY_CTOR_DTOR(Display)
8867771015571c5542d39e393d7fe6304421a928vboxsync
8867771015571c5542d39e393d7fe6304421a928vboxsync HRESULT FinalConstruct();
9de47c4ec7b0fc9a384e4b815153de399da7b8devboxsync void FinalRelease();
9de47c4ec7b0fc9a384e4b815153de399da7b8devboxsync
9de47c4ec7b0fc9a384e4b815153de399da7b8devboxsync // public initializer/uninitializer for internal purposes only
9de47c4ec7b0fc9a384e4b815153de399da7b8devboxsync HRESULT init(Console *aParent);
9de47c4ec7b0fc9a384e4b815153de399da7b8devboxsync void uninit();
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync int registerSSM(PUVM pUVM);
9de47c4ec7b0fc9a384e4b815153de399da7b8devboxsync
9de47c4ec7b0fc9a384e4b815153de399da7b8devboxsync // public methods only for internal purposes
9de47c4ec7b0fc9a384e4b815153de399da7b8devboxsync int handleDisplayResize(unsigned uScreenId, uint32_t bpp, void *pvVRAM, uint32_t cbLine, int w, int h, uint16_t flags);
9de47c4ec7b0fc9a384e4b815153de399da7b8devboxsync void handleDisplayUpdateLegacy(int x, int y, int cx, int cy);
8867771015571c5542d39e393d7fe6304421a928vboxsync void handleDisplayUpdate(unsigned uScreenId, int x, int y, int w, int h);
8867771015571c5542d39e393d7fe6304421a928vboxsync#ifdef VBOX_WITH_VIDEOHWACCEL
8867771015571c5542d39e393d7fe6304421a928vboxsync void handleVHWACommandProcess(PPDMIDISPLAYCONNECTOR pInterface, PVBOXVHWACMD pCommand);
9de47c4ec7b0fc9a384e4b815153de399da7b8devboxsync#endif
9de47c4ec7b0fc9a384e4b815153de399da7b8devboxsync#ifdef VBOX_WITH_CRHGSMI
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync void handleCrHgsmiCommandProcess(PPDMIDISPLAYCONNECTOR pInterface, PVBOXVDMACMD_CHROMIUM_CMD pCmd, uint32_t cbCmd);
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync void handleCrHgsmiControlProcess(PPDMIDISPLAYCONNECTOR pInterface, PVBOXVDMACMD_CHROMIUM_CTL pCtl, uint32_t cbCtl);
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync void handleCrHgsmiCommandCompletion(int32_t result, uint32_t u32Function, PVBOXHGCMSVCPARM pParam);
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync void handleCrHgsmiControlCompletion(int32_t result, uint32_t u32Function, PVBOXHGCMSVCPARM pParam);
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync#endif
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync IFramebuffer *getFramebuffer()
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync {
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync return maFramebuffers[VBOX_VIDEO_PRIMARY_SCREEN].pFramebuffer;
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync }
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync void getFramebufferDimensions(int32_t *px1, int32_t *py1, int32_t *px2, int32_t *py2);
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync int getScreenResolution(uint32_t cScreen, ULONG *pcx, ULONG *pcy,
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync ULONG *pcBPP)
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync {
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync return GetScreenResolution(cScreen, pcx, pcy, pcBPP);
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync }
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync
8867771015571c5542d39e393d7fe6304421a928vboxsync int handleSetVisibleRegion(uint32_t cRect, PRTRECT pRect);
8867771015571c5542d39e393d7fe6304421a928vboxsync int handleQueryVisibleRegion(uint32_t *pcRect, PRTRECT pRect);
8867771015571c5542d39e393d7fe6304421a928vboxsync
8867771015571c5542d39e393d7fe6304421a928vboxsync int VideoAccelEnable(bool fEnable, VBVAMEMORY *pVbvaMemory);
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync void VideoAccelFlush(void);
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync bool VideoAccelAllowed(void);
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync void VideoAccelVRDP(bool fEnable);
8867771015571c5542d39e393d7fe6304421a928vboxsync
8867771015571c5542d39e393d7fe6304421a928vboxsync int VideoCaptureStart();
8867771015571c5542d39e393d7fe6304421a928vboxsync void VideoCaptureStop();
8867771015571c5542d39e393d7fe6304421a928vboxsync int VideoCaptureEnableScreens(ComSafeArrayIn(BOOL, aScreens));
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync // IEventListener methods
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync STDMETHOD(HandleEvent)(IEvent * aEvent);
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync // IDisplay methods
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync STDMETHOD(GetScreenResolution)(ULONG aScreenId, ULONG *aWidth, ULONG *aHeight, ULONG *aBitsPerPixel);
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync STDMETHOD(SetFramebuffer)(ULONG aScreenId, IFramebuffer *aFramebuffer);
9de47c4ec7b0fc9a384e4b815153de399da7b8devboxsync STDMETHOD(GetFramebuffer)(ULONG aScreenId, IFramebuffer **aFramebuffer, LONG *aXOrigin, LONG *aYOrigin);
9de47c4ec7b0fc9a384e4b815153de399da7b8devboxsync STDMETHOD(SetVideoModeHint)(ULONG aDisplay, BOOL aEnabled, BOOL aChangeOrigin, LONG aOriginX, LONG aOriginY, ULONG aWidth, ULONG aHeight, ULONG aBitsPerPixel);
9de47c4ec7b0fc9a384e4b815153de399da7b8devboxsync STDMETHOD(TakeScreenShot)(ULONG aScreenId, BYTE *address, ULONG width, ULONG height);
9de47c4ec7b0fc9a384e4b815153de399da7b8devboxsync STDMETHOD(TakeScreenShotToArray)(ULONG aScreenId, ULONG width, ULONG height, ComSafeArrayOut(BYTE, aScreenData));
9de47c4ec7b0fc9a384e4b815153de399da7b8devboxsync STDMETHOD(TakeScreenShotPNGToArray)(ULONG aScreenId, ULONG width, ULONG height, ComSafeArrayOut(BYTE, aScreenData));
9de47c4ec7b0fc9a384e4b815153de399da7b8devboxsync STDMETHOD(DrawToScreen)(ULONG aScreenId, BYTE *address, ULONG x, ULONG y, ULONG width, ULONG height);
9de47c4ec7b0fc9a384e4b815153de399da7b8devboxsync STDMETHOD(InvalidateAndUpdate)();
9de47c4ec7b0fc9a384e4b815153de399da7b8devboxsync STDMETHOD(ResizeCompleted)(ULONG aScreenId);
9de47c4ec7b0fc9a384e4b815153de399da7b8devboxsync STDMETHOD(SetSeamlessMode)(BOOL enabled);
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync
fe14fe6d46ce87a9b25cbdacb3a20b1f87bf34c7vboxsync STDMETHOD(CompleteVHWACommand)(BYTE *pCommand);
8867771015571c5542d39e393d7fe6304421a928vboxsync
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync STDMETHOD(ViewportChanged)(ULONG aScreenId, ULONG x, ULONG y, ULONG width, ULONG height);
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync static const PDMDRVREG DrvReg;
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsyncprivate:
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync void updateDisplayData(void);
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync#ifdef VBOX_WITH_CRHGSMI
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync void setupCrHgsmiData(void);
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync void destructCrHgsmiData(void);
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync#endif
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync static DECLCALLBACK(int) changeFramebuffer(Display *that, IFramebuffer *aFB, unsigned uScreenId);
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync static DECLCALLBACK(void*) drvQueryInterface(PPDMIBASE pInterface, const char *pszIID);
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync static DECLCALLBACK(int) drvConstruct(PPDMDRVINS pDrvIns, PCFGMNODE pCfg, uint32_t fFlags);
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync static DECLCALLBACK(void) drvDestruct(PPDMDRVINS pDrvIns);
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync static DECLCALLBACK(int) displayResizeCallback(PPDMIDISPLAYCONNECTOR pInterface, uint32_t bpp, void *pvVRAM, uint32_t cbLine, uint32_t cx, uint32_t cy);
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync static DECLCALLBACK(void) displayUpdateCallback(PPDMIDISPLAYCONNECTOR pInterface,
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync uint32_t x, uint32_t y, uint32_t cx, uint32_t cy);
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync static DECLCALLBACK(void) displayRefreshCallback(PPDMIDISPLAYCONNECTOR pInterface);
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync static DECLCALLBACK(void) displayResetCallback(PPDMIDISPLAYCONNECTOR pInterface);
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync static DECLCALLBACK(void) displayLFBModeChangeCallback(PPDMIDISPLAYCONNECTOR pInterface, bool fEnabled);
8867771015571c5542d39e393d7fe6304421a928vboxsync static DECLCALLBACK(void) displayProcessAdapterDataCallback(PPDMIDISPLAYCONNECTOR pInterface, void *pvVRAM, uint32_t u32VRAMSize);
8867771015571c5542d39e393d7fe6304421a928vboxsync static DECLCALLBACK(void) displayProcessDisplayDataCallback(PPDMIDISPLAYCONNECTOR pInterface, void *pvVRAM, unsigned uScreenId);
8867771015571c5542d39e393d7fe6304421a928vboxsync
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync#ifdef VBOX_WITH_VIDEOHWACCEL
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync static DECLCALLBACK(void) displayVHWACommandProcess(PPDMIDISPLAYCONNECTOR pInterface, PVBOXVHWACMD pCommand);
8867771015571c5542d39e393d7fe6304421a928vboxsync#endif
8867771015571c5542d39e393d7fe6304421a928vboxsync
8867771015571c5542d39e393d7fe6304421a928vboxsync#ifdef VBOX_WITH_CRHGSMI
8867771015571c5542d39e393d7fe6304421a928vboxsync static DECLCALLBACK(void) displayCrHgsmiCommandProcess(PPDMIDISPLAYCONNECTOR pInterface, PVBOXVDMACMD_CHROMIUM_CMD pCmd, uint32_t cbCmd);
8867771015571c5542d39e393d7fe6304421a928vboxsync static DECLCALLBACK(void) displayCrHgsmiControlProcess(PPDMIDISPLAYCONNECTOR pInterface, PVBOXVDMACMD_CHROMIUM_CTL pCtl, uint32_t cbCtl);
8867771015571c5542d39e393d7fe6304421a928vboxsync
8867771015571c5542d39e393d7fe6304421a928vboxsync static DECLCALLBACK(void) displayCrHgsmiCommandCompletion(int32_t result, uint32_t u32Function, PVBOXHGCMSVCPARM pParam, void *pvContext);
8867771015571c5542d39e393d7fe6304421a928vboxsync static DECLCALLBACK(void) displayCrHgsmiControlCompletion(int32_t result, uint32_t u32Function, PVBOXHGCMSVCPARM pParam, void *pvContext);
8867771015571c5542d39e393d7fe6304421a928vboxsync#endif
8867771015571c5542d39e393d7fe6304421a928vboxsync
8867771015571c5542d39e393d7fe6304421a928vboxsync#ifdef VBOX_WITH_HGSMI
8867771015571c5542d39e393d7fe6304421a928vboxsync static DECLCALLBACK(int) displayVBVAEnable(PPDMIDISPLAYCONNECTOR pInterface, unsigned uScreenId, PVBVAHOSTFLAGS pHostFlags);
8867771015571c5542d39e393d7fe6304421a928vboxsync static DECLCALLBACK(void) displayVBVADisable(PPDMIDISPLAYCONNECTOR pInterface, unsigned uScreenId);
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync static DECLCALLBACK(void) displayVBVAUpdateBegin(PPDMIDISPLAYCONNECTOR pInterface, unsigned uScreenId);
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync static DECLCALLBACK(void) displayVBVAUpdateProcess(PPDMIDISPLAYCONNECTOR pInterface, unsigned uScreenId, const PVBVACMDHDR pCmd, size_t cbCmd);
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync static DECLCALLBACK(void) displayVBVAUpdateEnd(PPDMIDISPLAYCONNECTOR pInterface, unsigned uScreenId, int32_t x, int32_t y, uint32_t cx, uint32_t cy);
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync static DECLCALLBACK(int) displayVBVAResize(PPDMIDISPLAYCONNECTOR pInterface, const PVBVAINFOVIEW pView, const PVBVAINFOSCREEN pScreen, void *pvVRAM);
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync static DECLCALLBACK(int) displayVBVAMousePointerShape(PPDMIDISPLAYCONNECTOR pInterface, bool fVisible, bool fAlpha, uint32_t xHot, uint32_t yHot, uint32_t cx, uint32_t cy, const void *pvShape);
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync#endif
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync static DECLCALLBACK(void) displaySSMSaveScreenshot(PSSMHANDLE pSSM, void *pvUser);
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync static DECLCALLBACK(int) displaySSMLoadScreenshot(PSSMHANDLE pSSM, void *pvUser, uint32_t uVersion, uint32_t uPass);
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync static DECLCALLBACK(void) displaySSMSave(PSSMHANDLE pSSM, void *pvUser);
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync static DECLCALLBACK(int) displaySSMLoad(PSSMHANDLE pSSM, void *pvUser, uint32_t uVersion, uint32_t uPass);
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync Console * const mParent;
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync /** Pointer to the associated display driver. */
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync struct DRVMAINDISPLAY *mpDrv;
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync /** Pointer to the device instance for the VMM Device. */
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync PPDMDEVINS mpVMMDev;
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync /** Set after the first attempt to find the VMM Device. */
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync bool mfVMMDevInited;
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync unsigned mcMonitors;
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync DISPLAYFBINFO maFramebuffers[SchemaDefs::MaxGuestMonitors];
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync /* arguments of the last handleDisplayResize() call */
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync void *mLastAddress;
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync uint32_t mLastBytesPerLine;
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync uint32_t mLastBitsPerPixel;
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync int mLastWidth;
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync int mLastHeight;
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync uint16_t mLastFlags;
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync VBVAMEMORY *mpVbvaMemory;
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync bool mfVideoAccelEnabled;
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync bool mfVideoAccelVRDP;
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync uint32_t mfu32SupportedOrders;
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync int32_t volatile mcVideoAccelVRDPRefs;
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync VBVAMEMORY *mpPendingVbvaMemory;
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync bool mfPendingVideoAccelEnable;
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync bool mfMachineRunning;
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync uint8_t *mpu8VbvaPartial;
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync uint32_t mcbVbvaPartial;
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync#ifdef VBOX_WITH_CRHGSMI
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync /* for fast host hgcm calls */
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync HGCMCVSHANDLE mhCrOglSvc;
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync#endif
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync bool vbvaFetchCmd(VBVACMDHDR **ppHdr, uint32_t *pcbCmd);
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync void vbvaReleaseCmd(VBVACMDHDR *pHdr, int32_t cbCmd);
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync void handleResizeCompletedEMT(void);
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync RTCRITSECT mVBVALock;
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync volatile uint32_t mfu32PendingVideoAccelDisable;
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync
8867771015571c5542d39e393d7fe6304421a928vboxsync int vbvaLock(void);
8867771015571c5542d39e393d7fe6304421a928vboxsync void vbvaUnlock(void);
8867771015571c5542d39e393d7fe6304421a928vboxsync
8867771015571c5542d39e393d7fe6304421a928vboxsync RTCRITSECT mSaveSeamlessRectLock;
8867771015571c5542d39e393d7fe6304421a928vboxsync int SaveSeamlessRectLock(void);
8867771015571c5542d39e393d7fe6304421a928vboxsync void SaveSeamlessRectUnLock(void);
8867771015571c5542d39e393d7fe6304421a928vboxsync
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsyncpublic:
8867771015571c5542d39e393d7fe6304421a928vboxsync static int displayTakeScreenshotEMT(Display *pDisplay, ULONG aScreenId, uint8_t **ppu8Data, size_t *pcbData, uint32_t *pu32Width, uint32_t *pu32Height);
8867771015571c5542d39e393d7fe6304421a928vboxsync
8867771015571c5542d39e393d7fe6304421a928vboxsyncprivate:
8867771015571c5542d39e393d7fe6304421a928vboxsync static void InvalidateAndUpdateEMT(Display *pDisplay, unsigned uId, bool fUpdateAll);
8867771015571c5542d39e393d7fe6304421a928vboxsync static int drawToScreenEMT(Display *pDisplay, ULONG aScreenId, BYTE *address, ULONG x, ULONG y, ULONG width, ULONG height);
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync
8867771015571c5542d39e393d7fe6304421a928vboxsync int videoAccelRefreshProcess(void);
8867771015571c5542d39e393d7fe6304421a928vboxsync
8867771015571c5542d39e393d7fe6304421a928vboxsync /* Functions run under VBVA lock. */
8867771015571c5542d39e393d7fe6304421a928vboxsync int videoAccelEnable(bool fEnable, VBVAMEMORY *pVbvaMemory);
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync void videoAccelFlush(void);
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync
8867771015571c5542d39e393d7fe6304421a928vboxsync#ifdef VBOX_WITH_HGSMI
8867771015571c5542d39e393d7fe6304421a928vboxsync volatile uint32_t mu32UpdateVBVAFlags;
8867771015571c5542d39e393d7fe6304421a928vboxsync#endif
8867771015571c5542d39e393d7fe6304421a928vboxsync
8867771015571c5542d39e393d7fe6304421a928vboxsync#ifdef VBOX_WITH_VPX
8867771015571c5542d39e393d7fe6304421a928vboxsync VIDEORECCONTEXT *mpVideoRecCtx;
8867771015571c5542d39e393d7fe6304421a928vboxsync bool maVideoRecEnabled[SchemaDefs::MaxGuestMonitors];
8867771015571c5542d39e393d7fe6304421a928vboxsync#endif
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync};
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsyncvoid gdImageCopyResampled(uint8_t *dst, uint8_t *src,
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync int dstX, int dstY, int srcX, int srcY,
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync int dstW, int dstH, int srcW, int srcH);
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsync
4c464a0800535c29782d7ab5bcd7820bc7115cd7vboxsyncvoid BitmapScale32(uint8_t *dst, int dstW, int dstH,
8867771015571c5542d39e393d7fe6304421a928vboxsync const uint8_t *src, int iDeltaLine, int srcW, int srcH);
8867771015571c5542d39e393d7fe6304421a928vboxsync
8867771015571c5542d39e393d7fe6304421a928vboxsyncint DisplayMakePNG(uint8_t *pu8Data, uint32_t cx, uint32_t cy,
8867771015571c5542d39e393d7fe6304421a928vboxsync uint8_t **ppu8PNG, uint32_t *pcbPNG, uint32_t *pcxPNG, uint32_t *pcyPNG,
8867771015571c5542d39e393d7fe6304421a928vboxsync uint8_t fLimitSize);
8867771015571c5542d39e393d7fe6304421a928vboxsync
8867771015571c5542d39e393d7fe6304421a928vboxsync#endif // ____H_DISPLAYIMPL
8867771015571c5542d39e393d7fe6304421a928vboxsync/* vi: set tabstop=4 shiftwidth=4 expandtab: */
c1b4529a269091edd0274bd98d35b75663fd66c0vboxsync