16 #define CheckObject(Handle, Pointers, Handles) do \ 18 PUBLIC_OBJECT_BASIC_INFORMATION ObjectInfo; \ 19 Status = ZwQueryObject(Handle, ObjectBasicInformation, \ 20 &ObjectInfo, sizeof ObjectInfo, NULL); \ 21 ok_eq_hex(Status, STATUS_SUCCESS); \ 22 ok_eq_ulong(ObjectInfo.PointerCount, Pointers); \ 23 ok_eq_ulong(ObjectInfo.HandleCount, Handles); \ 69 DPRINT(
"DumpProc() called\n");
83 DPRINT(
"OpenProc() 0x%p, OpenReason %d, HandleCount %lu, AccessMask 0x%lX\n",
99 DPRINT(
"CloseProc() 0x%p, ProcessHandleCount %lu, SystemHandleCount %lu, AccessMask 0x%lX\n",
129 DPRINT(
"ParseProc() called\n");
145 DPRINT(
"OkayToCloseProc() 0x%p, Handle 0x%p, AccessMask 0x%lX\n",
162 DPRINT(
"QueryNameProc() 0x%p, HasObjectName %d, Len %lu, AccessMask 0x%lX\n",
166 ObjectNameInfo =
NULL;
179 WCHAR DirectoryName[
sizeof "\\ObjectTypes\\" - 1];
225 ok(ObjectTypeHandle !=
NULL,
"ObjectTypeHandle = NULL\n");
262 #define CheckCounts(OpenCount, CloseCount, DeleteCount, ParseCount, \ 263 OkayToCloseCount, QueryNameCount) do \ 265 ok_eq_uint(Counts.Open, OpenCount); \ 266 ok_eq_uint(Counts.Close, CloseCount); \ 267 ok_eq_uint(Counts.Delete, DeleteCount); \ 268 ok_eq_uint(Counts.Parse, ParseCount); \ 269 ok_eq_uint(Counts.OkayToClose, OkayToCloseCount); \ 270 ok_eq_uint(Counts.QueryName, QueryNameCount); \ 273 #define SaveCounts(Save) memcpy(&Save, &Counts, sizeof Counts) 276 #define NUM_OBTYPES2 2 359 if (
skip(Clean,
"Not cleaning up, as requested. Use ObTypeClean to clean up\n"))
381 if (!AlternativeMethod)
405 DPRINT(
"Reference Name %wZ = %p, ObTypes[%d] = %p\n",
421 DPRINT(
"ObtCreateObjectTypes() done\n");
424 DPRINT(
"ObtCreateDirectory() done\n");
428 DPRINT(
"ObtCreateObjects() done\n");
NTSTATUS NTAPI ObOpenObjectByName(IN POBJECT_ATTRIBUTES ObjectAttributes, IN POBJECT_TYPE ObjectType, IN KPROCESSOR_MODE AccessMode, IN PACCESS_STATE PassedAccessState, IN ACCESS_MASK DesiredAccess, IN OUT PVOID ParseContext, OUT PHANDLE Handle)
struct _MY_OBJECT2 MY_OBJECT2
#define STATUS_OBJECT_NAME_COLLISION
static VOID ObtCreateDirectory(VOID)
OB_DUMP_METHOD DumpProcedure
IN PUNICODE_STRING IN POBJECT_ATTRIBUTES ObjectAttributes
IN CINT OUT PVOID IN ULONG OUT PULONG ReturnLength
NTSTATUS NTAPI ObCreateObjectType(IN PUNICODE_STRING TypeName, IN POBJECT_TYPE_INITIALIZER ObjectTypeInitializer, IN PVOID Reserved, OUT POBJECT_TYPE *ObjectType)
static VOID ObtCreateObjects(VOID)
struct _MY_OBJECT1 * PMY_OBJECT1
#define CheckCounts(OpenCount, CloseCount, DeleteCount, ParseCount, OkayToCloseCount, QueryNameCount)
_In_ ULONG _In_ ULONG _In_ ULONG Length
static NTSTATUS NTAPI QueryNameProc(IN PVOID Object, IN BOOLEAN HasObjectName, OUT POBJECT_NAME_INFORMATION ObjectNameInfo, IN ULONG Length, OUT PULONG ReturnLength, IN KPROCESSOR_MODE AccessMode)
static VOID NTAPI CloseProc(IN PEPROCESS Process, IN PVOID Object, IN ACCESS_MASK GrantedAccess, IN ULONG ProcessHandleCount, IN ULONG SystemHandleCount)
#define OBJ_CASE_INSENSITIVE
OB_OKAYTOCLOSE_METHOD OkayToCloseProcedure
static UNICODE_STRING ObDirectoryName
#define STATUS_INVALID_PARAMETER
NTSYSAPI NTSTATUS NTAPI ZwClose(_In_ HANDLE Handle)
static NTSTATUS NTAPI ParseProc(IN PVOID ParseObject, IN PVOID ObjectType, IN OUT PACCESS_STATE AccessState, IN KPROCESSOR_MODE AccessMode, IN ULONG Attributes, IN OUT PUNICODE_STRING CompleteName, IN OUT PUNICODE_STRING RemainingName, IN OUT PVOID Context OPTIONAL, IN PSECURITY_QUALITY_OF_SERVICE SecurityQos OPTIONAL, OUT PVOID *Object)
static HANDLE DirectoryHandle
static OBJECT_TYPE_INITIALIZER ObTypeInitializer[NUM_OBTYPES]
static VOID ObtClose(BOOLEAN Clean, BOOLEAN AlternativeMethod)
static OBJECT_ATTRIBUTES ObDirectoryAttributes
#define OBJ_KERNEL_HANDLE
struct _MY_OBJECT2 * PMY_OBJECT2
static HANDLE ObHandle1[NUM_OBTYPES]
static PVOID ObBody[NUM_OBTYPES]
static UNICODE_STRING ObTypeName[NUM_OBTYPES]
NTSTATUS NTAPI ObReferenceObjectByHandle(IN HANDLE Handle, IN ACCESS_MASK DesiredAccess, IN POBJECT_TYPE ObjectType, IN KPROCESSOR_MODE AccessMode, OUT PVOID *Object, OUT POBJECT_HANDLE_INFORMATION HandleInformation OPTIONAL)
NTSTATUS(* NTAPI)(IN PFILE_FULL_EA_INFORMATION EaBuffer, IN ULONG EaLength, OUT PULONG ErrorOffset)
static UNICODE_STRING ObName[NUM_OBTYPES]
BOOLEAN MaintainHandleCount
_In_ PEPROCESS _In_ KPROCESSOR_MODE AccessMode
NTSYSAPI NTSTATUS NTAPI ZwCreateDirectoryObject(_Out_ PHANDLE DirectoryHandle, _In_ ACCESS_MASK DesiredAccess, _In_ POBJECT_ATTRIBUTES ObjectAttributes)
OB_CLOSE_METHOD CloseProcedure
NTSTATUS NTAPI ObCreateObject(IN KPROCESSOR_MODE ProbeMode OPTIONAL, IN POBJECT_TYPE Type, IN POBJECT_ATTRIBUTES ObjectAttributes OPTIONAL, IN KPROCESSOR_MODE AccessMode, IN OUT PVOID ParseContext OPTIONAL, IN ULONG ObjectSize, IN ULONG PagedPoolCharge OPTIONAL, IN ULONG NonPagedPoolCharge OPTIONAL, OUT PVOID *Object)
#define NT_SUCCESS(StatCode)
NTSTRSAFEVAPI RtlStringCbPrintfW(_Out_writes_bytes_(cbDest) _Always_(_Post_z_) NTSTRSAFE_PWSTR pszDest, _In_ size_t cbDest, _In_ _Printf_format_string_ NTSTRSAFE_PCWSTR pszFormat,...)
#define ObDereferenceObject
OB_PARSE_METHOD ParseProcedure
#define CheckObject(Handle, Pointers, Handles)
_In_opt_ PVOID _In_opt_ PUNICODE_STRING _In_ PSECURITY_DESCRIPTOR _In_ PACCESS_STATE AccessState
static NTSTATUS NTAPI OpenProc(IN OB_OPEN_REASON OpenReason, IN PEPROCESS Process, IN PVOID Object, IN ACCESS_MASK GrantedAccess, IN ULONG HandleCount)
OB_OPEN_METHOD OpenProcedure
static VOID TestObjectType(IN BOOLEAN Clean)
OBJECT_TYPE_INITIALIZER TypeInfo
#define OBJECT_TYPE_ALL_ACCESS
_Must_inspect_result_ _In_ WDFCOLLECTION _In_ WDFOBJECT Object
enum _OB_OPEN_REASON OB_OPEN_REASON
#define ok_eq_longptr(value, expected)
static OBJECT_ATTRIBUTES ObAttributes[NUM_OBTYPES]
NTSTATUS NTAPI ObInsertObject(IN PVOID Object, IN PACCESS_STATE AccessState OPTIONAL, IN ACCESS_MASK DesiredAccess, IN ULONG ObjectPointerBias, OUT PVOID *NewObject OPTIONAL, OUT PHANDLE Handle)
#define STATUS_OBJECT_NAME_NOT_FOUND
#define STANDARD_RIGHTS_ALL
GLsizei GLenum const GLvoid GLsizei GLenum GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLint GLint GLint GLshort GLshort GLshort GLubyte GLubyte GLubyte GLuint GLuint GLuint GLushort GLushort GLushort GLbyte GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLfloat GLint GLint GLint GLint GLshort GLshort GLshort GLshort GLubyte GLubyte GLubyte GLubyte GLuint GLuint GLuint GLuint GLushort GLushort GLushort GLushort GLboolean const GLdouble const GLfloat const GLint const GLshort const GLbyte const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLdouble const GLfloat const GLfloat const GLint const GLint const GLshort const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort GLenum GLenum GLenum GLfloat GLenum GLint GLenum GLenum GLenum GLfloat GLenum GLenum GLint GLenum GLfloat GLenum GLint GLint GLushort GLenum GLenum GLfloat GLenum GLenum GLint GLfloat const GLubyte GLenum GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLint GLint GLsizei GLsizei GLint GLenum GLenum const GLvoid GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLenum const GLdouble GLenum GLenum const GLfloat GLenum GLenum const GLint GLsizei GLuint GLfloat GLuint GLbitfield GLfloat GLint GLuint GLboolean GLenum GLfloat GLenum GLbitfield GLenum GLfloat GLfloat GLint GLint const GLfloat GLenum GLfloat GLfloat GLint GLint GLfloat GLfloat GLint GLint const GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat const GLdouble const GLfloat const GLdouble const GLfloat GLint i
static VOID NTAPI DeleteProc(IN PVOID Object)
static POBJECT_TYPE ObTypes[NUM_OBTYPES]
_Must_inspect_result_ _In_ PLARGE_INTEGER _In_ PLARGE_INTEGER _In_ ULONG _In_ PFILE_OBJECT _In_ PVOID Process
struct _MY_OBJECT1 MY_OBJECT1
static VOID NTAPI DumpProc(IN PVOID Object, IN POB_DUMP_CONTROL DumpControl)
#define ObReferenceObject
OB_QUERYNAME_METHOD QueryNameProcedure
NTSYSAPI VOID NTAPI RtlInitUnicodeString(PUNICODE_STRING DestinationString, PCWSTR SourceString)
#define RtlZeroMemory(Destination, Length)
#define InitializeObjectAttributes(p, n, a, r, s)
#define RtlCopyMemory(Destination, Source, Length)
#define ok_eq_hex(value, expected)
_In_ PSECURITY_SUBJECT_CONTEXT _In_ BOOLEAN _In_ ACCESS_MASK _In_ ACCESS_MASK _Outptr_opt_ PPRIVILEGE_SET _In_ PGENERIC_MAPPING _In_ KPROCESSOR_MODE _Out_ PACCESS_MASK GrantedAccess
OB_DELETE_METHOD DeleteProcedure
NTSTATUS NTAPI ObReferenceObjectByName(IN PUNICODE_STRING ObjectPath, IN ULONG Attributes, IN PACCESS_STATE PassedAccessState, IN ACCESS_MASK DesiredAccess, IN POBJECT_TYPE ObjectType, IN KPROCESSOR_MODE AccessMode, IN OUT PVOID ParseContext, OUT PVOID *ObjectPtr)
NTSYSAPI NTSTATUS NTAPI ZwMakeTemporaryObject(_In_ HANDLE Handle)
static VOID ObtCreateObjectTypes(VOID)
static BOOLEAN NTAPI OkayToCloseProc(IN PEPROCESS Process OPTIONAL, IN PVOID Object, IN HANDLE Handle, IN KPROCESSOR_MODE AccessMode)
_Must_inspect_result_ _In_ WDFDMAENABLER _In_ _In_opt_ PWDF_OBJECT_ATTRIBUTES Attributes
_Inout_ PFCB _Inout_ PUNICODE_STRING RemainingName
PULONG MinorVersion OPTIONAL