mirror of
https://github.com/vxunderground/MalwareSourceCode.git
synced 2025-01-12 13:25:30 +00:00
171 lines
3.9 KiB
C
171 lines
3.9 KiB
C
|
/*
|
||
|
* This file is part of the Process Hacker project - https://processhacker.sourceforge.io/
|
||
|
*
|
||
|
* You can redistribute this file and/or modify it under the terms of the
|
||
|
* Attribution 4.0 International (CC BY 4.0) license.
|
||
|
*
|
||
|
* You must give appropriate credit, provide a link to the license, and
|
||
|
* indicate if changes were made. You may do so in any reasonable manner, but
|
||
|
* not in any way that suggests the licensor endorses you or your use.
|
||
|
*/
|
||
|
|
||
|
#ifndef _NTPNPAPI_H
|
||
|
#define _NTPNPAPI_H
|
||
|
|
||
|
typedef enum _PLUGPLAY_EVENT_CATEGORY
|
||
|
{
|
||
|
HardwareProfileChangeEvent,
|
||
|
TargetDeviceChangeEvent,
|
||
|
DeviceClassChangeEvent,
|
||
|
CustomDeviceEvent,
|
||
|
DeviceInstallEvent,
|
||
|
DeviceArrivalEvent,
|
||
|
PowerEvent,
|
||
|
VetoEvent,
|
||
|
BlockedDriverEvent,
|
||
|
InvalidIDEvent,
|
||
|
MaxPlugEventCategory
|
||
|
} PLUGPLAY_EVENT_CATEGORY, *PPLUGPLAY_EVENT_CATEGORY;
|
||
|
|
||
|
typedef struct _PLUGPLAY_EVENT_BLOCK
|
||
|
{
|
||
|
GUID EventGuid;
|
||
|
PLUGPLAY_EVENT_CATEGORY EventCategory;
|
||
|
PULONG Result;
|
||
|
ULONG Flags;
|
||
|
ULONG TotalSize;
|
||
|
PVOID DeviceObject;
|
||
|
|
||
|
union
|
||
|
{
|
||
|
struct
|
||
|
{
|
||
|
GUID ClassGuid;
|
||
|
WCHAR SymbolicLinkName[1];
|
||
|
} DeviceClass;
|
||
|
struct
|
||
|
{
|
||
|
WCHAR DeviceIds[1];
|
||
|
} TargetDevice;
|
||
|
struct
|
||
|
{
|
||
|
WCHAR DeviceId[1];
|
||
|
} InstallDevice;
|
||
|
struct
|
||
|
{
|
||
|
PVOID NotificationStructure;
|
||
|
WCHAR DeviceIds[1];
|
||
|
} CustomNotification;
|
||
|
struct
|
||
|
{
|
||
|
PVOID Notification;
|
||
|
} ProfileNotification;
|
||
|
struct
|
||
|
{
|
||
|
ULONG NotificationCode;
|
||
|
ULONG NotificationData;
|
||
|
} PowerNotification;
|
||
|
struct
|
||
|
{
|
||
|
PNP_VETO_TYPE VetoType;
|
||
|
WCHAR DeviceIdVetoNameBuffer[1]; // DeviceId<null>VetoName<null><null>
|
||
|
} VetoNotification;
|
||
|
struct
|
||
|
{
|
||
|
GUID BlockedDriverGuid;
|
||
|
} BlockedDriverNotification;
|
||
|
struct
|
||
|
{
|
||
|
WCHAR ParentId[1];
|
||
|
} InvalidIDNotification;
|
||
|
} u;
|
||
|
} PLUGPLAY_EVENT_BLOCK, *PPLUGPLAY_EVENT_BLOCK;
|
||
|
|
||
|
typedef enum _PLUGPLAY_CONTROL_CLASS
|
||
|
{
|
||
|
PlugPlayControlEnumerateDevice,
|
||
|
PlugPlayControlRegisterNewDevice,
|
||
|
PlugPlayControlDeregisterDevice,
|
||
|
PlugPlayControlInitializeDevice,
|
||
|
PlugPlayControlStartDevice,
|
||
|
PlugPlayControlUnlockDevice,
|
||
|
PlugPlayControlQueryAndRemoveDevice,
|
||
|
PlugPlayControlUserResponse,
|
||
|
PlugPlayControlGenerateLegacyDevice,
|
||
|
PlugPlayControlGetInterfaceDeviceList,
|
||
|
PlugPlayControlProperty,
|
||
|
PlugPlayControlDeviceClassAssociation,
|
||
|
PlugPlayControlGetRelatedDevice,
|
||
|
PlugPlayControlGetInterfaceDeviceAlias,
|
||
|
PlugPlayControlDeviceStatus,
|
||
|
PlugPlayControlGetDeviceDepth,
|
||
|
PlugPlayControlQueryDeviceRelations,
|
||
|
PlugPlayControlTargetDeviceRelation,
|
||
|
PlugPlayControlQueryConflictList,
|
||
|
PlugPlayControlRetrieveDock,
|
||
|
PlugPlayControlResetDevice,
|
||
|
PlugPlayControlHaltDevice,
|
||
|
PlugPlayControlGetBlockedDriverList,
|
||
|
PlugPlayControlGetDeviceInterfaceEnabled,
|
||
|
MaxPlugPlayControl
|
||
|
} PLUGPLAY_CONTROL_CLASS, *PPLUGPLAY_CONTROL_CLASS;
|
||
|
|
||
|
#if (PHNT_VERSION < PHNT_WIN8)
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtGetPlugPlayEvent(
|
||
|
_In_ HANDLE EventHandle,
|
||
|
_In_opt_ PVOID Context,
|
||
|
_Out_writes_bytes_(EventBufferSize) PPLUGPLAY_EVENT_BLOCK EventBlock,
|
||
|
_In_ ULONG EventBufferSize
|
||
|
);
|
||
|
#endif
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtPlugPlayControl(
|
||
|
_In_ PLUGPLAY_CONTROL_CLASS PnPControlClass,
|
||
|
_Inout_updates_bytes_(PnPControlDataLength) PVOID PnPControlData,
|
||
|
_In_ ULONG PnPControlDataLength
|
||
|
);
|
||
|
|
||
|
#if (PHNT_VERSION >= PHNT_WIN7)
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtSerializeBoot(
|
||
|
VOID
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtEnableLastKnownGood(
|
||
|
VOID
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtDisableLastKnownGood(
|
||
|
VOID
|
||
|
);
|
||
|
|
||
|
#endif
|
||
|
|
||
|
#if (PHNT_VERSION >= PHNT_VISTA)
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtReplacePartitionUnit(
|
||
|
_In_ PUNICODE_STRING TargetInstancePath,
|
||
|
_In_ PUNICODE_STRING SpareInstancePath,
|
||
|
_In_ ULONG Flags
|
||
|
);
|
||
|
#endif
|
||
|
|
||
|
#endif
|