a9ea3dda01b2621387afb4b98346c6c2138b9231
[reactos.git] / reactos / subsystems / win32 / win32k / include / object.h
1 #pragma once
2
3 typedef struct _USER_REFERENCE_ENTRY
4 {
5 SINGLE_LIST_ENTRY Entry;
6 PVOID obj;
7 } USER_REFERENCE_ENTRY, *PUSER_REFERENCE_ENTRY;
8
9 #define USER_ASSERT(exp,file,line) \
10 if (!(exp)) {RtlAssert(#exp,(PVOID)file,line,"");}
11
12 static __inline VOID
13 UserAssertLastRef(PVOID obj, const char *file, int line)
14 {
15 PTHREADINFO W32Thread;
16 PSINGLE_LIST_ENTRY ReferenceEntry;
17 PUSER_REFERENCE_ENTRY UserReferenceEntry;
18
19 USER_ASSERT(obj != NULL, file, line);
20 W32Thread = PsGetCurrentThreadWin32Thread();
21 USER_ASSERT(W32Thread != NULL, file, line);
22 ReferenceEntry = W32Thread->ReferencesList.Next;
23 USER_ASSERT(ReferenceEntry != NULL, file, line);
24 UserReferenceEntry = CONTAINING_RECORD(ReferenceEntry, USER_REFERENCE_ENTRY, Entry);
25 USER_ASSERT(UserReferenceEntry != NULL, file, line);
26 USER_ASSERT(obj == UserReferenceEntry->obj, file, line);
27 }
28 #define ASSERT_LAST_REF(_obj_) UserAssertLastRef(_obj,__FILE__,__LINE__)
29
30 #undef USER_ASSERT
31
32 extern PUSER_HANDLE_TABLE gHandleTable;
33 VOID FASTCALL UserReferenceObject(PVOID obj);
34 PVOID FASTCALL UserReferenceObjectByHandle(HANDLE handle, USER_OBJECT_TYPE type);
35 BOOL FASTCALL UserDereferenceObject(PVOID obj);
36 PVOID FASTCALL UserCreateObject(PUSER_HANDLE_TABLE ht, struct _DESKTOP* pDesktop, HANDLE* h,USER_OBJECT_TYPE type , ULONG size);
37 BOOL FASTCALL UserDeleteObject(HANDLE h, USER_OBJECT_TYPE type );
38 PVOID UserGetObject(PUSER_HANDLE_TABLE ht, HANDLE handle, USER_OBJECT_TYPE type );
39 BOOL FASTCALL UserCreateHandleTable(VOID);
40
41 static __inline VOID
42 UserRefObjectCo(PVOID obj, PUSER_REFERENCE_ENTRY UserReferenceEntry)
43 {
44 PTHREADINFO W32Thread;
45
46 W32Thread = PsGetCurrentThreadWin32Thread();
47 ASSERT(W32Thread != NULL);
48 ASSERT(UserReferenceEntry != NULL);
49 UserReferenceEntry->obj = obj;
50 UserReferenceObject(obj);
51 PushEntryList(&W32Thread->ReferencesList, &UserReferenceEntry->Entry);
52 }
53
54 static __inline VOID
55 UserDerefObjectCo(PVOID obj)
56 {
57 PTHREADINFO W32Thread;
58 PSINGLE_LIST_ENTRY ReferenceEntry;
59 PUSER_REFERENCE_ENTRY UserReferenceEntry;
60
61 ASSERT(obj != NULL);
62 W32Thread = PsGetCurrentThreadWin32Thread();
63 ASSERT(W32Thread != NULL);
64 ReferenceEntry = PopEntryList(&W32Thread->ReferencesList);
65 ASSERT(ReferenceEntry != NULL);
66 UserReferenceEntry = CONTAINING_RECORD(ReferenceEntry, USER_REFERENCE_ENTRY, Entry);
67 ASSERT(UserReferenceEntry != NULL);
68
69 ASSERT(obj == UserReferenceEntry->obj);
70 UserDereferenceObject(obj);
71 }
72
73 /* EOF */