2006-05-10 17:47:44 +00:00
|
|
|
/*++ NDK Version: 0098
|
2005-11-22 04:57:45 +00:00
|
|
|
|
|
|
|
Copyright (c) Alex Ionescu. All rights reserved.
|
|
|
|
|
|
|
|
Header Name:
|
|
|
|
|
|
|
|
lpctypes.h
|
|
|
|
|
|
|
|
Abstract:
|
|
|
|
|
|
|
|
Type definitions for the Loader.
|
|
|
|
|
|
|
|
Author:
|
|
|
|
|
2006-05-10 17:47:44 +00:00
|
|
|
Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006
|
2005-11-22 04:57:45 +00:00
|
|
|
|
|
|
|
--*/
|
|
|
|
|
2005-06-18 23:33:40 +00:00
|
|
|
#ifndef _LPCTYPES_H
|
|
|
|
#define _LPCTYPES_H
|
|
|
|
|
2005-11-22 04:57:45 +00:00
|
|
|
//
|
|
|
|
// Dependencies
|
|
|
|
//
|
2005-11-25 00:17:40 +00:00
|
|
|
#include <umtypes.h>
|
2007-04-07 05:33:30 +00:00
|
|
|
//#include <pstypes.h>
|
2005-06-18 23:33:40 +00:00
|
|
|
|
2005-11-27 18:24:32 +00:00
|
|
|
//
|
|
|
|
// Internal helper macro
|
|
|
|
//
|
|
|
|
#define N_ROUND_UP(x,s) \
|
|
|
|
(((ULONG)(x)+(s)-1) & ~((ULONG)(s)-1))
|
|
|
|
|
2005-11-26 22:51:59 +00:00
|
|
|
//
|
|
|
|
// Port Object Access Masks
|
|
|
|
//
|
2006-10-30 14:17:37 +00:00
|
|
|
#define PORT_CONNECT 0x1
|
2005-11-26 22:51:59 +00:00
|
|
|
#define PORT_ALL_ACCESS 0x1
|
|
|
|
|
2006-10-30 14:17:37 +00:00
|
|
|
//
|
|
|
|
// Port Object Flags
|
|
|
|
//
|
|
|
|
#define LPCP_CONNECTION_PORT 0x00000001
|
|
|
|
#define LPCP_UNCONNECTED_PORT 0x00000002
|
|
|
|
#define LPCP_COMMUNICATION_PORT 0x00000003
|
|
|
|
#define LPCP_CLIENT_PORT 0x00000004
|
|
|
|
#define LPCP_PORT_TYPE_MASK 0x0000000F
|
|
|
|
#define LPCP_PORT_DELETED 0x10000000
|
|
|
|
#define LPCP_WAITABLE_PORT 0x20000000
|
|
|
|
#define LPCP_NAME_DELETED 0x40000000
|
|
|
|
#define LPCP_SECURITY_DYNAMIC 0x80000000
|
|
|
|
|
2005-11-22 04:57:45 +00:00
|
|
|
//
|
|
|
|
// LPC Message Types
|
|
|
|
//
|
2005-06-26 01:08:55 +00:00
|
|
|
typedef enum _LPC_TYPE
|
2005-06-18 23:33:40 +00:00
|
|
|
{
|
|
|
|
LPC_NEW_MESSAGE,
|
|
|
|
LPC_REQUEST,
|
|
|
|
LPC_REPLY,
|
|
|
|
LPC_DATAGRAM,
|
|
|
|
LPC_LOST_REPLY,
|
|
|
|
LPC_PORT_CLOSED,
|
|
|
|
LPC_CLIENT_DIED,
|
|
|
|
LPC_EXCEPTION,
|
|
|
|
LPC_DEBUG_EVENT,
|
|
|
|
LPC_ERROR_EVENT,
|
|
|
|
LPC_CONNECTION_REQUEST,
|
|
|
|
LPC_CONNECTION_REFUSED,
|
|
|
|
LPC_MAXIMUM
|
|
|
|
} LPC_TYPE;
|
|
|
|
|
2005-11-22 04:57:45 +00:00
|
|
|
//
|
|
|
|
// Information Classes for NtQueryInformationPort
|
|
|
|
//
|
2005-09-06 15:57:42 +00:00
|
|
|
typedef enum _PORT_INFORMATION_CLASS
|
|
|
|
{
|
|
|
|
PortNoInformation
|
|
|
|
} PORT_INFORMATION_CLASS;
|
|
|
|
|
2005-08-17 07:06:59 +00:00
|
|
|
#ifdef NTOS_MODE_USER
|
2005-08-16 23:05:33 +00:00
|
|
|
|
2009-10-14 17:03:41 +00:00
|
|
|
//
|
|
|
|
// Maximum message size that can be sent through an LPC Port without a section
|
|
|
|
//
|
2009-10-14 17:05:51 +00:00
|
|
|
#ifdef _WIN64
|
|
|
|
#define PORT_MAXIMUM_MESSAGE_LENGTH 512
|
|
|
|
#else
|
|
|
|
#define PORT_MAXIMUM_MESSAGE_LENGTH 256
|
|
|
|
#endif
|
2009-10-14 17:03:41 +00:00
|
|
|
|
2005-11-22 04:57:45 +00:00
|
|
|
//
|
|
|
|
// Portable LPC Types for 32/64-bit compatibility
|
|
|
|
//
|
|
|
|
#ifdef USE_LPC6432
|
2005-08-11 02:58:54 +00:00
|
|
|
#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
|
|
|
|
|
2005-11-22 04:57:45 +00:00
|
|
|
//
|
|
|
|
// LPC Port Message
|
|
|
|
//
|
2005-08-11 02:58:54 +00:00
|
|
|
typedef struct _PORT_MESSAGE
|
2005-06-26 01:08:55 +00:00
|
|
|
{
|
2005-08-11 02:58:54 +00:00
|
|
|
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;
|
2005-06-18 23:33:40 +00:00
|
|
|
|
2005-11-22 04:57:45 +00:00
|
|
|
//
|
|
|
|
// Local and Remove Port Views
|
|
|
|
//
|
2005-08-11 03:23:44 +00:00
|
|
|
typedef struct _PORT_VIEW
|
2005-06-18 23:33:40 +00:00
|
|
|
{
|
2005-08-11 03:23:44 +00:00
|
|
|
ULONG Length;
|
|
|
|
LPC_HANDLE SectionHandle;
|
|
|
|
ULONG SectionOffset;
|
|
|
|
LPC_SIZE_T ViewSize;
|
|
|
|
LPC_PVOID ViewBase;
|
|
|
|
LPC_PVOID ViewRemoteBase;
|
|
|
|
} PORT_VIEW, *PPORT_VIEW;
|
2005-06-18 23:33:40 +00:00
|
|
|
|
2005-08-11 03:23:44 +00:00
|
|
|
typedef struct _REMOTE_PORT_VIEW
|
2005-06-18 23:33:40 +00:00
|
|
|
{
|
2005-08-11 03:23:44 +00:00
|
|
|
ULONG Length;
|
|
|
|
LPC_SIZE_T ViewSize;
|
|
|
|
LPC_PVOID ViewBase;
|
|
|
|
} REMOTE_PORT_VIEW, *PREMOTE_PORT_VIEW;
|
2005-06-18 23:33:40 +00:00
|
|
|
|
2005-11-22 04:57:45 +00:00
|
|
|
//
|
|
|
|
// LPC Kernel-Mode Message Structures defined for size only
|
|
|
|
//
|
2005-08-16 23:05:33 +00:00
|
|
|
typedef struct _LPCP_MESSAGE
|
|
|
|
{
|
|
|
|
UCHAR Data[0x14];
|
|
|
|
PORT_MESSAGE Request;
|
|
|
|
} LPCP_MESSAGE;
|
|
|
|
|
|
|
|
typedef struct _LPCP_CONNECTION_MESSAGE
|
|
|
|
{
|
|
|
|
UCHAR Data[0x2C];
|
|
|
|
} LPCP_CONNECTION_MESSAGE;
|
|
|
|
|
|
|
|
#else
|
|
|
|
|
2005-11-22 04:57:45 +00:00
|
|
|
//
|
|
|
|
// LPC Paged and Non-Paged Port Queues
|
|
|
|
//
|
2005-08-16 23:05:33 +00:00
|
|
|
typedef struct _LPCP_NONPAGED_PORT_QUEUE
|
|
|
|
{
|
|
|
|
KSEMAPHORE Semaphore;
|
|
|
|
struct _LPCP_PORT_OBJECT *BackPointer;
|
|
|
|
} LPCP_NONPAGED_PORT_QUEUE, *PLPCP_NONPAGED_PORT_QUEUE;
|
|
|
|
|
|
|
|
typedef struct _LPCP_PORT_QUEUE
|
|
|
|
{
|
|
|
|
PLPCP_NONPAGED_PORT_QUEUE NonPagedPortQueue;
|
2006-10-30 14:17:37 +00:00
|
|
|
PKSEMAPHORE Semaphore;
|
2005-08-16 23:05:33 +00:00
|
|
|
LIST_ENTRY ReceiveHead;
|
|
|
|
} LPCP_PORT_QUEUE, *PLPCP_PORT_QUEUE;
|
|
|
|
|
2005-11-22 04:57:45 +00:00
|
|
|
//
|
|
|
|
// LPC Port Object
|
|
|
|
//
|
2005-08-16 23:05:33 +00:00
|
|
|
typedef struct _LPCP_PORT_OBJECT
|
|
|
|
{
|
|
|
|
struct _LPCP_PORT_OBJECT *ConnectionPort;
|
|
|
|
struct _LPCP_PORT_OBJECT *ConnectedPort;
|
|
|
|
LPCP_PORT_QUEUE MsgQueue;
|
|
|
|
CLIENT_ID Creator;
|
|
|
|
PVOID ClientSectionBase;
|
|
|
|
PVOID ServerSectionBase;
|
|
|
|
PVOID PortContext;
|
|
|
|
PETHREAD ClientThread;
|
|
|
|
SECURITY_QUALITY_OF_SERVICE SecurityQos;
|
|
|
|
SECURITY_CLIENT_CONTEXT StaticSecurity;
|
|
|
|
LIST_ENTRY LpcReplyChainHead;
|
|
|
|
LIST_ENTRY LpcDataInfoChainHead;
|
2006-10-30 14:17:37 +00:00
|
|
|
PEPROCESS ServerProcess;
|
|
|
|
PEPROCESS MappingProcess;
|
|
|
|
ULONG MaxMessageLength;
|
|
|
|
ULONG MaxConnectionInfoLength;
|
|
|
|
ULONG Flags;
|
|
|
|
KEVENT WaitEvent;
|
2005-08-16 23:05:33 +00:00
|
|
|
} LPCP_PORT_OBJECT, *PLPCP_PORT_OBJECT;
|
|
|
|
|
2005-11-22 04:57:45 +00:00
|
|
|
//
|
|
|
|
// LPC Kernel-Mode Message Structures
|
|
|
|
//
|
2005-08-16 23:05:33 +00:00
|
|
|
typedef struct _LPCP_MESSAGE
|
2005-06-18 23:33:40 +00:00
|
|
|
{
|
2005-08-16 23:05:33 +00:00
|
|
|
union
|
|
|
|
{
|
|
|
|
LIST_ENTRY Entry;
|
|
|
|
struct
|
|
|
|
{
|
|
|
|
SINGLE_LIST_ENTRY FreeEntry;
|
|
|
|
ULONG Reserved0;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
PLPCP_PORT_OBJECT SenderPort;
|
|
|
|
PETHREAD RepliedToThread;
|
|
|
|
PVOID PortContext;
|
|
|
|
PORT_MESSAGE Request;
|
|
|
|
} LPCP_MESSAGE, *PLPCP_MESSAGE;
|
|
|
|
|
|
|
|
typedef struct _LPCP_CONNECTION_MESSAGE
|
|
|
|
{
|
|
|
|
PORT_VIEW ClientView;
|
|
|
|
PLPCP_PORT_OBJECT ClientPort;
|
|
|
|
PVOID SectionToMap;
|
|
|
|
REMOTE_PORT_VIEW ServerView;
|
|
|
|
} LPCP_CONNECTION_MESSAGE, *PLPCP_CONNECTION_MESSAGE;
|
2005-11-22 04:57:45 +00:00
|
|
|
|
2005-08-16 23:05:33 +00:00
|
|
|
#endif
|
|
|
|
|
2005-11-22 04:57:45 +00:00
|
|
|
//
|
2006-05-10 17:47:44 +00:00
|
|
|
// Client Died LPC Message
|
2005-11-22 04:57:45 +00:00
|
|
|
//
|
2005-09-04 18:00:59 +00:00
|
|
|
typedef struct _CLIENT_DIED_MSG
|
|
|
|
{
|
|
|
|
PORT_MESSAGE h;
|
|
|
|
LARGE_INTEGER CreateTime;
|
|
|
|
} CLIENT_DIED_MSG, *PCLIENT_DIED_MSG;
|
|
|
|
|
2005-11-22 04:57:45 +00:00
|
|
|
//
|
|
|
|
// Maximum total Kernel-Mode LPC Message Structure Size
|
|
|
|
//
|
2005-08-16 23:05:33 +00:00
|
|
|
#define LPCP_MAX_MESSAGE_SIZE \
|
2005-11-27 18:24:32 +00:00
|
|
|
N_ROUND_UP(PORT_MAXIMUM_MESSAGE_LENGTH + \
|
2005-08-16 23:05:33 +00:00
|
|
|
sizeof(LPCP_MESSAGE) + \
|
2005-11-27 18:24:32 +00:00
|
|
|
sizeof(LPCP_CONNECTION_MESSAGE), 16)
|
2005-08-16 23:05:33 +00:00
|
|
|
|
2005-11-22 04:57:45 +00:00
|
|
|
//
|
|
|
|
// Maximum actual LPC Message Length
|
|
|
|
//
|
2005-08-16 23:05:33 +00:00
|
|
|
#define LPC_MAX_MESSAGE_LENGTH \
|
|
|
|
(LPCP_MAX_MESSAGE_SIZE - \
|
|
|
|
FIELD_OFFSET(LPCP_MESSAGE, Request))
|
|
|
|
|
2005-11-22 04:57:45 +00:00
|
|
|
//
|
|
|
|
// Maximum actual size of LPC Message Data
|
|
|
|
//
|
2005-08-16 23:05:33 +00:00
|
|
|
#define LPC_MAX_DATA_LENGTH \
|
|
|
|
(LPC_MAX_MESSAGE_LENGTH - \
|
|
|
|
sizeof(PORT_MESSAGE) - \
|
|
|
|
sizeof(LPCP_CONNECTION_MESSAGE))
|
2005-06-18 23:33:40 +00:00
|
|
|
|
2005-11-22 04:57:45 +00:00
|
|
|
#endif // _LPCTYPES_H
|