mirror of
https://github.com/JKornev/hidden
synced 2024-06-28 09:52:05 +00:00
105 lines
3.6 KiB
C
105 lines
3.6 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_DriverStatusPacket {
|
|
unsigned short state;
|
|
unsigned short reserved;
|
|
} Hid_DriverStatus, *PHid_DriverStatus;
|
|
|
|
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 applyForProcesses;
|
|
} 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)
|