向Windows内核驱动中传递一个函数指针,使其在内核模式下执行

向Windows内核驱动中传递一个函数指针,使其在内核级执行。

这个例子是来自于张帆编写的《Windows驱动开发技术详解》第15章15.5节,P397-399页。首先注意这个例子有个错误:

	switch (code)
	{						// process request
		case IOCTL_KERNEL_FUNCTION:
		{
			KdPrint(("IOCTL_KERNEL_FUNCTION\n"));
			
			KernelFun* InputBuffer = (KernelFun*)pIrp->AssociatedIrp.SystemBuffer;

			//将应用程序提供的函数地址提供给驱动程序			
			KernelFun foo = *InputBuffer;

			//在内核模式下调用应用程序的函数
			int ret = foo();

			KdPrint(("ret = %d, out = %d\n", ret, cbout));
			memcpy(pIrp->AssociatedIrp.SystemBuffer, &ret, 4);

 			info = cbout;
			break;
		}
		default:
			status = STATUS_INVALID_VARIANT;
	}

少了个case分支中少了个break语句(上面已经加上了),这样会导致IRPTrace查看“IRP_MJ_DEVICE_CONTROL”返回时失败,注意这个细节的小问题。

应用层的调用方法:

//
//	首先定义要执行的函数
//
int KernelModeFunction()
{
	//运行在ring0
	//所以能执行IO操作
//	Out_8((PUCHAR)0x378,0);
	return 100+67;
}


//
//下面是DeviceIoControl调用
//
	DWORD dwOutput ;
	int  ret;

	//类似于Out_8((PUCHAR)0x378,0);
	DWORD Function_Address = (DWORD)KernelModeFunction;
	DeviceIoControl(hDevice, IOCTL_KERNEL_FUNCTION, 
		&Function_Address, 4, 
		&ret, 4, &dwOutput, 
		NULL);

这个示例很有借鉴意义:通过这个方法,能在应用层执行一些只有内核级才能执行的函数。

可以在这里下载张帆完整的《Windows驱动开发技术详解》光盘源码:http://pan.baidu.com/s/1sjJhjwp


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值