一些内核操作函数

#ifdef __cplusplus
extern "C" {
#endif

#define DELAY_ONE_MICRO (-10)
#define DELAY_ONE_MILLI (DELAY_ONE_MICRO*1000)
#include <ntifs.h>
#include <stdlib.h>
	NTSTATUS DriverEntry(IN PDRIVER_OBJECT  objDriver,IN PUNICODE_STRING strRegPath);

	HANDLE KernelCreateFile(IN PUNICODE_STRING pstrFile,IN BOOLEAN bIsDir);

	ULONG64 KernelGetFileSize(IN HANDLE hFile);

	ULONG64 KernelReadFile(IN HANDLE hFile,IN PLARGE_INTEGER Offset,IN ULONG ulLength,OUT PVOID pBuffer);
	ULONG64 KernelWriteFile(IN HANDLE hFile,IN PLARGE_INTEGER Offset,IN ULONG ulLength,OUT PVOID pBuffer);
	NTSTATUS KernelDeleteFile(IN PUNICODE_STRING pstrFile);

	void KernelKillProcess(UINT32 PiD);

	PEPROCESS LookupProcess(HANDLE hPid);
	NTKERNELAPI HANDLE PsGetProcessInheritedFromUniqueProcessId(IN PEPROCESS pEProcess);
	NTKERNELAPI UCHAR* PsGetProcessImageFileName(IN PEPROCESS pEProcess);
	VOID EnumProcess();

	PFILE_BOTH_DIR_INFORMATION KernelFindFirstFile(IN HANDLE hFile,IN ULONG ulLen,OUT PFILE_BOTH_DIR_INFORMATION pDir);
	NTSTATUS KernelFindNextFile(IN OUT PFILE_BOTH_DIR_INFORMATION* pDir);
	void Traversal();

	NTKERNELAPI NTSTATUS PsSuspendProcess(PEPROCESS pEProcess);
	NTKERNELAPI NTSTATUS PsResumeProcess(PEPROCESS pEProcess);

	UINT32 PauseProcess(PEPROCESS pEProcess);
	UINT32 ResumeProcess(PEPROCESS pEProcess);

	typedef NTSTATUS (__stdcall *PSSUSPENDTHREAD)(IN PETHREAD pEThread,OUT PULONG PreviousSuspendCount);
	typedef NTSTATUS (__stdcall *PSRESUMETHREAD)(IN PETHREAD pEThread,OUT PULONG PreviousCount);
	PSSUSPENDTHREAD PsSuspendThread = (PSSUSPENDTHREAD)0x842de1bb;
	PSRESUMETHREAD PsResumeThread = (PSRESUMETHREAD)0x84235cd6;

	UINT32 PauseThread(PETHREAD pEThread);
	UINT32 ResumeThread(PETHREAD pEThread);

	KEVENT g_kEvent;
	
	VOID t_funThread(IN PVOID StartContext);
	VOID Test_CreateThread();

	typedef NTSTATUS (__fastcall *ZWTERMINATETHREAD)(HANDLE hThread,ULONG uExitCode);
	ZWTERMINATETHREAD ZwTerminateThread = (ZWTERMINATETHREAD)0x8407fad4;
	void KernelKillThread(UINT32 TiD);
	NTSTATUS ZwOpenThread(OUT PHANDLE ThreadHandle,IN ACCESS_MASK DesiredAccess,IN POBJECT_ATTRIBUTES ObjectAttributes,IN PCLIENT_ID ClientId OPTIONAL);
	VOID EnumThread(PEPROCESS pEProcess);

	VOID KernelSleepA(LONG MicroSeconds);
	VOID KernelSleepB(LONG MicroSeconds);

	ULONG KernelGetVersion();

	VOID Test_GetCurrentTime();
#ifdef __cplusplus
}
#endif

HANDLE KernelCreateFile(IN PUNICODE_STRING pstrFile,IN BOOLEAN bIsDir)
{
	HANDLE hFile = NULL;
	NTSTATUS Status = STATUS_UNSUCCESSFUL;
	IO_STATUS_BLOCK StatusBlock = {0};
	ULONG ulShareAccess = FILE_SHARE_READ|FILE_SHARE_WRITE|FILE_SHARE_DELETE;
	ULONG ulCreateOpt = FILE_SYNCHRONOUS_IO_NONALE
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值