2006-05-10 17:47:44 +00:00
|
|
|
/*++ NDK Version: 0098
|
2006-05-05 18:13:26 +00:00
|
|
|
|
|
|
|
Copyright (c) Alex Ionescu. All rights reserved.
|
|
|
|
|
|
|
|
Header Name:
|
|
|
|
|
|
|
|
ifssupp.h
|
|
|
|
|
|
|
|
Abstract:
|
|
|
|
|
|
|
|
NDK Support for usage without the IFS. Will be deprecated at WDK Release.
|
|
|
|
|
|
|
|
Author:
|
|
|
|
|
2006-05-10 17:47:44 +00:00
|
|
|
Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006
|
2006-05-05 18:13:26 +00:00
|
|
|
|
|
|
|
--*/
|
|
|
|
#ifndef _NTIFS_
|
|
|
|
#ifndef NTOS_MODE_USER
|
|
|
|
#define _NTIFS_
|
|
|
|
|
|
|
|
#define TOKEN_SOURCE_LENGTH 8
|
|
|
|
|
2010-03-06 00:59:29 +00:00
|
|
|
#ifndef _NTIFS_
|
2006-05-05 18:13:26 +00:00
|
|
|
typedef enum _TOKEN_TYPE
|
|
|
|
{
|
|
|
|
TokenPrimary = 1,
|
|
|
|
TokenImpersonation
|
|
|
|
} TOKEN_TYPE, *PTOKEN_TYPE;
|
|
|
|
|
2010-03-08 21:42:18 +00:00
|
|
|
typedef NTSTATUS
|
|
|
|
(NTAPI * PRTL_HEAP_COMMIT_ROUTINE)(
|
2013-01-13 14:49:21 +00:00
|
|
|
_In_ PVOID Base,
|
|
|
|
_Inout_ PVOID *CommitAddress,
|
|
|
|
_Inout_ PSIZE_T CommitSize
|
2010-03-08 21:42:18 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
typedef struct _RTL_HEAP_PARAMETERS
|
|
|
|
{
|
|
|
|
ULONG Length;
|
|
|
|
SIZE_T SegmentReserve;
|
|
|
|
SIZE_T SegmentCommit;
|
|
|
|
SIZE_T DeCommitFreeBlockThreshold;
|
|
|
|
SIZE_T DeCommitTotalFreeThreshold;
|
|
|
|
SIZE_T MaximumAllocationSize;
|
|
|
|
SIZE_T VirtualMemoryThreshold;
|
|
|
|
SIZE_T InitialCommit;
|
|
|
|
SIZE_T InitialReserve;
|
|
|
|
PRTL_HEAP_COMMIT_ROUTINE CommitRoutine;
|
|
|
|
SIZE_T Reserved[2];
|
|
|
|
} RTL_HEAP_PARAMETERS, *PRTL_HEAP_PARAMETERS;
|
2010-03-06 00:59:29 +00:00
|
|
|
|
2006-07-09 15:25:14 +00:00
|
|
|
typedef PVOID PFS_FILTER_CALLBACKS;
|
2006-05-05 18:13:26 +00:00
|
|
|
typedef USHORT SECURITY_DESCRIPTOR_CONTROL, *PSECURITY_DESCRIPTOR_CONTROL;
|
|
|
|
|
|
|
|
typedef struct _RTL_SPLAY_LINKS
|
|
|
|
{
|
|
|
|
struct _RTL_SPLAY_LINKS *Parent;
|
|
|
|
struct _RTL_SPLAY_LINKS *LeftChild;
|
|
|
|
struct _RTL_SPLAY_LINKS *RightChild;
|
|
|
|
} RTL_SPLAY_LINKS, *PRTL_SPLAY_LINKS;
|
|
|
|
|
2006-10-16 15:27:12 +00:00
|
|
|
typedef struct _RTL_GENERIC_TABLE RTL_GENERIC_TABLE, *PRTL_GENERIC_TABLE;
|
|
|
|
typedef ULONG TABLE_SEARCH_RESULT;
|
|
|
|
|
2006-05-05 18:13:26 +00:00
|
|
|
#if defined(USE_LPC6432)
|
|
|
|
#define LPC_CLIENT_ID CLIENT_ID64
|
|
|
|
#define LPC_SIZE_T ULONGLONG
|
|
|
|
#define LPC_PVOID ULONGLONG
|
|
|
|
#define LPC_HANDLE ULONGLONG
|
|
|
|
#else
|
|
|
|
#define LPC_CLIENT_ID CLIENT_ID
|
|
|
|
#define LPC_SIZE_T SIZE_T
|
|
|
|
#define LPC_PVOID PVOID
|
|
|
|
#define LPC_HANDLE HANDLE
|
|
|
|
#endif
|
|
|
|
|
|
|
|
typedef struct _PORT_MESSAGE
|
|
|
|
{
|
|
|
|
union
|
|
|
|
{
|
|
|
|
struct
|
|
|
|
{
|
|
|
|
CSHORT DataLength;
|
|
|
|
CSHORT TotalLength;
|
|
|
|
} s1;
|
|
|
|
ULONG Length;
|
|
|
|
} u1;
|
|
|
|
union
|
|
|
|
{
|
|
|
|
struct
|
|
|
|
{
|
|
|
|
CSHORT Type;
|
|
|
|
CSHORT DataInfoOffset;
|
|
|
|
} s2;
|
|
|
|
ULONG ZeroInit;
|
|
|
|
} u2;
|
|
|
|
union
|
|
|
|
{
|
|
|
|
LPC_CLIENT_ID ClientId;
|
|
|
|
double DoNotUseThisField;
|
|
|
|
};
|
|
|
|
ULONG MessageId;
|
|
|
|
union
|
|
|
|
{
|
|
|
|
LPC_SIZE_T ClientViewSize;
|
|
|
|
ULONG CallbackId;
|
|
|
|
};
|
|
|
|
} PORT_MESSAGE, *PPORT_MESSAGE;
|
|
|
|
|
|
|
|
typedef struct _PORT_VIEW
|
|
|
|
{
|
|
|
|
ULONG Length;
|
|
|
|
LPC_HANDLE SectionHandle;
|
|
|
|
ULONG SectionOffset;
|
|
|
|
LPC_SIZE_T ViewSize;
|
|
|
|
LPC_PVOID ViewBase;
|
|
|
|
LPC_PVOID ViewRemoteBase;
|
|
|
|
} PORT_VIEW, *PPORT_VIEW;
|
|
|
|
|
|
|
|
typedef struct _REMOTE_PORT_VIEW
|
|
|
|
{
|
|
|
|
ULONG Length;
|
|
|
|
LPC_SIZE_T ViewSize;
|
|
|
|
LPC_PVOID ViewBase;
|
|
|
|
} REMOTE_PORT_VIEW, *PREMOTE_PORT_VIEW;
|
|
|
|
|
|
|
|
typedef struct _KAPC_STATE
|
|
|
|
{
|
|
|
|
LIST_ENTRY ApcListHead[2];
|
|
|
|
struct _KPROCESS *Process;
|
|
|
|
BOOLEAN KernelApcInProgress;
|
|
|
|
BOOLEAN KernelApcPending;
|
|
|
|
BOOLEAN UserApcPending;
|
|
|
|
} KAPC_STATE, *PKAPC_STATE, *RESTRICTED_POINTER PRKAPC_STATE;
|
|
|
|
|
|
|
|
typedef struct _KQUEUE
|
|
|
|
{
|
|
|
|
DISPATCHER_HEADER Header;
|
|
|
|
LIST_ENTRY EntryListHead;
|
|
|
|
ULONG CurrentCount;
|
|
|
|
ULONG MaximumCount;
|
|
|
|
LIST_ENTRY ThreadListHead;
|
|
|
|
} KQUEUE, *PKQUEUE, *RESTRICTED_POINTER PRKQUEUE;
|
|
|
|
|
|
|
|
typedef struct _ACE_HEADER
|
|
|
|
{
|
|
|
|
UCHAR AceType;
|
|
|
|
UCHAR AceFlags;
|
|
|
|
USHORT AceSize;
|
|
|
|
} ACE_HEADER, *PACE_HEADER;
|
|
|
|
|
|
|
|
typedef enum _RTL_GENERIC_COMPARE_RESULTS
|
|
|
|
{
|
|
|
|
GenericLessThan,
|
|
|
|
GenericGreaterThan,
|
|
|
|
GenericEqual
|
|
|
|
} RTL_GENERIC_COMPARE_RESULTS;
|
|
|
|
|
|
|
|
typedef struct _SID_IDENTIFIER_AUTHORITY
|
|
|
|
{
|
|
|
|
UCHAR Value[6];
|
|
|
|
} SID_IDENTIFIER_AUTHORITY, *PSID_IDENTIFIER_AUTHORITY;
|
|
|
|
|
|
|
|
typedef struct _SID_AND_ATTRIBUTES
|
|
|
|
{
|
|
|
|
PSID Sid;
|
|
|
|
ULONG Attributes;
|
|
|
|
} SID_AND_ATTRIBUTES, * PSID_AND_ATTRIBUTES;
|
|
|
|
|
|
|
|
typedef struct _TOKEN_SOURCE
|
|
|
|
{
|
|
|
|
CHAR SourceName[TOKEN_SOURCE_LENGTH];
|
|
|
|
LUID SourceIdentifier;
|
|
|
|
} TOKEN_SOURCE, *PTOKEN_SOURCE;
|
|
|
|
|
|
|
|
typedef struct _TOKEN_CONTROL
|
|
|
|
{
|
|
|
|
LUID TokenId;
|
|
|
|
LUID AuthenticationId;
|
|
|
|
LUID ModifiedId;
|
|
|
|
TOKEN_SOURCE TokenSource;
|
|
|
|
} TOKEN_CONTROL, *PTOKEN_CONTROL;
|
|
|
|
|
|
|
|
typedef struct _SECURITY_CLIENT_CONTEXT
|
|
|
|
{
|
|
|
|
SECURITY_QUALITY_OF_SERVICE SecurityQos;
|
|
|
|
PACCESS_TOKEN ClientToken;
|
|
|
|
BOOLEAN DirectlyAccessClientToken;
|
|
|
|
BOOLEAN DirectAccessEffectiveOnly;
|
|
|
|
BOOLEAN ServerIsRemote;
|
|
|
|
TOKEN_CONTROL ClientTokenControl;
|
|
|
|
} SECURITY_CLIENT_CONTEXT, *PSECURITY_CLIENT_CONTEXT;
|
|
|
|
|
|
|
|
typedef struct _SECURITY_DESCRIPTOR_RELATIVE
|
|
|
|
{
|
|
|
|
UCHAR Revision;
|
|
|
|
UCHAR Sbz1;
|
|
|
|
SECURITY_DESCRIPTOR_CONTROL Control;
|
|
|
|
ULONG Owner;
|
|
|
|
ULONG Group;
|
|
|
|
ULONG Sacl;
|
|
|
|
ULONG Dacl;
|
|
|
|
} SECURITY_DESCRIPTOR_RELATIVE, *PISECURITY_DESCRIPTOR_RELATIVE;
|
|
|
|
|
|
|
|
typedef struct _TOKEN_GROUPS
|
|
|
|
{
|
|
|
|
ULONG GroupCount;
|
|
|
|
SID_AND_ATTRIBUTES Groups[ANYSIZE_ARRAY];
|
|
|
|
} TOKEN_GROUPS, *PTOKEN_GROUPS;
|
|
|
|
|
|
|
|
typedef struct _TOKEN_PRIVILEGES
|
|
|
|
{
|
|
|
|
ULONG PrivilegeCount;
|
|
|
|
LUID_AND_ATTRIBUTES Privileges[ANYSIZE_ARRAY];
|
|
|
|
} TOKEN_PRIVILEGES, *PTOKEN_PRIVILEGES;
|
|
|
|
|
|
|
|
typedef struct _TOKEN_USER
|
|
|
|
{
|
|
|
|
SID_AND_ATTRIBUTES User;
|
|
|
|
} TOKEN_USER, *PTOKEN_USER;
|
|
|
|
|
|
|
|
typedef enum _TOKEN_INFORMATION_CLASS
|
|
|
|
{
|
|
|
|
TokenUser = 1,
|
|
|
|
TokenGroups,
|
|
|
|
TokenPrivileges,
|
|
|
|
TokenOwner,
|
|
|
|
TokenPrimaryGroup,
|
|
|
|
TokenDefaultDacl,
|
|
|
|
TokenSource,
|
|
|
|
TokenType,
|
|
|
|
TokenImpersonationLevel,
|
|
|
|
TokenStatistics,
|
|
|
|
TokenRestrictedSids,
|
|
|
|
TokenSessionId,
|
|
|
|
TokenGroupsAndPrivileges,
|
|
|
|
TokenSessionReference,
|
|
|
|
TokenSandBoxInert,
|
|
|
|
TokenAuditPolicy,
|
|
|
|
TokenOrigin,
|
|
|
|
TokenElevationType,
|
|
|
|
TokenLinkedToken,
|
|
|
|
TokenElevation,
|
|
|
|
TokenIsRestricted,
|
|
|
|
TokenAccessInformation,
|
|
|
|
TokenVirtualization,
|
|
|
|
TokenIntegrityLevel,
|
|
|
|
TokenIntegrityLevelDesktop,
|
|
|
|
TokenMandatoryPolicy,
|
|
|
|
MaxTokenInfoClass
|
|
|
|
} TOKEN_INFORMATION_CLASS, *PTOKEN_INFORMATION_CLASS;
|
|
|
|
|
|
|
|
typedef struct _TOKEN_OWNER
|
|
|
|
{
|
|
|
|
PSID Owner;
|
|
|
|
} TOKEN_OWNER, *PTOKEN_OWNER;
|
|
|
|
|
|
|
|
typedef struct _TOKEN_PRIMARY_GROUP
|
|
|
|
{
|
|
|
|
PSID PrimaryGroup;
|
|
|
|
} TOKEN_PRIMARY_GROUP, *PTOKEN_PRIMARY_GROUP;
|
|
|
|
|
|
|
|
typedef struct _TOKEN_DEFAULT_DACL
|
|
|
|
{
|
|
|
|
PACL DefaultDacl;
|
|
|
|
} TOKEN_DEFAULT_DACL, *PTOKEN_DEFAULT_DACL;
|
|
|
|
|
2008-12-01 15:12:23 +00:00
|
|
|
//
|
|
|
|
// Heap flags
|
|
|
|
//
|
|
|
|
#define HEAP_NO_SERIALIZE 0x00000001
|
|
|
|
#define HEAP_GROWABLE 0x00000002
|
|
|
|
#define HEAP_GENERATE_EXCEPTIONS 0x00000004
|
|
|
|
#define HEAP_ZERO_MEMORY 0x00000008
|
|
|
|
#define HEAP_REALLOC_IN_PLACE_ONLY 0x00000010
|
|
|
|
#define HEAP_TAIL_CHECKING_ENABLED 0x00000020
|
|
|
|
#define HEAP_FREE_CHECKING_ENABLED 0x00000040
|
|
|
|
#define HEAP_DISABLE_COALESCE_ON_FREE 0x00000080
|
|
|
|
|
|
|
|
#define HEAP_CREATE_ALIGN_16 0x00010000
|
|
|
|
#define HEAP_CREATE_ENABLE_TRACING 0x00020000
|
|
|
|
#define HEAP_CREATE_ENABLE_EXECUTE 0x00040000
|
|
|
|
|
2010-03-06 00:59:29 +00:00
|
|
|
#endif
|
|
|
|
|
2006-05-05 18:13:26 +00:00
|
|
|
#endif // !NTOS_MODE_USER
|
|
|
|
#endif // _NTIFS_
|