Windows NT 设备驱动程序开发基础(3)

发表于:2007-07-01来源:作者:点击数: 标签:
1.3实现细节 1.3.1内核代码运行级别 Windows NT为它的内核模式的代码分配了不同的级别。在同一个CPU上,级别低的过程 可以被任何级别更大的过程中断。级别由低到高排列如下: 级别名称运行于该级别的过程 PASSIVE_LEVELDriverEntry,Unload,ShutDown,DispatchX
1.3 实现细节 
  
  1.3.1 内核代码运行级别 
  
  Windows NT为它的内核模式的代码分配了不同的级别。在同一个CPU上,级别低的过程 
可以被任何级别更大的过程中断。级别由低到高排列如下: 
  
  级别名称       运行于该级别的过程 
  
  PASSIVE_LEVEL  DriverEntry, Unload, ShutDown, DispatchXxx。 
  
  APC_LEVEL      在某些特殊情况下,大存储量设备的驱动程序运行于该级别。 
  
  DISPATCH_LEVEL StartIo, AdapterControl, ControllerControl, IoTimer,Dpc。 
  
  DIRQLs         各种中断处理程序。 
  
  表二 
 1.3.2  几个对象 
  
  i)     I/O请求包(IRP) 
  
      I/O管理器每收到一个来自用户的请求就创建一个该结构,并将其作为参数传给驱 
动程序的DispatchXxx、StartIo过程。该结构中存放有请求的类型,用户缓冲区的首地 
址,用户请求数据的长度等信息。驱动程序处理完这个请求后,也在该结构中添入处理 
结果的有关信息,调用IoCompleteRequest将其返回给I/O管理器,用户程序的请求随即 
返回。 
  
  ii)     DPC 
  
  当驱动程序中要用到Dpc过程时,需要创建该对象。具体作用请见1.3.3。 
  
  iii) 驱动程序对象(DriverObject) 
  
      该对象在驱动程序被启动时由I/O管理器创建,保存有该程序处理各种请求的过程 
入口、该程序所驱动的全部设备对象的链表等。 
  
  iv) 设备对象(DeviceObject) 
  
      每发现一个可以驱动的设备,驱动程序调用IoCreateDevice创建一个该对象。该 

对象有一个指针DeviceExtension指向一块由驱动程序定义的结构,其中保存有关此设备 
的如端口号,中断向量等全部信息。 
  
  v) 中断对象(Interrupt) 
  
  该对象在驱动程序调用IoConnectInterrupt时创建,存有中断及处理的过程的信息。 
当一个中断发生时,I/O管理器用它寻找对应的处理过程。 
  
  
  1.3.3  推迟过程调用(Deferred Procedure Call) 
  
  由于中断处理过程运行于较高的DIRQL级,它们能屏蔽许多级别小于或等于它们的过程 
的执行,如果它们占用CPU时间过长,很容易使系统性能下降。因此中断处理过程应将一 
些不是很紧急的任务放在被称为Dpc的过程中,在完成数据传输等紧急任务后将一个DPC 
对象放在系统DPC队列的末尾,然后退出,尽量早地让出CPU。系统将在完成所有DIRQL级 
的任务后处理DPC队列,在DISPATCH_LEVEL执行每一个DPC 对象指定的Dpc过程,完成中 
处理断过程未尽的任务。 
  
-- 

原文转自:http://www.ltesting.net