news 2026/4/18 12:03:51

驱动开发之遍历驱动

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
驱动开发之遍历驱动

一、目标:遍历系统中所有已加载驱动

在内核中,每一个已加载的模块(exe / dll / sys)都会有一个
_LDR_DATA_TABLE_ENTRY结构体描述它。

对于驱动来说:会把“当前驱动对应的那个 _LDR_DATA_TABLE_ENTRY 的地址” 存放在 DriverObject->DriverSection 中。 DriverObject->DriverSection=当前驱动自己的 _LDR_DATA_TABLE_ENTRY

_LDR_DATA_TABLE_ENTRY并不是孤立存在的, 它的第一个成员InLoadOrderLinks表明:这个结构被设计成“可挂入链表的节点”。
换句话说:每一个模块的_LDR_DATA_TABLE_ENTRY,都和其它模块的_LDR_DATA_TABLE_ENTRY通过LIST_ENTRY相互连接

二、遍历的本质

遍历代码做的事情只有三步:

  1. 拿到当前驱动的_LDR_DATA_TABLE_ENTRY

  2. 通过它的InLoadOrderLinks.Flink找到“下一个节点”

  3. 再从这个节点还原出下一个模块的 _LDR_DATA_TABLE_ENTRY

遍历驱动

完整代码:

#include<ntddk.h>typedefstruct_LDR_DATA_TABLE_ENTRY{LIST_ENTRY InLoadOrderLinks;LIST_ENTRY InMemoryOrderLinks;LIST_ENTRY InInitializationOrderLinks;PVOID DllBase;PVOID EntryPoint;ULONG SizeOfImage;UNICODE_STRING FullDllName;UNICODE_STRING BaseDllName;ULONG Flags;USHORT LoadCount;USHORT TlsIndex;LIST_ENTRY HashLinks;PVOID SectionPointer;ULONG CheckSum;ULONG TimeDateStamp;PVOID LoadedImports;PVOID EntryPointActivationContext;PVOID PatchInformation;LIST_ENTRY ForwarderLinks;LIST_ENTRY ServiceTagLinks;LIST_ENTRY StaticLinks;PVOID ContextInformation;ULONG OriginalBase;LARGE_INTEGER LoadTime;}LDR_DATA_TABLE_ENTRY,*PLDR_DATA_TABLE_ENTRY;// 卸载函数VOIDDriverUnload(PDRIVER_OBJECT DriverObject){DbgPrint("(mydriver) 驱动程序停止运行了。\n");}NTSTATUSDriverEntry(PDRIVER_OBJECT DriverObject,PUNICODE_STRING RegistryPath){DbgPrint("(mydriver) DRIVER_OBJECT 地址:%p\n",DriverObject);DbgPrint("(mydriver) 驱动名称:%wZ\n",&DriverObject->DriverName);DbgPrint("(mydriver) 模块基址:%p\n",DriverObject->DriverStart);DbgPrint("(mydriver) 模块大小:0x%X\n",DriverObject->DriverSize);DbgPrint("(mydriver) -------开始遍历模块-------\n");// DriverSection 通常指向当前驱动自身的 LDR_DATA_TABLE_ENTRYPLDR_DATA_TABLE_ENTRY first=(PLDR_DATA_TABLE_ENTRY)DriverObject->DriverSection;if(first==NULL){DbgPrint("(mydriver) DriverSection 为空,无法遍历。\n");DriverObject->DriverUnload=DriverUnload;returnSTATUS_SUCCESS;}// 用 LIST_ENTRY 来做链表遍历PLIST_ENTRY head=&first->InLoadOrderLinks;PLIST_ENTRY cur=head->Flink;inti=0;while(cur!=head){// 从 LIST_ENTRY* 还原回 LDR_DATA_TABLE_ENTRY*PLDR_DATA_TABLE_ENTRY ldr=CONTAINING_RECORD(cur,LDR_DATA_TABLE_ENTRY,InLoadOrderLinks);if(ldr->FullDllName.Length!=0){DbgPrint("(mydriver) [%d] %wZ\n",i++,&ldr->FullDllName);// DbgPrint("(mydriver) Base: %wZ\n", &ldr->BaseDllName);// DbgPrint("(mydriver) BaseAddr: %p\n", ldr->DllBase);// DbgPrint("(mydriver) Size: 0x%X\n", ldr->SizeOfImage);}cur=cur->Flink;}DbgPrint("(mydriver) -------遍历结束-------\n");DriverObject->DriverUnload=DriverUnload;returnSTATUS_SUCCESS;}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 6:51:06

ClearerVoice-Studio:AI语音处理完整指南,从入门到精通

ClearerVoice-Studio&#xff1a;AI语音处理完整指南&#xff0c;从入门到精通 【免费下载链接】ClearerVoice-Studio An AI-Powered Speech Processing Toolkit and Open Source SOTA Pretrained Models, Supporting Speech Enhancement, Separation, and Target Speaker Extr…

作者头像 李华
网站建设 2026/4/18 3:49:28

如何让旧款Mac焕发新生?OpenCore Legacy Patcher完整指南

还在为你的老Mac无法升级到最新系统而烦恼吗&#xff1f;OpenCore Legacy Patcher这款革命性工具&#xff0c;正是为你量身打造的解决方案&#xff01;它能突破Apple官方限制&#xff0c;让那些被遗忘的Intel Mac设备重新获得新系统的完整支持。无论你是2012年的MacBook Pro还是…

作者头像 李华
网站建设 2026/4/18 3:52:08

LOL皮肤免费获取终极指南:开源资源库完整使用教程

想要在英雄联盟中免费体验所有精美外观吗&#xff1f;现在通过开源社区维护的lol-skins项目&#xff0c;你可以轻松获取游戏中所有官方外观和炫彩资源。这个完整的自定义外观资源库为玩家提供了前所未有的个性化游戏体验。 【免费下载链接】lol-skins Community-maintained rep…

作者头像 李华
网站建设 2026/4/18 3:50:52

3步打造个性化动态桌面:让你的Windows桌面“活“起来

3步打造个性化动态桌面&#xff1a;让你的Windows桌面"活"起来 【免费下载链接】DreamScene2 一个小而快并且功能强大的 Windows 动态桌面软件 项目地址: https://gitcode.com/gh_mirrors/dr/DreamScene2 还在使用单调的静态壁纸吗&#xff1f;当桌面背景能够…

作者头像 李华
网站建设 2026/4/18 4:16:07

Image-Downloader:智能图片批量下载的效率革命

还记得那些为了收集图片素材而熬夜手动保存的夜晚吗&#xff1f;设计师小王曾经需要为新产品设计收集300张参考图片&#xff0c;结果花了整整两天时间在浏览器和文件夹间反复切换。直到他发现了Image-Downloader——这款基于Python开发的图片批量下载自动化工具&#xff0c;彻底…

作者头像 李华