1 | /******************************Module*Header*******************************\
|
---|
2 | *
|
---|
3 | * Copyright (C) 2006-2007 Sun Microsystems, Inc.
|
---|
4 | *
|
---|
5 | * This file is part of VirtualBox Open Source Edition (OSE), as
|
---|
6 | * available from http://www.virtualbox.org. This file is free software;
|
---|
7 | * you can redistribute it and/or modify it under the terms of the GNU
|
---|
8 | * General Public License (GPL) as published by the Free Software
|
---|
9 | * Foundation, in version 2 as it comes in the "COPYING" file of the
|
---|
10 | * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
|
---|
11 | * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
|
---|
12 | *
|
---|
13 | * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
|
---|
14 | * Clara, CA 95054 USA or visit http://www.sun.com if you need
|
---|
15 | * additional information or have any questions.
|
---|
16 | */
|
---|
17 | /*
|
---|
18 | * Based in part on Microsoft DDK sample code
|
---|
19 | *
|
---|
20 | * *******************
|
---|
21 | * * GDI SAMPLE CODE *
|
---|
22 | * *******************
|
---|
23 | *
|
---|
24 | * Module Name: driver.h
|
---|
25 | *
|
---|
26 | * contains prototypes for the frame buffer driver.
|
---|
27 | *
|
---|
28 | * Copyright (c) 1992-1998 Microsoft Corporation
|
---|
29 | \**************************************************************************/
|
---|
30 |
|
---|
31 | #define DBG 1
|
---|
32 |
|
---|
33 | #include "stddef.h"
|
---|
34 |
|
---|
35 | #include <stdarg.h>
|
---|
36 |
|
---|
37 | #include "windef.h"
|
---|
38 | #include "wingdi.h"
|
---|
39 | #include "winddi.h"
|
---|
40 | #include "devioctl.h"
|
---|
41 | #include "ntddvdeo.h"
|
---|
42 | #include "debug.h"
|
---|
43 |
|
---|
44 | typedef struct _PDEV
|
---|
45 | {
|
---|
46 | HANDLE hDriver; // Handle to \Device\Screen
|
---|
47 | HDEV hdevEng; // Engine's handle to PDEV
|
---|
48 | HSURF hsurfEng; // Engine's handle to surface
|
---|
49 | //@todo Make work without palette
|
---|
50 | HPALETTE hpalDefault; // Handle to the default palette for device.
|
---|
51 | PBYTE pjScreen; // This is pointer to base screen address
|
---|
52 | ULONG cxScreen; // Visible screen width
|
---|
53 | ULONG cyScreen; // Visible screen height
|
---|
54 | POINTL ptlOrg; // Where this display is anchored in
|
---|
55 | // the virtual desktop.
|
---|
56 | ULONG ulMode; // Mode the mini-port driver is in.
|
---|
57 | LONG lDeltaScreen; // Distance from one scan to the next.
|
---|
58 | ULONG cScreenSize; // size of video memory, including
|
---|
59 | // offscreen memory.
|
---|
60 | PVOID pOffscreenList; // linked list of DCI offscreen surfaces.
|
---|
61 | FLONG flRed; // For bitfields device, Red Mask
|
---|
62 | FLONG flGreen; // For bitfields device, Green Mask
|
---|
63 | FLONG flBlue; // For bitfields device, Blue Mask
|
---|
64 | ULONG cPaletteShift; // number of bits the 8-8-8 palette must
|
---|
65 | // be shifted by to fit in the hardware
|
---|
66 | // palette.
|
---|
67 | ULONG ulBitCount; // # of bits per pel 8,16,24,32 are only supported.
|
---|
68 | POINTL ptlHotSpot; // adjustment for pointer hot spot
|
---|
69 | VIDEO_POINTER_CAPABILITIES PointerCapabilities; // HW pointer abilities
|
---|
70 | PVIDEO_POINTER_ATTRIBUTES pPointerAttributes; // hardware pointer attributes
|
---|
71 | DWORD cjPointerAttributes; // Size of buffer allocated
|
---|
72 | BOOL fHwCursorActive; // Are we currently using the hw cursor
|
---|
73 | PALETTEENTRY *pPal; // If this is pal managed, this is the pal
|
---|
74 | BOOL bSupportDCI; // Does the miniport support DCI?
|
---|
75 |
|
---|
76 | //@todo Make work without allocation
|
---|
77 | PVOID pvTmpBuffer; // ptr to MIRRSURF bits for screen surface
|
---|
78 | } PDEV, *PPDEV;
|
---|
79 |
|
---|
80 | typedef struct _MIRRSURF {
|
---|
81 | PPDEV *pdev;
|
---|
82 | ULONG cx;
|
---|
83 | ULONG cy;
|
---|
84 | ULONG lDelta;
|
---|
85 | ULONG ulBitCount;
|
---|
86 | BOOL bIsScreen;
|
---|
87 |
|
---|
88 | } MIRRSURF, *PMIRRSURF;
|
---|
89 |
|
---|
90 | DWORD getAvailableModes(HANDLE, PVIDEO_MODE_INFORMATION *, DWORD *);
|
---|
91 | BOOL bInitPDEV(PPDEV, PDEVMODEW, GDIINFO *, DEVINFO *);
|
---|
92 | BOOL bInitSURF(PPDEV, BOOL);
|
---|
93 | BOOL bInitPaletteInfo(PPDEV, DEVINFO *);
|
---|
94 | BOOL bInitPointer(PPDEV, DEVINFO *);
|
---|
95 | BOOL bInit256ColorPalette(PPDEV);
|
---|
96 | VOID vDisablePalette(PPDEV);
|
---|
97 | VOID vDisableSURF(PPDEV);
|
---|
98 |
|
---|
99 | #define MAX_CLUT_SIZE (sizeof(VIDEO_CLUT) + (sizeof(ULONG) * 256))
|
---|
100 |
|
---|
101 | //
|
---|
102 | // Determines the size of the DriverExtra information in the DEVMODE
|
---|
103 | // structure passed to and from the display driver.
|
---|
104 | //
|
---|
105 |
|
---|
106 | #define DRIVER_EXTRA_SIZE 0
|
---|
107 |
|
---|
108 | #define DLL_NAME L"vrdpdd" // Name of the DLL in UNICODE
|
---|
109 | #define STANDARD_DEBUG_PREFIX "vrdpdd: " // All debug output is prefixed
|
---|
110 | #define ALLOC_TAG 'rvDD' // Four byte tag (characters in
|
---|
111 | // reverse order) used for memory
|
---|
112 | // allocations
|
---|
113 |
|
---|