6
0
mirror of https://github.com/JKornev/hidden synced 2024-06-27 09:28:04 +00:00
hidden/Hidden/DeviceAPI.h
JKornev 80b89c2f28 Added Get\Set process exclude\protect state
Fixed issue with the hidden.inf
and etc
2016-09-04 20:19:17 +03:00

100 lines
3.5 KiB
C

#pragma once
// ========================================
// Device information
#define DEVICE_NAME L"\\Device\\HiddenGate"
#define DOS_DEVICES_LINK_NAME L"\\DosDevices\\HiddenGate"
#define DEVICE_WIN32_NAME L"\\\\.\\HiddenGate"
// ========================================
// IOCTL codes
#define HID_IOCTL_SET_DRIVER_STATE CTL_CODE (FILE_DEVICE_UNKNOWN, (0x800 + 0), METHOD_BUFFERED, FILE_SPECIAL_ACCESS)
#define HID_IOCTL_GET_DRIVER_STATE CTL_CODE (FILE_DEVICE_UNKNOWN, (0x800 + 1), METHOD_BUFFERED, FILE_SPECIAL_ACCESS)
#define HID_IOCTL_SET_STEALTH_MODE CTL_CODE (FILE_DEVICE_UNKNOWN, (0x800 + 2), METHOD_BUFFERED, FILE_SPECIAL_ACCESS)
#define HID_IOCTL_ADD_HIDDEN_OBJECT CTL_CODE (FILE_DEVICE_UNKNOWN, (0x800 + 60), METHOD_BUFFERED, FILE_SPECIAL_ACCESS)
#define HID_IOCTL_REMOVE_HIDDEN_OBJECT CTL_CODE (FILE_DEVICE_UNKNOWN, (0x800 + 61), METHOD_BUFFERED, FILE_SPECIAL_ACCESS)
#define HID_IOCTL_REMOVE_ALL_HIDDEN_OBJECTS CTL_CODE (FILE_DEVICE_UNKNOWN, (0x800 + 62), METHOD_BUFFERED, FILE_SPECIAL_ACCESS)
#define HID_IOCTL_ADD_OBJECT CTL_CODE (FILE_DEVICE_UNKNOWN, (0x800 + 70), METHOD_BUFFERED, FILE_SPECIAL_ACCESS)
#define HID_IOCTL_GET_OBJECT_STATE CTL_CODE (FILE_DEVICE_UNKNOWN, (0x800 + 71), METHOD_BUFFERED, FILE_SPECIAL_ACCESS)
#define HID_IOCTL_SET_OBJECT_STATE CTL_CODE (FILE_DEVICE_UNKNOWN, (0x800 + 72), METHOD_BUFFERED, FILE_SPECIAL_ACCESS)
#define HID_IOCTL_REMOVE_OBJECT CTL_CODE (FILE_DEVICE_UNKNOWN, (0x800 + 73), METHOD_BUFFERED, FILE_SPECIAL_ACCESS)
#define HID_IOCTL_REMOVE_ALL_OBJECTS CTL_CODE (FILE_DEVICE_UNKNOWN, (0x800 + 74), METHOD_BUFFERED, FILE_SPECIAL_ACCESS)
enum Hid_ObjectTypes {
RegKeyObject,
RegValueObject,
FsFileObject,
FsDirObject,
PsExcludedObject,
PsProtectedObject,
};
#pragma pack(push, 4)
// Fs/Reg packets
typedef struct _Hid_HideObjectPacket {
unsigned short objType;
unsigned short dataSize;
} Hid_HideObjectPacket, *PHid_HideObjectPacket;
typedef struct _Hid_UnhideObjectPacket {
unsigned short objType;
unsigned short reserved;
unsigned long long id;
} Hid_UnhideObjectPacket, *PHid_UnhideObjectPacket;
typedef struct _Hid_UnhideAllObjectsPacket {
unsigned short objType;
unsigned short reserved;
} Hid_UnhideAllObjectsPacket, *PHid_UnhideAllObjectsPacket;
// Ps packets
typedef struct _Hid_AddPsObjectPacket {
unsigned short objType;
unsigned short dataSize;
unsigned short inheritType;
unsigned short reserved;
} Hid_AddPsObjectPacket, *PHid_AddPsObjectPacket;
typedef struct _Hid_GetPsObjectInfoPacket {
unsigned short objType;
unsigned short inheritType;
unsigned short enable;
unsigned short reserved;
unsigned long procId;
} Hid_GetPsObjectInfoPacket, *PHid_GetPsObjectInfoPacket;
typedef Hid_GetPsObjectInfoPacket Hid_SetPsObjectInfoPacket;
typedef Hid_GetPsObjectInfoPacket* PHid_SetPsObjectInfoPacket;
typedef struct _Hid_RemovePsObjectPacket {
unsigned short objType;
unsigned short reserved;
unsigned long long id;
} Hid_RemovePsObjectPacket, *PHid_RemovePsObjectPacket;
typedef struct _Hid_RemoveAllPsObjectsPacket {
unsigned short objType;
unsigned short reserved;
} Hid_RemoveAllPsObjectsPacket, *PHid_RemoveAllPsObjectsPacket;
// Result packet
typedef struct _Hid_StatusPacket {
unsigned int status;
unsigned int dataSize;
union {
unsigned long long id;
unsigned long state;
} info;
} Hid_StatusPacket, *PHid_StatusPacket;
#pragma pack(pop)