[WIN32K]
[reactos.git] / subsystems / win32 / win32k / include / gdiobj.h
1 /*
2 * GDI object common header definition
3 *
4 */
5
6 #pragma once
7
8 /* Public GDI Object/Handle definitions */
9 #include <win32k/ntgdihdl.h>
10 #include "win32.h"
11
12 typedef struct _GDI_HANDLE_TABLE
13 {
14 /* The table must be located at the beginning of this structure so it can be
15 * properly mapped!
16 */
17 //////////////////////////////////////////////////////////////////////////////
18 GDI_TABLE_ENTRY Entries[GDI_HANDLE_COUNT];
19 DEVCAPS DevCaps; // Device Capabilities.
20 FLONG flDeviceUniq; // Device settings uniqueness.
21 PVOID pvLangPack; // Language Pack.
22 CFONT cfPublic[GDI_CFONT_MAX]; // Public Fonts.
23 DWORD dwCFCount;
24 //////////////////////////////////////////////////////////////////////////////
25 PPAGED_LOOKASIDE_LIST LookasideLists;
26
27 ULONG FirstFree;
28 ULONG FirstUnused;
29
30 } GDI_HANDLE_TABLE, *PGDI_HANDLE_TABLE;
31
32 extern PGDI_HANDLE_TABLE GdiHandleTable;
33
34 typedef PVOID PGDIOBJ;
35
36 typedef BOOL (INTERNAL_CALL *GDICLEANUPPROC)(PVOID ObjectBody);
37 typedef VOID (INTERNAL_CALL *GDILOCKOBJPROC)(PVOID ObjectBody);
38
39 /* Every GDI Object must have this standard type of header.
40 * It's for thread locking. */
41 typedef struct _BASEOBJECT
42 {
43 HGDIOBJ hHmgr;
44 ULONG ulShareCount;
45 USHORT cExclusiveLock;
46 USHORT BaseFlags;
47 PTHREADINFO Tid;
48 } BASEOBJECT, *POBJ;
49
50 typedef struct _CLIENTOBJ
51 {
52 BASEOBJECT BaseObject;
53 } CLIENTOBJ, *PCLIENTOBJ;
54
55 enum BASEFLAGS
56 {
57 BASEFLAG_LOOKASIDE = 0x80,
58
59 /* ReactOS specific: */
60 BASEFLAG_READY_TO_DIE = 0x1000
61 };
62
63 BOOL INTERNAL_CALL GDIOBJ_OwnedByCurrentProcess(HGDIOBJ ObjectHandle);
64 BOOL INTERNAL_CALL GDIOBJ_SetOwnership(HGDIOBJ ObjectHandle, PEPROCESS Owner);
65 BOOL INTERNAL_CALL GDIOBJ_CopyOwnership(HGDIOBJ CopyFrom, HGDIOBJ CopyTo);
66 BOOL INTERNAL_CALL GDIOBJ_ConvertToStockObj(HGDIOBJ *hObj);
67 //VOID INTERNAL_CALL GDIOBJ_ShareUnlockObjByPtr(POBJ Object);
68 BOOL INTERNAL_CALL GDIOBJ_ValidateHandle(HGDIOBJ hObj, ULONG ObjectType);
69 POBJ INTERNAL_CALL GDIOBJ_AllocObj(UCHAR ObjectType);
70 POBJ INTERNAL_CALL GDIOBJ_AllocObjWithHandle(ULONG ObjectType);
71 VOID INTERNAL_CALL GDIOBJ_FreeObj (POBJ pObj, UCHAR ObjectType);
72 BOOL INTERNAL_CALL GDIOBJ_FreeObjByHandle (HGDIOBJ hObj, DWORD ObjectType);
73 PGDIOBJ INTERNAL_CALL GDIOBJ_LockObj (HGDIOBJ hObj, DWORD ObjectType);
74 PGDIOBJ INTERNAL_CALL GDIOBJ_ShareLockObj (HGDIOBJ hObj, DWORD ObjectType);
75 VOID INTERNAL_CALL GDIOBJ_LockMultipleObjs(ULONG ulCount, IN HGDIOBJ* ahObj, OUT PGDIOBJ* apObj);
76
77 PVOID INTERNAL_CALL GDI_MapHandleTable(PSECTION_OBJECT SectionObject, PEPROCESS Process);
78
79 #define GDIOBJ_GetObjectType(Handle) \
80 GDI_HANDLE_GET_TYPE(Handle)
81
82 #define GDIOBJFLAG_DEFAULT (0x0)
83 #define GDIOBJFLAG_IGNOREPID (0x1)
84 #define GDIOBJFLAG_IGNORELOCK (0x2)
85
86 BOOL FASTCALL GreDeleteObject(HGDIOBJ hObject);
87 BOOL FASTCALL IsObjectDead(HGDIOBJ);
88 BOOL FASTCALL IntGdiSetDCOwnerEx( HDC, DWORD, BOOL);
89 BOOL FASTCALL IntGdiSetRegionOwner(HRGN,DWORD);
90
91 /*!
92 * Release GDI object. Every object locked by GDIOBJ_LockObj() must be unlocked.
93 * You should unlock the object
94 * as soon as you don't need to have access to it's data.
95
96 * \param Object Object pointer (as returned by GDIOBJ_LockObj).
97 */
98 ULONG
99 FORCEINLINE
100 GDIOBJ_UnlockObjByPtr(POBJ Object)
101 {
102 INT cLocks = InterlockedDecrement((PLONG)&Object->cExclusiveLock);
103 ASSERT(cLocks >= 0);
104 return cLocks;
105 }
106
107 ULONG
108 FORCEINLINE
109 GDIOBJ_ShareUnlockObjByPtr(POBJ Object)
110 {
111 HGDIOBJ hobj = Object->hHmgr;
112 USHORT flags = Object->BaseFlags;
113 INT cLocks = InterlockedDecrement((PLONG)&Object->ulShareCount);
114 ASSERT(cLocks >= 0);
115 if ((flags & BASEFLAG_READY_TO_DIE) && (cLocks == 0))
116 {
117 GDIOBJ_FreeObjByHandle(hobj, GDI_OBJECT_TYPE_DONTCARE);
118 }
119 return cLocks;
120 }
121
122 #ifdef GDI_DEBUG
123 ULONG FASTCALL GDIOBJ_IncrementShareCount(POBJ Object);
124 #else
125 ULONG
126 FORCEINLINE
127 GDIOBJ_IncrementShareCount(POBJ Object)
128 {
129 INT cLocks = InterlockedIncrement((PLONG)&Object->ulShareCount);
130 ASSERT(cLocks >= 1);
131 return cLocks;
132 }
133 #endif
134
135 INT FASTCALL GreGetObjectOwner(HGDIOBJ, GDIOBJTYPE);