自己写IRP,做文件操作,遇到的坑

Posted suanguade

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了自己写IRP,做文件操作,遇到的坑相关的知识,希望对你有一定的参考价值。

在写文件的时候没问题,但是写完文件之后,就出问题了,

什么问题呢,是因为写完文件之后,文件关闭之后,

调用了一个叫做 CcFlushCache 的函数,这个函数是从CcWriteBehind 调过来的,

顿时懵逼了,什么情况,怎么会进入刷缓存的函数,和缓存有鸡毛关系,

这是我至少半年前的代码了,因为当初没有使用到这块,所以就没有测试这块,

结果现在要用,SB了,咋办,

看代码没啥问题啊。但是就是蓝屏,稳定蓝屏。

哎,

该谁的事,找谁去,

翻了一下ntoskrnl,找到了NtWriteFile函数,

其实这里已经看过好多次了,不说闭眼睛都知道流程,

至少也是和舅舅看外甥一样那么亲切了,

一行一行找,一个字一个字找,突然,

我看到了下面一行,图片中,红色一行。

there is a 1 flage,擦,都怪我当初太年轻,过于自信就没照抄这块代码,

结果IRP的Flages我写的是 IRP_WRITE_OPERATION ,就是少了那个 1, 导致最后又刷缓存去了,

但是我没有缓存操作,所以不存在缓存,所以刷不到,所以崩,

人生无奈,那个1 的英文名字叫。。。IRP_NOCACHE。。。

哈哈哈哈,人生都无奈得到头了,当初我就一个IRP_WRI 然后自动补全,就全了,

都没仔细看一眼标志位,结果导致人生出现了一堆插曲。。。

哎。拐了,拐了,结果把自己拐了。。。

当一个教训吧。。。人生无奈的教训。。。

记住这个1,英文名字叫 IRP 没缓存。 

 

 留个图片,祭奠伟大的Windows。

技术分享图片

 

以上是关于自己写IRP,做文件操作,遇到的坑的主要内容,如果未能解决你的问题,请参考以下文章

使用IRP进行文件操作

文件过滤驱动实现目录重定向good

python 在操作文件的时候,遇到的坑

Minifilter和IRP_MJ_DIRECTORY_CONTROL发布后操作

I/O管理器

xml 操作遇到的坑