2536|0

81

帖子

0

TA的资源

一粒金砂(初级)

楼主
 

关于SSDT HOOK后通过事件通知应用程序问题 [复制链接]

关于SSDT HOOK后通过事件通知应用程序问题


HOOK SSDT应该没有问题通过DbgPrint在自己的函数中显示被HOOK的信息一切正常但是通过事件通知应用程序时却有时候会蓝屏
驱动:
在列程序IRP_MJ_WRITE中
通过
RtlCopyMemory(&hEventApp,Irp->AssociatedIrp.SystemBuffer,4);
ObReferenceObjectByHandle(hEventApp,EVENT_MODIFY_STATE,*ExEventObjectType,Irp->RequestorMode,(PVOID*) &pEventApp,NULL);
得到用户应用程序传来的事件对象指针
然后在自己定义用来代替被HOOK的函数的函数里用如下代码激发事件
if(pEventApp!=NULL)
{
            
    KeSetEvent(pEventApp, IO_NO_INCREMENT, TRUE);
    KeClearEvent(pEventApp);
}
======================================================================
应用程序:
hShareE = CreateEvent(NULL,TRUE,FALSE,"jwtEvent");//创建事件
DWORD t;
HANDLE fh = CreateFile("\\\\.\\jwtddk", GENERIC_READ | GENERIC_WRITE, 0, NULL, OPEN_EXISTING, 0, NULL);
WriteFile(fh,&hShareE,4,&t,NULL);//将事件句柄传到驱动中

然后在应用程序中创建一个线程等待事件发生代码如下:
UINT __cdecl mySingle( LPVOID pParam )
{  
  while(1)
  {
    //阻塞等待
   
    WaitForSingleObject((HANDLE) pParam,INFINITE);
        //通知用户
    AfxMessageBox("jwt Event!");//这句写与不写有时候均出线蓝屏
  }
return 0;
}

请大侠赐教
点赞 关注

回复
举报
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/8 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表