vs2008配置DDK驱动开发环境

2024-03-02 01:08

本文主要是介绍vs2008配置DDK驱动开发环境,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.首先下载ddk开发包

Windows DDK 3790.1830 下载

安装DDK后,去http://ddkwizard.assarbad.net/ 下载ddkwizard_setup_v1.2.0a、ddkbuild_bat.zip、ddkbuild_cmd.zip。

2.拷贝 DDKBUILD.bat 和 DDKBUILD.cmd 到DDK安装根目录,如我的是D:/WinDDK.

3.. 将上述文件(DDKBUILD.bat 和 DDKBUILD.cmd )的路径添加到系统的path变量(右击我的电脑,系统属性/高级/环境变量/系统变量/path变量双击修改值)。

4. 根据你所安装的DDK的不同版本添加不同的变量到系统变量中。

  右击我的电脑,系统属性/高级/环境变量/系统变量/新建:

  2000 DDK则变量名为: W2KBASE

  XP DDK则变量名为: WXPBASE

  2003 sp1 DDK则变量名为: WNETBASE

  这里我的是WNETBASE(值为D:/WinDDK/3790.1830)

5.启动vs2008 打开菜单中的工具——选项,弹出选项对话框。选择左边的项目和解决方案——VC++目录,在右边的显示以下内容的目录下拉列表中选择可执行文件,在下面列表框中添加上面DDKBuild.bat文件所在的路径(这里是D:/WinDDK),同样设置包含文件和库文件 如下图:

 

 

设置可执行文件

 

 

设置包含文件(D:/WINDDK/3790.1830/inc/wnet D:/WINDDK/3790.1830/inc/ddk/wnet )

 

 

设置库文件(D:/WINDDK/3790.1830/lib/wnet/i386)

 

6. 开始安装DDKWizard,在安装的最后一步你可以选择编辑ddkwizard的配置文件。

7. 现在重新打开VC2008就会发现在新建项目里面有DDK Project的选项了,里面就可以建立驱动工程来编写驱动程序了。

 

8. 验证你做的工作,你可以直接新建一个Driver工程按F7编译,编译看看。

建立EmptyDriver时,

要在sources文件的第4行TARGETTYPE=后面加DRIVER

加入[源文件]后还要在sources文件里的SOURCES=后面加上[源文件名]。比如:

SOURCES=DriverDemo.cpp /

  DriverDemo.h

VS2008集成DDKWizard遇到的问题>>>>>>>>>>>>>>>>>>>>>

————————————————————————————

▲建立EmptyDriver时,

要在sources文件的第4行TARGETTYPE=后面加DRIVER

加入[源文件]后还要在sources文件里的SOURCES=后面加上[源文件名]。比如:

SOURCES=DriverDemo.cpp /

  DriverDemo.h

▲Cannot open include file: /'NTDDK.h/': No such file or directory

解决方案:VS2005/工具/选项/VC++目录/,

[显示以下内容的目录]为[包含文件],把DDK包含文件加进目录——

[D:/WINDDK/3790.1830/inc/ddk/wnet]和[D:/WINDDK/3790.1830/inc/wnet]。

[显示以下内容的目录]为[库文件],把DDK库文件加进目录——

[D:/WINDDK/3790.1830/LIB/WNET/I386]

以上DDK的路径要放到最先。

参考自:http://blog.csdn.net/jamesandy/archive/2008/03/17/2192267.aspx

结果:

▲编译提示错误:

BufferOverflowK.lib(gs_support.obj) : error LNK2019: unresolved external symbol _DriverEntry@8 referenced in function _GsDriverEntry@8

objchk_w2K_x86/i386/Helloworld.sys : fatal error LNK1120: 1 unresolved externals

解决方案:

把[入口函数DriverEntry]前加上extern "C":

extern "C"{

NTSTATUS DriverEntry(PDRIVER_OBJECT pDriverObj, PUNICODE_STRING pRegistryString)

{ /*DriverEntry函数内容*/ }

}//extern "C"

结果:OK。编译通过,才。我靠!终于啊!

另:据说改成.c文件也可。理论上是这样,但测试失败。

测试代码如下

// sources文件

# $Id$

TARGETNAME=HelloWorld

TARGETPATH=obj

TARGETTYPE=DRIVER

# Create browse info

#BROWSER_INFO=1

#BROWSERFILE=<some path>

# Additional defines for the C/C++ preprocessor

C_DEFINES=$(C_DEFINES)

SOURCES=HelloWorld.c

//makefile文件

#

# 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 the Windows NT DDK

#

!INCLUDE $(NTMAKEENV)/makefile.def

//HelloWorld.h文件

#ifndef __HELLOWORLD_H__

#define __HELLOWORLD_H__

#include <ntddk.h>

#define DEVICE_HELLO_INDEX 0x860

#define START_HELLOWORLD CTL_CODE( FILE_DEVICE_UNKNOWN,DEVICE_HELLO_INDEX,METHOD_BUFFERED,FILE_ANY_ACCESS)

