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

转载 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 USB 驱动开发(三)—— 编写USB 驱动程序

前面学习了USB驱动的一些基础概念与重要的数据结构,那么究竟如何编写一个USB 驱动程序呢?编写与一个USB设备驱动程序的方法和其他总线驱动方式类似,驱动程序把驱动程序对象注册到USB子系统中,稍后再...

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

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

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

转自:http://blog.csdn.net/zqixiao_09/article/details/50986965     前面学习了USB驱动的一些基础概念与重要的数据结构,那么究竟如何编...

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

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

Linux驱动程序开发之三----按键驱动(Tiny6410)

在Linux驱动程序开发之三----按键驱动(Tiny6410)博文中讨论了使用中断来实现按键驱动,毫无疑问,中断方式效率相当高,但是在此之前,CPU要想获知按键的状态都是通过查询方式来实现的,查询方...
  • mish84
  • mish84
  • 2014年06月18日 11:36
  • 332

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

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

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

http://hi.baidu.com/combojiang/item/778f34ad3c88e9ac29ce9d32 接上 步骤2:打开连接上下文 第二步是打开连接上下文。在你建...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:驱动开发之三:简单的什么也不做的驱动程序筐架
举报原因:
原因补充:

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