最近Win10比较火的一个蓝屏bug,谷歌浏览器输入\\.\globalroot\device\condrv\kernelconnect,就会导致电脑输入出现如下图所示蓝屏。好奇心突发,于是尝试用ie浏览器,却不会触发蓝屏。到底为什么呢?开始分析
data:image/s3,"s3://crabby-images/10a3c/10a3c15c8a91a37c9cf2bc25b70e462d75f8118c" alt=""
内核完整转储,然后Windbg分析一下
data:image/s3,"s3://crabby-images/cb7be/cb7be56af11f01fe7c23bbcae38f05a6f9bb80f7" alt=""
可以看到在condrv驱动里的派遣函数CdpDispatchCleanup发生了空指针引用,而后触发了蓝屏。
data:image/s3,"s3://crabby-images/2e5d5/2e5d536fc634f33c6660dac96c53dacad69a92ff" alt=""
查看栈调用,发现谷歌浏览器调用了GetFileAttributesExW函数,然后转入ntdll,接着走进了内核,然后调用了condrv的派遣函数。
data:image/s3,"s3://crabby-images/e7777/e77779e5aff9cd9fe62d12b5e4f911f3956f7c81" alt=""
将C:\Windows\System32\drivers\condrv.sys拖入IDA,查看函数,经过对应发现是走到如上图所示的代码,触发了蓝屏异常。
data:image/s3,"s3://crabby-images/2cb73/2cb73be201d7ac678b64c21c9308fa2960d51d66" alt=""
接下来是动态调试google浏览器,在KERNELBASE.GetFileAttributesExW下断点。看看传了哪些参数。
data:image/s3,"s3://crabby-images/3241c/3241cd1bc051235c5a9b796f7ce520d4ebea9484" alt=""
由此可以写代码复现了。rcx,rdx,r8三个参数。
[C++] 纯文本查看 复制代码
01 02 03 04 05 06 07 08 09 10 11 12 | // BSOD.cpp : 此文件包含 "main" 函数。程序执行将在此处开始并结束。 // #include <iostream> #include <Windows.h> int main() { WCHAR fileName[] = L "\\\\.\\globalroot\\device\\condrv\\kernelconnect" ; WIN32_FILE_ATTRIBUTE_DATA data; GetFileAttributesEx(fileName, GetFileExInfoStandard, &data); } |