如何搭建Visual Studio的内核编程开发环境
2016-05-30 17:27
441 查看
最近正在看《寒江独钓——Windows内核安全编程》这本书,感觉这本书非常好,有兴趣的朋友可以买来看看,有关这本书的信息请参考:http://www.china-pub.com/195592
这本书里没有详细介绍如何搭建Visual Studio的内核编程开发环境,在这里我简单介绍一下,希望能让像我一样刚学习内核编程的朋友更方便地开发。
一、下载与安装WDK
《寒》说,以前说的DDK、IFS已成为历史,现在已经改为使用WDK了,具体下载地址可以这里注册并下载:http://connect.microsoft.com,目前的版本是6001.18002,大小只有577MB。
下载安装后,假设安装路径为“c:\winddk”,接下来要设计环境变量,添加:BASEDIR,值为:“c:\winddk\6001”。必须设置此环境变量,否则下面编译时会出问题。
二、Visual Studio的开发环境
笔者用的是Visual Studio 2005,所以就以此版本介绍,其他版本的类似。
首先新建项目,类型选择Visual C++->General中的“Makefile Project”,这里的项目保存路径不要包括空格、中文等字符,否则会造成后面编译时的出错。
下一步,在Debug Configuration Settings中设置如下:
Build command line: ddk_build chk wxp
Clean commands: ddk_clean chk wxp
Rebuild command line: ddk_build chk wxp /a
Output: first.sys
如图:
下一步,在Release Configuration Settings中与Debug的一样,只是把“chk”改为“fre”即可,如下图:
接下来设置工程属性,在All Configurations中,Configuration Properties->NMake->Include Search Path中添加路径:
C:\WinDDK\6000\inc\ddk;C:\WinDDK\6000\inc\api
接下来添加源代码文件,举个例子:
first.c
现在可以发现在VS中可以使用VS开发环境带来的强大功能,如查看PDRIVER_OBJECT的定义、查看某变量的成员函数(Ctrl+J)等等。
接下来要为编译作准备,添加以下这些文件:
makefile
sources
ddk_build.bat
ddk_clean.bat
现在,按F7就可以编译连接了。
以上就是搭建VS的内核开发环境过程。
三、调试环境
在《寒》一书中,有详细的调试方法介绍,在这里就不说了。不过可以透露的是,使用到的工具是:VMware、WinDbg、srvinstw.exe等。
http://www.cnblogs.com/cxun/archive/2009/08/03/1537646.html
这本书里没有详细介绍如何搭建Visual Studio的内核编程开发环境,在这里我简单介绍一下,希望能让像我一样刚学习内核编程的朋友更方便地开发。
一、下载与安装WDK
《寒》说,以前说的DDK、IFS已成为历史,现在已经改为使用WDK了,具体下载地址可以这里注册并下载:http://connect.microsoft.com,目前的版本是6001.18002,大小只有577MB。
下载安装后,假设安装路径为“c:\winddk”,接下来要设计环境变量,添加:BASEDIR,值为:“c:\winddk\6001”。必须设置此环境变量,否则下面编译时会出问题。
二、Visual Studio的开发环境
笔者用的是Visual Studio 2005,所以就以此版本介绍,其他版本的类似。
首先新建项目,类型选择Visual C++->General中的“Makefile Project”,这里的项目保存路径不要包括空格、中文等字符,否则会造成后面编译时的出错。
下一步,在Debug Configuration Settings中设置如下:
Build command line: ddk_build chk wxp
Clean commands: ddk_clean chk wxp
Rebuild command line: ddk_build chk wxp /a
Output: first.sys
如图:
下一步,在Release Configuration Settings中与Debug的一样,只是把“chk”改为“fre”即可,如下图:
接下来设置工程属性,在All Configurations中,Configuration Properties->NMake->Include Search Path中添加路径:
C:\WinDDK\6000\inc\ddk;C:\WinDDK\6000\inc\api
接下来添加源代码文件,举个例子:
first.c
#include <ntddk.h> VOID DriverUnload(PDRIVER_OBJECT driver) { DbgPrint("Driver unloading...\n"); } NTSTATUS DriverEntry(PDRIVER_OBJECT driver, PUNICODE_STRING reg_path) { DbgPrint("Entered Driver Entry!\n"); driver->DriverUnload = DriverUnload; return STATUS_SUCCESS; } |
接下来要为编译作准备,添加以下这些文件:
makefile
!IF 0 Copyright (C) Microsoft Corporation, 1999 - 2002 Module Name: makefile. Notes: DO NOT EDIT THIS FILE!!! Edit .\sources. if you want to add a new source file to this component. This file merely indirects to the real make file that is shared by all the components of Windows NT (DDK) !ENDIF !INCLUDE $(NTMAKEENV)\makefile.def |
TARGETNAME=first TARGETTYPE=DRIVER TARGETPATH=obj SOURCES=first.c |
@echo on @echo %1 is chk or fre %2 is WXP or W2K or WNET. if "%4"=="/a" call ddk_clean %1 %2 pushd. call %BASEDIR%\bin\setenv.bat %BASEDIR% %1 %2 popd @echo on build |
if exist Debug rd /s /q Debug if exist Release rd /s /q Release if exist obj%1_%2_x86 rd /s /q obj%1_%2_x86 |
以上就是搭建VS的内核开发环境过程。
三、调试环境
在《寒》一书中,有详细的调试方法介绍,在这里就不说了。不过可以透露的是,使用到的工具是:VMware、WinDbg、srvinstw.exe等。
http://www.cnblogs.com/cxun/archive/2009/08/03/1537646.html
相关文章推荐
- Dubbo与Zookeeper、SpringMVC整合和使用(负载均衡、容错)
- MVC中去掉index.php(优雅的使用url)
- 多个cpp共用一个变量,agent开发中应用到
- SpringMVC学习系列(4) 之 数据绑定-1
- java接口可以多继承
- C++ Builder多线程编程技术经验谈(转)
- delphi 设置开机自动启动函数
- python编码
- ASP.NET多次点击提交按钮以及Session超时和丢失过期问题
- Myeclipse常用设置
- Java的一些知识图片
- Java Annotation 必须掌握的特性
- c++基本数据类型
- DB Version Control Tool "Flyway" note 2 Auto run.
- 【C语言】静态顺序表的实现(包括头插、头删、尾插、尾删、查找、删除指定位置)
- 【C语言】输入一个整数,输出该数二进制表示中1的个数(三种方法)
- 【C语言】单链表的相关热点面试题(包括:从尾到头打印,逆置,冒泡,寻找中间节点,倒数k节点)
- 12 种编程语言的起源故事
- Java之IO操作总结
- 【C++】认识模版函数