一、在MFC中添加控制码,告诉驱动我们要进行的操作
#include <winioctl.h>
#define 写测试 CTL_CODE(FILE_DEVICE_UNKNOWN, 0x801, METHOD_BUFFERED,FILE_ANY_ACCESS)
#define 读测试 CTL_CODE(FILE_DEVICE_UNKNOWN, 0x802, METHOD_BUFFERED,FILE_ANY_ACCESS)
#define 读写测试 CTL_CODE(FILE_DEVICE_UNKNOWN, 0x803, METHOD_BUFFERED,FILE_ANY_ACCESS)
二、MFC代码实现
1、双击写操作按钮,通过DeviceIoControl函数进行操作
char 输入缓冲区指针[] = "我是写操作测试!!!";
int 返回缓冲区指针[] = { 0 };
DWORD 实际读取字节数;
DeviceIoControl(
设备句柄,
写测试,
&输入缓冲区指针,
sizeof(输入缓冲区指针),
&返回缓冲区指针,
sizeof(返回缓冲区指针),
&实际读取字节数,
NULL);
2、双击读操作按钮,通过
char 返回数据;
DWORD 实际读取字节数;
DeviceIoControl(
设备句柄,
读测试,
NULL,
0,
&返回数据,
sizeof(返回数据),
&实际读取字节数,
NULL);
char 缓存区[256];
sprintf_s(缓存区, "nxyn:读取到驱动内容:%s\n", 返回数据);
OutputDebugStringA(缓存区);
3、应用层通过驱动实现加法运算
写入的数据是3个整数
char 缓存区[256];
sprintf_s(缓存区, "nxyn:应用程序写测试控制为%X\n", 读写测试);
OutputDebugStringA(缓存区);
int 输入数据[] = { 1,2,3 };
int 返回数据;
DWORD 实际读取字节数;
DeviceIoControl(
设备句柄,
读写测试,
&输入数据,
sizeof(输入数据),
&返回数据,
sizeof(返回数据),
&实际读取字节数,
NULL);
sprintf_s(缓存区, "nxyn:读取到驱动内容:%d+%d+%d=%d\n", 输入数据[0], 输入数据[1], 输入数据[2],返回数据);
OutputDebugStringA(缓存区);
三、驱动层代码实现
1、写测试函数
void IRP写测试(PIRP IRP指针)
{
PIO_STACK_LOCATION 栈指针 = IoGetCurrentIrpStackLocation(IRP指针); //通过栈指针获取应用层传来的参数
char* 缓冲区 = (char*)IRP指针->AssociatedIrp.SystemBuffer;
KdPrint(("nxyn:应用层缓冲区写入驱动=%s", 缓冲区));
}
2、读测试函数
void IRP读测试(PIRP IRP指针)
{
char* 缓冲区 = (char*)IRP指针->AssociatedIrp.SystemBuffer;
char 返回数据[] = "我是来自驱动层的数据";
memcpy_s(缓冲区, 256, 返回数据, sizeof(返回数据));
IRP指针->IoStatus.Information = sizeof(返回数据);//设置操作的字节数
IRP指针->IoStatus.Status = STATUS_SUCCESS;//返回状态
IoCompleteRequest(IRP指针, IO_NO_INCREMENT);//完成一个IRP请求
KdPrint(("nxyn:IRP函数处理完毕"));
}
3、读写测试函数
int* 缓冲区 = (int*)IRP指针->AssociatedIrp.SystemBuffer;
int 计算结果=0;
if(缓冲区)
{
计算结果 = 缓冲区[0] + 缓冲区[1] + 缓冲区[2];
KdPrint(("nxyn:驱动层计算结果%d + %d + %d=%d", 缓冲区[0],缓冲区[1],缓冲区[2],计算结果));
}
*缓冲区 = 计算结果;
四、在IRP处理函数中调用
if (控制码==写测试)
{
IRP写测试(IRP指针);
}
else if (控制码 == 读测试)
{
IRP读测试(IRP指针);
return STATUS_SUCCESS;
}
else if(控制码 == 读写测试)
{
IRP读写测试(IRP指针);
}
五、查看效果