一个比较简单驱动程序初学者可以看看

王朝other·作者佚名  2006-01-10
窄屏简体版  字體: |||超大  

我写程序,喜欢以最简单的方式写,因为我怕眼花,我的程序只能看到程序功能,没什么语法特点,都是最基本的.

#include <wdm.h>

#define NT_DEVICE_NAME L"\Device\Example"

#define DOS_DEVICE_NAME L"\DosDevices\Example"

VOID DriverUnload( IN PDRIVER_OBJECT pDriverObject );

NTSTATUS DispatchFunction( IN PDEVICE_OBJECT pDeviceObject, IN PIRP Irp );

NTSTATUS DispatchRead( IN PDEVICE_OBJECT pDeviceObject, IN PIRP Irp );

NTSTATUS DispatchWrite( IN PDEVICE_OBJECT pDeviceObject, IN PIRP Irp );

NTSTATUS DriverEntry( IN PDRIVER_OBJECT pDriverObject, IN PIRP Irp )

{

NTSTATUS status = STATUS_SUCCESS;

PDEVICE_OBJECT pDeviceObject = NULL;

UNICODE_STRING usNtDeviceName, usDosDeviceName;

int nIndex = 0;

RtlInitUnicodeString( &usNtDeviceName, NT_DEVICE_NAME );

status = IoCreateDevice( pDriverObject,

0,

&usNtDeviceName,

FILE_DEVICE_UNKNOWN,

FILE_DEVICE_SECURE_OPEN,

FALSE,

&pDeviceObject );

if ( NT_SUCCESS(status) )

{

DbgPrint( "DriverEntry" );

pDriverObject->DriverUnload = DriverUnload;

RtlInitUnicodeString( &usDosDeviceName, DOS_DEVICE_NAME );

IoCreateSymbolicLink( &usDosDeviceName, &usNtDeviceName );

for (nIndex; nIndex <= IRP_MJ_MAXIMUM_FUNCTION; nIndex ++)

pDriverObject->MajorFunction[ nIndex ] = DispatchFunction;

}

return status;

}

VOID DriverUnload( IN PDRIVER_OBJECT pDriverObject )

{

UNICODE_STRING usDosDeviceName;

RtlInitUnicodeString( &usDosDeviceName, DOS_DEVICE_NAME );

DbgPrint( "DriverUnload" );

IoDeleteSymbolicLink( &usDosDeviceName );

IoDeleteDevice( pDriverObject->DeviceObject );

}

NTSTATUS DispatchFunction( IN PDEVICE_OBJECT pDeviceObject, IN PIRP Irp )

{

NTSTATUS status = STATUS_SUCCESS;

PIO_STACK_LOCATION irpStack = NULL;

irpStack = IoGetCurrentIrpStackLocation( Irp );

switch ( irpStack->MajorFunction )

{

case IRP_MJ_CREATE:

break;

case IRP_MJ_READ:

DispatchRead( pDeviceObject, Irp );

break;

case IRP_MJ_WRITE:

DispatchWrite( pDeviceObject, Irp );

break;

default:

DbgPrint( "DispatchFunction" );

break;

}

IoCompleteRequest( Irp, IO_NO_INCREMENT );

return status;

}

NTSTATUS DispatchRead( IN PDEVICE_OBJECT pDeviceObject, IN PIRP Irp )

{

NTSTATUS status = STATUS_SUCCESS;

PIO_STACK_LOCATION irpStack = NULL;

char *pBuf = "88888888";

int nLen = sizeof ("88888888");

irpStack = IoGetCurrentIrpStackLocation( Irp );

if ( irpStack )

{

ProbeForWrite( Irp->UserBuffer, irpStack->Parameters.Read.Length, TYPE_ALIGNMENT(char) );

RtlCopyMemory( Irp->UserBuffer, pBuf, nLen );

}

return status;

}

NTSTATUS DispatchWrite( IN PDEVICE_OBJECT pDeviceObject, IN PIRP Irp )

{

NTSTATUS status = STATUS_SUCCESS;

PIO_STACK_LOCATION irpStack = NULL;

irpStack = IoGetCurrentIrpStackLocation( Irp );

if ( irpStack )

{

ProbeForRead( Irp->UserBuffer, irpStack->Parameters.Read.Length, TYPE_ALIGNMENT(char) );

DbgPrint( Irp->UserBuffer );

}

return status;

}

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航