typedef struct { PDEVICE_OBJECT DeviceObject; //指向驱动程序创建的设备对象 PUNICODE_STRING HardwareDatabase; //记录的是设备的硬件数据库名,这里同样用Unicode字符串记录 PFAST_IO_DISPATCH FastIoDispatch;//文件驱动中用到的派遣函数 PDRIVER_INITIALIZE DriverInit;//指向DriverEntry函数的,这是通过IO管理器来建立的。 PDRIVER_STARTIO DriverStartIo;//记录StartIO例程的函数地址,用于串行化操作 PDRIVER_UNLOAD DriverUnload;//指定驱动卸载时所用的回调函数地址 PDRIVER_DISPATCH MajorFunction[IRP_MJ_NUM+1];//指向驱动程序的DispatchXXX函数指针的数组 }DRIVER_OBJECT,*PDRIVER_OBJECT;指向驱动程序的DispatchXXX函数指针的数组 PDRIVER_DISPATCH MajorFunction[IRP_MJ_NUM+1] IRP_MJ_CLEANUP 清除工作,CloseHandle会产生此IRP IRP_MJ_CLOSE 关闭设备,CloseHandle会产生此IRP IRP_MJ_CREATE 创建设备,CreateFile会产生此IRP IRP_MJ_DEVICE_CONTROL DeviceloControl 函数会产生此IRP IRP_MJ_INTERNAL_DEVICE_CONTROL 该IO代码用来与其他驱动之间的通讯 IRP_MJ_PNP 即插即用消息 IRP_MJ_POWER 操作系统处理电源消息时产生此IRP IRP_MJ_READ 读取设备内容,ReadFile产生此IRP IRP_MJ_SHUTDOWN 关闭系统前会产生此IRP IRP_MJ_SYSTEM_CONTROL 系统内部产生的控制信息类似于内核调用eviceloControl函数 IRP_MJ_WRITE 对设备进行WriteFile时会产生此IRP 最简单的处理全部返还成功。 #pragma PAGEDCODE NTSTATUS HelloDDKDispatchRoutin(IN PDEVICE_OBJECT pDevObj,IN PIRP pIrp) { KdPrint(("Enter HelloDDKDispatchRoutin\n")); PIO_STACK_LOCATION stack = IoGetCurrentIrpStackLocation(pIrp); NTSTATUS status = STATUS_SUCCESS; // 完成IRP pIrp->IoStatus.Status = status; pIrp->IoStatus.Information = 0; // bytes xfered IoCompleteRequest(pIrp, IO_NO_INCREMENT); KdPrint(("Leave HelloDDKDispatchRoutin\n")); return status; }
时间: 2024-10-15 06:48:14