• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            S.l.e!ep.¢%

            像打了激速一樣,以四倍的速度運轉,開心的工作
            簡單、開放、平等的公司文化;尊重個性、自由與個人價值;
            posts - 1098, comments - 335, trackbacks - 0, articles - 1
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            hook NtTerminateProcess

            Posted on 2009-08-23 17:03 S.l.e!ep.¢% 閱讀(954) 評論(0)  編輯 收藏 引用 所屬分類: Windows WDM

            #include <ntddk.h>

            ULONG g_NtTerminateProcess = 0x8058f695;
            UCHAR g_OrigCode[5];
            UCHAR g_JmpHookCode[5] = {0xe9};

            VOID WpOn()
            {
            ?__asm
            ?{
            ??mov eax,cr0
            ??or eax,10000h
            ??mov cr0,eax
            ??sti
            ?}
            }

            VOID WpOff()
            {
            ?__asm
            ?{
            ??cli
            ??mov eax,cr0
            ??and eax,not 10000h
            ??mov cr0,eax
            ?}
            }

            int NTAPI MyNtTerminateProcess(IN HANDLE ProcessHandle, IN NTSTATUS ExitStatus)
            {
            ?return 1;
            }

            __declspec(naked) NTSTATUS NTAPI HOOK_NtTerminateProcess(IN HANDLE ProcessHandle, IN NTSTATUS ExitStatus)
            {
            ?__asm
            ?{
            ??mov edi,edi
            ??push ebp
            ??mov ebp,esp
            ??push [ebp+0xc]
            ??push [ebp+0x8]
            ?call MyNtTerminateProcess
            ?cmp eax,1
            ??jz end
            ??mov eax,g_NtTerminateProcess
            ??add eax,5
            ??jmp eax
            ??end:
            ??mov [ebp+8],0
            ??mov eax,g_NtTerminateProcess
            ??add eax,5
            ??jmp eax
            ?}
            }

            VOID StartHook()
            {
            ?KIRQL OldIrql;

            ?RtlCopyMemory((PUCHAR)g_OrigCode, (PUCHAR)g_NtTerminateProcess, 5);
            ?*(PULONG)((PUCHAR)g_JmpHookCode + 1) = (ULONG)HOOK_NtTerminateProcess - (ULONG)g_NtTerminateProcess - 5;
            ?WpOff();
            ?OldIrql = KeRaiseIrqlToDpcLevel();
            ?RtlCopyMemory((PUCHAR)g_NtTerminateProcess, g_JmpHookCode, 5);
            ?KeLowerIrql(OldIrql);
            ?WpOn();
            }

            VOID StopHook()
            {
            ?KIRQL OldIrql;

            ?WpOff();
            ?OldIrql = KeRaiseIrqlToDpcLevel();
            ?RtlCopyMemory((PUCHAR)g_NtTerminateProcess, (PUCHAR)g_OrigCode, 5);
            ?KeLowerIrql(OldIrql);
            ?WpOn();
            }

            VOID DriverUnload(IN PDRIVER_OBJECT DriverObject)
            {
            ?StopHook();
            }

            NTSTATUS DriverEntry(IN PDRIVER_OBJECT DriverObject, IN PUNICODE_STRING RegistryPath)
            {
            ?DriverObject->DriverUnload = DriverUnload;
            ?StartHook();
            ?return STATUS_SUCCESS;
            }

            精品久久亚洲中文无码| 久久影视国产亚洲| a高清免费毛片久久| 国产亚洲精午夜久久久久久| 精品水蜜桃久久久久久久| 区亚洲欧美一级久久精品亚洲精品成人网久久久久 | 久久精品中文闷骚内射| 国产福利电影一区二区三区久久久久成人精品综合 | 久久国产精品-国产精品| 久久男人AV资源网站| 久久99国产综合精品免费| 精品久久久久久国产牛牛app| 国产香蕉久久精品综合网| 成人午夜精品久久久久久久小说| 波多野结衣久久精品| 久久精品国产亚洲网站| 亚洲中文字幕无码久久综合网| 国产免费久久精品丫丫| 精品久久8x国产免费观看| 2021国内精品久久久久久影院| 国产精品伊人久久伊人电影| 久久久无码精品亚洲日韩蜜臀浪潮 | 激情伊人五月天久久综合| 久久久久国产亚洲AV麻豆| 麻豆精品久久久一区二区| 久久超碰97人人做人人爱| 婷婷久久久亚洲欧洲日产国码AV| 热99RE久久精品这里都是精品免费| 国产亚州精品女人久久久久久 | 国产高潮国产高潮久久久91 | 久久夜色精品国产噜噜亚洲a| 99久久精品国产一区二区三区| 国产91色综合久久免费| 亚洲AV成人无码久久精品老人 | 久久天天躁狠狠躁夜夜av浪潮| 精品水蜜桃久久久久久久| 久久精品国产一区二区电影| 久久精品无码专区免费| 久久精品国产一区二区电影| 香蕉99久久国产综合精品宅男自 | 亚洲国产精品无码久久久不卡|