Win64 驱动内核编程-1.环境搭建
驱动开发环境及其双机调试环境搭建
开发环境搭建
使用工具:vs2015,Windows 10 SDK_10.0.14393,WDK10.0.14393.0
(1)安装VS2015 随便一个版本吧,我安装的企业版
(2)安装WDK10.0.14393 安装WDK
(3)安装Windows 10 SDK_10.0.14393.安装SDK,这个首先可以尝试从VS配置更新里安装。
控制面板->卸载程序->vs2015->更改
选上这个SDK,然后更新。注意这个地方很有可能更新失败,我在公司一次就更新成功,在家里更新了好多次,最后都是hash校验失败啥的错误。最终无奈,去网上找离线安装包,注意离线安装包是一个几百兆的压缩文件,不是那种很小的。很小的下载下来,双击之后还是走的上面的那个流程。相当于下载器。下载器下载下来的依然可能出现之前的hash校验失败。这个地方我尝试了好多次。
TIP:最后一点就是一定要注意,SDK和WDK的第三位版本号一定要对上。我的是14393。
搭建双击调试环境
接下来是搭建调试环境,驱动通常是搭建双击调试环境。虽然不是要逆向调试啥的。但是本机调试的话很容易丢失一些信息。毕竟蓝屏后我们能得到的只有一个dump。
双击调试环境搭建很简单。下面说下步骤:
1.安装VMWARE,虚拟机。
2.安装Win 64系统。(我是安装的win7)。
3.把第二部安装的系统UAC关掉。
4.在虚拟机里安装WMware Tools。这个在虚拟机设置里可以直接更新。
5.在虚拟机里直接安装.net framework4(如果安装的系统高于win7就不用了,win7,貌似是3.5的,之后都是大于等于4.0的)。
6.备份虚拟机当前镜像。
上面安装完虚拟机之后,接下来继续搭建调试环境。
1.安装windebug.
2.下载VirtualKD然后把target文件夹拷贝到虚拟机里。
3.虚拟机里管理员权限,找到刚刚下载的VirtualKD,运行target文件夹下的vminstall.exe。
4.然后在本机里运行VirtualKD里面的wmmon64.exe,设置调试路径[Debugger path]为1安装的windebug路径
5.重启刚刚的虚拟机(注意此时本机的wmon64正在开启着,在第3步里)。选择这个启动项:
然后会发现windebug自动启动了,其实是被wmon唤醒的,然后电脑卡在这个界面:
可以理解为现在是卡到了调试断点,在windebug里面直接按F5让虚拟机里的系统跑起来。
6.然后先别调试,先去下载windows符号表:
http://msdn.microsoft.com/en-us/windows/hardware/gg463028.aspx对应找到自己系统的符号表。注意有SP1和RTM的区别。下载之后安装到C:\symbols这个目录。
7.在windebug里设置符号表路径:
File->Sysbol file path
8.测试符号表是不是导入成功,此时先重启刚刚的虚拟机,进入到那个按f5之前的那一步。
输入u KiInsertQueueApc看到下面这样(u xxx是内存代码反汇编):
就没啥毛病了。
OK上面的开发环境和调试环境就OK了。
Win64 驱动内核编程-1.环境搭建相关推荐
- Win64 驱动内核编程-2.基本框架(安装.通讯.HelloWorld)
驱动安装,通讯,Hello World 开发驱动的简单流程是这样,开发驱动安装程序,开发驱动程序,然后安装程序(或者其他程序)通过通讯给驱动传命令,驱动接到之后进行解析并且执行,然后把执行结果返回. ...
- Win64 驱动内核编程-3.内核里使用内存
内核里使用内存 内存使用,无非就是申请.复制.设置.释放.在 C 语言里,它们对应的函数是:malloc.memcpy.memset.free:在内核编程里,他们分别对应 ExAllocatePool ...
- Win64 驱动内核编程-18.SSDT
SSDT 学习资料:http://blog.csdn.net/zfdyq0/article/details/26515019 学习资料:WIN64内核编程基础 胡文亮 SSDT(系统服务描述表),刚开 ...
- Win64 驱动内核编程-8.内核里的其他常用
内核里的其他常用 1.遍历链表.内核里有很多数据结构,但它们并不是孤立的,内核使用双向链表把它们像糖 葫芦一样给串了起来.所以遍历双向链表能获得很多重要的内核数据.举个简单的例子,驱 动对象 Driv ...
- Win64 驱动内核编程-25.X64枚举和隐藏内核模块
X64枚举和隐藏内核模块 在 WIN64 上枚举内核模块的人方法:使用 ZwQuerySystemInformation 的第 11 号功能和枚举 KLDR_DATA_TABLE_ENTRY 中的 I ...
- Win64 驱动内核编程-23.Ring0 InLineHook 和UnHook
Ring0 InLineHook 和UnHook 如果是要在R0里hook,作者的建议是InLine HOOK,毕竟SSDT HOOK 和 SHADOW SSDT HOOK比较麻烦,不好修改.目前R3 ...
- Win64 驱动内核编程-19.HOOK-SSDT
HOOK SSDT 在 WIN64 上 HOOK SSDT 和 UNHOOK SSDT 在原理上跟 WIN32 没什么不同,甚至说 HOOK 和 UNHOOK 在本质上也没有不同,都是在指定的地址上填 ...
- Win64 驱动内核编程-11.回调监控进线程句柄操作
无HOOK监控进线程句柄操作 在 NT5 平台下,要监控进线程句柄的操作. 通常要挂钩三个API:NtOpenProcess.NtOpenThread.NtDuplicateObject.但是在 VI ...
- Win64 驱动内核编程-10.突破WIN7的PatchGuard
突破WIN7的PatchGuard WIN64 有两个内核保护机制,KPP 和 DSE.KPP 阻止我们 PATCH 内核,DSE 拦截我们加载驱动.当然 KPP 和 DSE 并不是不可战胜的,WIN ...
最新文章
- 树莓派c语言输出pwm波,树莓派硬件PWM输出程序
- 海口这家只收5元的理发店火了 顾客求涨价老板都不肯
- CRC校验算法的解析,暨对网上的CRC详解的补充
- java用中根后根序列构造二叉树,106. 从中序与后序遍历序列构造二叉树
- 添加phpiredis扩展的时候报错
- Java开发Maven插件
- 软件设计师备考知识06--树
- 【7.1】property动态属性
- 基于Spring Boot的宠物猫店管理系统的设计与实现毕业设计源码140909
- SQL按每5分钟或者10分钟分组统计数据
- Httpwatch中http状态码列表
- java毕业设计共享充电宝系统mybatis+源码+调试部署+系统+数据库+lw
- 怎么设置邮箱自动回复?如何设置自动回复功能?
- Oracle调优总结
- Android避免内存溢出(Out of Memory)方法总结
- FusionCharts报表
- 验证:获取linux系统的网卡信息
- JS-打开新窗口(window.open)/关闭窗口(window.close)
- jenkins忘记管理员密码修改
- 【淘宝】从开店到运营 - 开店前期知识(天猫、淘宝店铺介绍)
热门文章
- Android中使用ContentProvider进行跨进程方法调用
- spring mybatis 集成
- lucene,基于QueryParser的搜索
- Blend学习资料总结
- 【专题六】虚拟化实施人才和培训的瓶颈如何解决? ——虚拟化人才逆势抢手 5项技能最关键...
- 正方形分成16份,将1到16填入其中。让行和列都是从大到小。问一共有多少种方法?...
- 关于算法的时间复杂度怎么计算
- 04 javascirpt基础知识---听课笔记
- dubbo中使用动态代理
- BZOJ3709: [PA2014]Bohater