📄 iorw.c
字号:
// iorw.c
//
// Generated by C DriverWizard 3.2.0 (Build 2485)
// Requires DDK Only
// File created on 3/12/2009
//
#include "pch.h"
#include "..\intrface.h"
#ifdef DRIVERB_SYN_WMI_TRACE
#include "iorw.tmh"
#endif
///////////////////////////////////////////////////////////////////////////////////////////////////
// DriverB_SynReadDispatch
// Handled incoming read requests
//
// Arguments:
// IN DeviceObject
// Device object for our device
//
// IN Irp
// The read IRP to handle
//
// Return Value:
// NT status code
//
NTSTATUS DriverB_SynReadDispatch(
IN PDEVICE_OBJECT DeviceObject,
IN PIRP Irp
)
{
PDRIVERB_SYN_DEVICE_EXTENSION deviceExtension;
NTSTATUS status;
UNICODE_STRING DeviceName;
OBJECT_ATTRIBUTES objectAttributes;
HANDLE hDevice;
IO_STATUS_BLOCK status_block;
DriverB_SynDebugPrint(DBG_IO, DBG_TRACE, __FUNCTION__"++. IRP %p", Irp);
status = STATUS_SUCCESS;
RtlInitUnicodeString(&DeviceName,L"\\Device\\DriverADevice");
InitializeObjectAttributes(&objectAttributes,
&DeviceName,
OBJ_CASE_INSENSITIVE,
NULL,
NULL);
status = ZwCreateFile(&hDevice,
FILE_READ_ATTRIBUTES|SYNCHRONIZE,
&objectAttributes,
&status_block,
NULL,
FILE_ATTRIBUTE_NORMAL,
FILE_SHARE_READ,
FILE_OPEN_IF,
FILE_SYNCHRONOUS_IO_NONALERT,
NULL,0);
if(NT_SUCCESS(status))
{
ZwReadFile(hDevice,NULL,NULL,NULL,&status_block,NULL,0,NULL,NULL);
}
ZwClose(hDevice);
Irp->IoStatus.Information = 0;
Irp->IoStatus.Status = status;
IoCompleteRequest(Irp, IO_NO_INCREMENT);
DriverB_SynDebugPrint(DBG_IO, DBG_TRACE, __FUNCTION__"--. IRP %p STATUS %x", Irp, status);
return status;
}
///////////////////////////////////////////////////////////////////////////////////////////////////
// DriverB_SynWriteDispatch
// Handled incoming write requests
//
// Arguments:
// IN DeviceObject
// Device object for our device
//
// IN Irp
// The write IRP to handle
//
// Return Value:
// NT status code
//
NTSTATUS DriverB_SynWriteDispatch(
IN PDEVICE_OBJECT DeviceObject,
IN PIRP Irp
)
{
PDRIVERB_SYN_DEVICE_EXTENSION deviceExtension;
NTSTATUS status;
PIO_STACK_LOCATION irpStack;
PVOID writeBuffer;
ULONG writeLength;
DriverB_SynDebugPrint(DBG_IO, DBG_TRACE, __FUNCTION__"++. IRP %p", Irp);
deviceExtension = (PDRIVERB_SYN_DEVICE_EXTENSION)DeviceObject->DeviceExtension;
status = DriverB_SynCheckIoLock(&deviceExtension->IoLock, Irp);
if (!NT_SUCCESS(status) || (status == STATUS_PENDING))
{
DriverB_SynDebugPrint(DBG_IO, DBG_WARN, __FUNCTION__"--. IRP %p STATUS %x", Irp, status);
return status;
}
// Get our IRP stack location
irpStack = IoGetCurrentIrpStackLocation(Irp);
// Get the write buffer length
writeLength = irpStack->Parameters.Write.Length;
if (writeLength == 0)
{
// just complete 0 length request
status = STATUS_SUCCESS;
Irp->IoStatus.Information = 0;
Irp->IoStatus.Status = status;
IoCompleteRequest(Irp, IO_NO_INCREMENT);
DriverB_SynDecrementIoCount(&deviceExtension->IoLock);
DriverB_SynDebugPrint(DBG_IO, DBG_WARN, __FUNCTION__"--. IRP %p, STATUS %x", Irp, status);
return status;
}
writeBuffer = MmGetSystemAddressForMdlSafe(Irp->MdlAddress, NormalPagePriority);
status = STATUS_NOT_IMPLEMENTED;
Irp->IoStatus.Information = 0;
Irp->IoStatus.Status = status;
IoCompleteRequest (Irp, IO_NO_INCREMENT);
DriverB_SynDecrementIoCount(&deviceExtension->IoLock);
DriverB_SynDebugPrint(DBG_IO, DBG_TRACE, __FUNCTION__"--. IRP %p STATUS %x", Irp, status);
return status;
}
///////////////////////////////////////////////////////////////////////////////////////////////////
// DriverB_SynDeviceIoControlDispatch
// Handled incoming IOCTL requests
//
// Arguments:
// IN DeviceObject
// Device object for our device
//
// IN Irp
// The IOCTL IRP to handle
//
// Return Value:
// NT status code
//
NTSTATUS DriverB_SynDeviceIoControlDispatch(
IN PDEVICE_OBJECT DeviceObject,
IN PIRP Irp
)
{
PIO_STACK_LOCATION irpStack;
NTSTATUS status;
PDRIVERB_SYN_DEVICE_EXTENSION deviceExtension;
PVOID inputBuffer;
ULONG inputLength;
PVOID outputBuffer;
ULONG outputLength;
DriverB_SynDebugPrint(DBG_IO, DBG_TRACE, __FUNCTION__"++. IRP %p", Irp);
deviceExtension = (PDRIVERB_SYN_DEVICE_EXTENSION)DeviceObject->DeviceExtension;
// Get our IRP stack location
irpStack = IoGetCurrentIrpStackLocation(Irp);
// Get the buffer lengths
inputLength = irpStack->Parameters.DeviceIoControl.InputBufferLength;
outputLength = irpStack->Parameters.DeviceIoControl.OutputBufferLength;
switch (irpStack->Parameters.DeviceIoControl.IoControlCode)
{
case 0:
default:
status = STATUS_INVALID_DEVICE_REQUEST;
Irp->IoStatus.Status = status;
IoCompleteRequest (Irp, IO_NO_INCREMENT);
break;
}
DriverB_SynDebugPrint(DBG_IO, DBG_TRACE, __FUNCTION__"--. IRP %p STATUS %x", Irp, status);
return status;
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -