驱动开发之三:简单的什么也不做的驱动程序筐架

转载 2006年06月15日 11:22:00
//说明,编译是需要相对路径中有inc目录,而且有ntifs.inc;且扩展了函数。

//#include "ntifs.h"

//#include "stdio.h"



//常量定义;

#define DEVICE_TYPE_SYSMON 0x8266 //DDK指出0-7fffh是被系统保留了

#define NT_DEVICE_NAME L"//Device//MINSYS" //内核设备名

#define DOS_DEVICE_NAME L"//DosDevices//MINSYS" //符号连接设备名



//全局变量定义;

PDRIVER_OBJECT gOwenDriverObject; //本驱动程序对象

PDEVICE_OBJECT gCtrlDeviceObject; //用控制设备对象域



#pragma code_seg("PAGE")

VOID//UnLoad例程;

Unload(PDRIVER_OBJECT DriverObject) 



UNICODE_STRING Win32DeviceName; 

RtlInitUnicodeString(&Win32DeviceName,DOS_DEVICE_NAME); 

IoDeleteSymbolicLink(&Win32DeviceName);

IoDeleteDevice(gCtrlDeviceObject); 

#if (DBG)

{

DbgPrint (("-------------------Unload OK/n"));

}

#endif

return;

}



NTSTATUS 

DeviceIrpCreate( IN PDEVICE_OBJECT DeviceObject, IN PIRP Irp )

{

IoCompleteRequest( Irp, IO_NO_INCREMENT );

return STATUS_SUCCESS;

}



NTSTATUS 

DeviceIrpClose( IN PDEVICE_OBJECT DeviceObject, IN PIRP Irp )

{

IoCompleteRequest( Irp, IO_NO_INCREMENT );

return STATUS_SUCCESS;

}



NTSTATUS 

DeviceIrpControl( IN PDEVICE_OBJECT DeviceObject, IN PIRP Irp )

{

IoCompleteRequest( Irp, IO_NO_INCREMENT );

return STATUS_SUCCESS;

}



#pragma code_seg("INIT")

NTSTATUS//驱动程序入口;

DriverEntry(IN PDRIVER_OBJECT DriverObject,IN PUNICODE_STRING RegistryPath)

{

NTSTATUS Status; 

UNICODE_STRING NtDeviceName; 

UNICODE_STRING Win32DeviceName; 



//保存自己的驱动程序对象,备用

gOwenDriverObject=DriverObject;



//初始化Unicode字符串, 创建设备对象;

RtlInitUnicodeString(&NtDeviceName,NT_DEVICE_NAME); 

Status=IoCreateDevice( DriverObject,0,&NtDeviceName,

DEVICE_TYPE_SYSMON,0,FALSE,&gCtrlDeviceObject);

if (!NT_SUCCESS(Status)) return Status; 



//初始化Unicode字符串, 创建Win32符号连接,以便Win32程序能够访问;

RtlInitUnicodeString(&Win32DeviceName,DOS_DEVICE_NAME); 

Status=IoCreateSymbolicLink(&Win32DeviceName,&NtDeviceName);

if (!NT_SUCCESS(Status))

{

IoDeleteDevice( gCtrlDeviceObject );

return Status; 

}



//填写驱动程序Dispatch例程

DriverObject->MajorFunction[IRP_MJ_CREATE] =DeviceIrpCreate;

DriverObject->MajorFunction[IRP_MJ_CLOSE] =DeviceIrpClose;

DriverObject->MajorFunction[IRP_MJ_DEVICE_CONTROL] =DeviceIrpControl;



//填写处理Unload例程

DriverObject->DriverUnload =Unload;



#if (DBG)

{

DbgPrint("DriverObject=%x RegistryPath=%x/n",DriverObject,RegistryPath);

}

#endif



return Status;

}

相关文章推荐

Linux USB 驱动开发(五)—— USB驱动程序开发过程简单总结

设备驱动程序是操作系统内核和机器硬件之间的接口,由一组函数和一些私有数据组成,是应用程序和硬件设备之间的桥梁。在应用程序看来,硬件设备只是一个设备文件,应用程序可以像操作普通文件一样对硬件设备进行操作...

Linux USB 驱动开发(三)—— 编写USB 驱动程序

Linux的设备驱动都遵循一个惯例——表征驱动程序(用driver更贴切一些,应该称为驱动器比较好吧)的结构体,结构体里面应该包含了驱动程序所需要的所有资源。用术语来说,就是这个驱动器对象所拥有的属性...

《Linux设备设备驱动程序(第三版)》学习笔记之三:sleepy设备的使用

By: 吴垠 Date: 2007-07-05 Email: lazy.fox.wu#gmail.com Homepage: http://blog.csdn.n...

敏用户故事驱动开发系列之三:用户故事来源之“北极星”计划

敏用户故事驱动开发系列之三:用户故事来源之“北极星”计划 本文是用户故事来源的第一篇,主要探讨产品经理从市场洞察的信息通过分析整理后,形成产品愿景,作为用户故事的重要来源! 《观象》载: 北极星...

驱动开发之五 --- TDI之三 【译文】

驱动开发之五 --- TDI之三 【译文】 接上 步骤2:打开连接上下文 第二步是打开连接上下文。在你建立的连接中,执行后续的操作会用到这个句柄。这也是由ZwCreateFile...

Android驱动开发-- 2.测试驱动程序

LED driver驱动可以正常加载后,需要写一个测试程序在用户空间测试一下驱动,测试LED驱动程序是否能控制LED的点亮或熄灭。 方法是写一个C的测试代码,编译后在用户空间执行,和操作文件的命令一样...

<学习笔记>Windows驱动开发技术详解__驱动程序的同步处理

如果驱动程序没有很好地处理同步问题,操作系统的性能就会下降,甚至出现死锁等现象。 基本概念 1.问题的引出 下面这段代码: int number; void Foo() { ...

windows xp 驱动开发(五) USB驱动程序、应用软件概述

转载请标明是引用于 http://blog.csdn.net/chenyujing1234   欢迎大家提出意见,一起讨论! 1、USB设备驱动程序(WDM模型) 1、1  分类 USB...

对 Windows驱动开发技术详解 第八章的(驱动程序的同步处理)自我理解

对 Windows驱动开发技术详解 第八章的(驱动程序的同步处理)自我理解 BY:ALALMN—飞龙 QQ:316118740 BLOG:http://hi.baidu.com/alal...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)