#define STOP_HELLOWORLD CTL_CODE(FILE_DEVICE_UNKNOWN,DEVICE_HELLO_INDEX+1,METHOD_BUFFERED,FILE_ANY_ACCESS)

#define NT_DEVICE_NAME L"//Device//HelloWorld"

#define DOS_DEVICE_NAME L"//DosDevices//HelloWorld"

NTSTATUS HelloWorldDispatch(IN PDEVICE_OBJECT DeviceObject,IN PIRP pIrp);

VOID HelloWorldUnload(IN PDRIVER_OBJECT DriverObject);

#endif

// HelloWorld.c文件

#ifndef __HELLOWORLD_C__

#define __HELLOWORLD_C__

#define DEBUGMSG

#include "HelloWorld.h"

NTSTATUS DriverEntry(IN PDRIVER_OBJECT DriverObject,IN PUNICODE_STRING RegistryPath)

{

  NTSTATUS ntStatus=STATUS_SUCCESS;

  PDEVICE_OBJECT IpDeviceObject=NULL;

  UNICODE_STRING DeviceNameString;

  UNICODE_STRING DeviceLinkString;

  #ifdef DEBUGMSG

  DbgPrint("hi, Starting DriverEntry()/n");

  #endif

 

  RtlInitUnicodeString(&DeviceNameString,NT_DEVICE_NAME);

  ntStatus=IoCreateDevice(DriverObject,0,&DeviceNameString,FILE_DEVICE_UNKNOWN,0,FALSE,&IpDeviceObject);

  if(!NT_SUCCESS(ntStatus))

  {

  #ifdef DEBUGMSG

  DbgPrint("hi, Error IoCreateDevice()/n");

  #endif

  goto Error;

  }

  RtlInitUnicodeString(&DeviceLinkString,DOS_DEVICE_NAME);

  ntStatus=IoCreateSymbolicLink(&DeviceLinkString,&DeviceNameString);

  if(!NT_SUCCESS(ntStatus))

  {

  #ifdef DEBUGMSG

  DbgPrint("hi, Error IoCreateSymbolicLink()/n");

  #endif

  goto Error;

  }

  DriverObject->MajorFunction[IRP_MJ_CREATE]=HelloWorldDispatch;

  DriverObject->MajorFunction[IRP_MJ_CLOSE]=HelloWorldDispatch;

  DriverObject->MajorFunction[IRP_MJ_DEVICE_CONTROL]=HelloWorldDispatch;

  DriverObject->DriverUnload=HelloWorldUnload;

  return ntStatus;

Error:

  #ifdef DEBUGMSG

  DbgPrint("hi, Error DriverEntry()/n");

  #endif

  return ntStatus;

}

NTSTATUS HelloWorldDispatch(IN PDEVICE_OBJECT DeviceObject,IN PIRP pIrp)

{

  NTSTATUS ntStatus=STATUS_SUCCESS;

  ULONG IoControlCodes=0;

  PIO_STACK_LOCATION IrpStack=NULL;

  pIrp->IoStatus.Status=STATUS_SUCCESS;

  pIrp->IoStatus.Information=0;

  #ifdef DEBUGMSG

  DbgPrint("hi, Starting HelloWorldDispatch()/n");

  #endif

  IrpStack=IoGetCurrentIrpStackLocation(pIrp);

  switch(IrpStack->MajorFunction)

  {

  case IRP_MJ_CREATE:

  #ifdef DEBUGMSG

  DbgPrint("hi, IRP_MJ_CREATE/n");

  #endif

  break;

  case IRP_MJ_CLOSE:

  #ifdef DEBUGMSG

  DbgPrint("hi, IRP_MJ_CLOSE/n");

  #endif

  break;

  case IRP_MJ_DEVICE_CONTROL:

  #ifdef DEBUGMSG

  DbgPrint("hi, IRP_MJ_DEVICE_CONTROL/n");

  #endif

  IoControlCodes=IrpStack->Parameters.DeviceIoControl.IoControlCode;

  switch(IoControlCodes)

  {

  case START_HELLOWORLD:

  DbgPrint("hi, Starting /"Hello World /"/n");

  break;

  case STOP_HELLOWORLD:

  DbgPrint("hi, Stoping /"Hello World /"/n");

  break;

  default:

  pIrp->IoStatus.Status=STATUS_INVALID_PARAMETER;

  break;

  }

  break;

  default:

  break;

  }

  ntStatus=pIrp->IoStatus.Status;

  IoCompleteRequest(pIrp,IO_NO_INCREMENT);

  return ntStatus;

}

VOID HelloWorldUnload(IN PDRIVER_OBJECT DriverObject)

