龙马谷

 找回密码
 立即注册

QQ登录

只需一步,快速开始

龙马谷VIP会员办理客服QQ:82926983(如果临时会话没有收到回复,请先加QQ好友再发。)
1 [已完结] GG修改器新手入门与实战教程 31课 2 [已完结] GG修改器美化修改教程 6课 3 [已完结] GG修改器Lua脚本新手入门教程 12课
4 [已完结] 触动精灵脚本新手入门必学教程 22课 5 [已完结] 手游自动化脚本入门实战教程 9课 6 [已完结] C++射击游戏方框骨骼透视与自瞄教程 27课
7 [已完结] C++零基础UE4逆向开发FPS透视自瞄教程 29课 8 [已完结] C++零基础大漠模拟器手游自动化辅助教程 22课 9 [已完结] C++零基础开发DXF内存脚本辅助教程 32课
以下是天马阁VIP教程,本站与天马阁合作,赞助VIP可以获得天马阁对应VIP会员,名额有限! 点击进入天马阁论坛
1 [已完结] x64CE与x64dbg入门基础教程 7课 2 [已完结] x64汇编语言基础教程 16课 3 [已完结] x64辅助入门基础教程 9课
4 [已完结] C++x64内存辅助实战技术教程 149课 5 [已完结] C++x64内存检测与过检测技术教程 10课 6 [已完结] C+x64二叉树分析遍历与LUA自动登陆教程 19课
7 [已完结] C++BT功能原理与x64实战教程 29课 8 [已完结] C+FPS框透视与自瞄x64实现原理及防护思路
查看: 7917|回复: 0

C++ 遍历DPC源码

[复制链接]

10

主题

1

回帖

15

积分

编程入门

Rank: 1

龙马币
40

测试没有问题,可以正常遍历哦。


  1. #include<ntddk.h>
  2. typedef struct _KTIMER_TABLE_ENTRY
  3. {
  4.         ULONG Lock;
  5.         LIST_ENTRY Entry;
  6.         ULARGE_INTEGER Time;
  7. } KTIMER_TABLE_ENTRY, *PKTIMER_TABLE_ENTRY;
  8. PKTIMER_TABLE_ENTRY timeTable;

  9. PKTIMER pkTimer;
  10. PLIST_ENTRY plist;

  11. VOID EnumDpcTimer()
  12. {
  13.         ULONG kPrcb=0;
  14.         ULONG index = 0;

  15.         __asm push eax;
  16.         __asm mov eax,fs:[0x20];
  17.         __asm add eax,0x19A0
  18.         __asm mov kPrcb,eax;
  19.         __asm pop eax;
  20.         //timeTable = (PKTIMER_TABLE_ENTRY)(kPrcb+0x19A0);
  21.         timeTable = (PKTIMER_TABLE_ENTRY)(kPrcb);
  22.         for (index; index < 0x100; index++)
  23.         {
  24.                 plist=timeTable[index].Entry.Flink;
  25.                 if (!MmIsAddressValid(plist))
  26.                 {
  27.                         continue;
  28.                 }
  29.                 while (plist!=&timeTable[index].Entry)
  30.                 {
  31.                         //pkTimer=(PKTIMER)((ULONG)plist-0x18);
  32.                         pkTimer=(PKTIMER)CONTAINING_RECORD(plist,KTIMER,TimerListEntry);

  33.                         if (MmIsAddressValid(pkTimer)&&MmIsAddressValid(pkTimer->Dpc))
  34.                         {
  35.                                 if (pkTimer->Period&0xF0000000)
  36.                                 {
  37.                                         break;
  38.                                 }
  39.                                 KdPrint(("0x%08x  ,0x%08x  , %d\n",pkTimer,pkTimer->Dpc->DeferredRoutine,pkTimer->Period));
  40.                         }else
  41.                         {
  42.                                 break;
  43.                         }

  44.                         plist=plist->Flink;
  45.                 }
  46.         }
  47. }

  48. VOID DdkUnload(IN PDRIVER_OBJECT objDriver)
  49. {
  50.         // 2. 删除设备对象
  51.         if ( objDriver->DeviceObject )
  52.                 IoDeleteDevice(objDriver->DeviceObject);
  53. }

  54. NTSTATUS DriverEntry(IN PDRIVER_OBJECT DriverObject, IN PUNICODE_STRING  RegistryPath)
  55. {
  56.         UNREFERENCED_PARAMETER(RegistryPath);

  57.         EnumDpcTimer();
  58.         // 5. 设置卸载函数
  59.         DriverObject->DriverUnload = DdkUnload;
  60.         return STATUS_SUCCESS;
  61. }
复制代码

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

龙马谷| C/C++辅助教程| 安卓逆向安全| 论坛导航| 免责申明|Archiver|
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表龙马谷立场!
任何人不得以任何方式翻录、盗版或出售本站视频,一经发现我们将追究其相关责任!
我们一直在努力成为最好的编程论坛!
Copyright© 2018-2021 All Right Reserved.
在线客服
快速回复 返回顶部 返回列表