{

  UNICODE_STRING DeviceLinkString;

  PDEVICE_OBJECT DeviceObjectTemp1=NULL;

  PDEVICE_OBJECT DeviceObjectTemp2=NULL;

  #ifdef DEBUGMSG

  DbgPrint("hi,Starting HelloWorldUnload()/n");

  #endif

  RtlInitUnicodeString(&DeviceLinkString,DOS_DEVICE_NAME);

  IoDeleteSymbolicLink(&DeviceLinkString);

  if(DriverObject)

  {

  DeviceObjectTemp1=DriverObject->DeviceObject;

  while(DeviceObjectTemp1)

  {

  DeviceObjectTemp2=DeviceObjectTemp1;

  DeviceObjectTemp1=DeviceObjectTemp1->NextDevice;

  IoDeleteDevice(DeviceObjectTemp2);

  }

  }

}

#endif

手动编译命令如下:

 

打开:开始/程序/……/Windows Server 2003 Checked x86 Build Environment

输入如下:

D:/WINDDK/3790~1.183>cd ..//uu

D:/WINDDK/uu>build

这篇关于vs2008配置DDK驱动开发环境的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/764448

相关文章

SpringBoot路径映射配置的实现步骤

《SpringBoot路径映射配置的实现步骤》本文介绍了如何在SpringBoot项目中配置路径映射,使得除static目录外的资源可被访问,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一... 目录SpringBoot路径映射补:springboot 配置虚拟路径映射 @RequestMapp

Python实战之SEO优化自动化工具开发指南

《Python实战之SEO优化自动化工具开发指南》在数字化营销时代,搜索引擎优化(SEO)已成为网站获取流量的重要手段,本文将带您使用Python开发一套完整的SEO自动化工具,需要的可以了解下... 目录前言项目概述技术栈选择核心模块实现1. 关键词研究模块2. 网站技术seo检测模块3. 内容优化分析模

Java+AI驱动实现PDF文件数据提取与解析

《Java+AI驱动实现PDF文件数据提取与解析》本文将和大家分享一套基于AI的体检报告智能评估方案,详细介绍从PDF上传、内容提取到AI分析、数据存储的全流程自动化实现方法,感兴趣的可以了解下... 目录一、核心流程:从上传到评估的完整链路二、第一步:解析 PDF,提取体检报告内容1. 引入依赖2. 封装

Nginx中配置使用非默认80端口进行服务的完整指南

《Nginx中配置使用非默认80端口进行服务的完整指南》在实际生产环境中,我们经常需要将Nginx配置在其他端口上运行,本文将详细介绍如何在Nginx中配置使用非默认端口进行服务,希望对大家有所帮助... 目录一、为什么需要使用非默认端口二、配置Nginx使用非默认端口的基本方法2.1 修改listen指令

基于Java开发一个极简版敏感词检测工具

《基于Java开发一个极简版敏感词检测工具》这篇文章主要为大家详细介绍了如何基于Java开发一个极简版敏感词检测工具,文中的示例代码简洁易懂,感兴趣的小伙伴可以跟随小编一起学习一下... 目录你是否还在为敏感词检测头疼一、极简版Java敏感词检测工具的3大核心优势1.1 优势1:DFA算法驱动,效率提升10

mysql5.7.15winx64配置全过程

《mysql5.7.15winx64配置全过程》文章详细介绍了MySQL5.7.15免安装版的配置步骤,包括解压安装包、设置环境变量、修改配置文件、初始化数据目录、安装服务、启动数据库、登录及密码修改... 目录前言一、首先下载安装包二、安android装步骤1.第一步解压文件2.配置环境变量3.复制my-

Jenkins的安装与简单配置过程

《Jenkins的安装与简单配置过程》本文简述Jenkins在CentOS7.3上安装流程,包括Java环境配置、RPM包安装、修改JENKINS_HOME路径及权限、启动服务、插件安装与系统管理设置... 目录www.chinasem.cnJenkins安装访问并配置JenkinsJenkins配置邮件通知

Python开发简易网络服务器的示例详解(新手入门)

《Python开发简易网络服务器的示例详解(新手入门)》网络服务器是互联网基础设施的核心组件,它本质上是一个持续运行的程序,负责监听特定端口,本文将使用Python开发一个简单的网络服务器,感兴趣的小... 目录网络服务器基础概念python内置服务器模块1. HTTP服务器模块2. Socket服务器模块

Conda国内镜像源及配置过程

《Conda国内镜像源及配置过程》文章介绍Conda镜像源使用方法,涵盖临时指定单个/多个源、永久配置及恢复默认设置,同时说明main(官方稳定)、free(逐渐弃用)、conda-forge(社区更... 目录一、Conda国内镜像源二、Conda临时使用镜像源指定单个源临时指定多个源创建环境时临时指定源

MySQL配置多主复制的实现步骤

《MySQL配置多主复制的实现步骤》多主复制是一种允许多个MySQL服务器同时接受写操作的复制方式,本文就来介绍一下MySQL配置多主复制的实现步骤,具有一定的参考价值,感兴趣的可以了解一下... 目录1. 环境准备2. 配置每台服务器2.1 修改每台服务器的配置文件3. 安装和配置插件4. 启动组复制4.