WINDOWS 7 RC 7100 GDI驱动Win32k.sys内核D.O.S漏洞
感谢:Iceboy发现此问题并提供DUMP
漏洞厂商及产品:Microsoft Windows 7 rc 7100 090421
存在漏洞组件:win32k.sys Timestamp :49ee8dc8
存在漏洞函数:NtUserGetDc/NtUserGetDcEx
漏洞描述:Win32k.sys是WINDOWS的GDI驱动程序,包含大量复杂的图形界面处理,由于其中大量代码是从WIN3.1中修改过来,因此成了WINDOWS漏洞多发之地。
这个漏洞主要是因为Windows 7 在其NtUserGetDc/NtUserGetDcEx函数中(也许不仅仅是这两个函数)不正确地使用了共享临界锁,导致了任何权限下的GDI程序可以引发内核BSOD,从而进行DOS攻击
漏洞分析:
在WINDOWS VISTA中,在这两个函数进入前,会调用UserEnterUserCirtSec,进入临界区,同时会将gptiCurrent设置为当前线程的WIN32THREAD
UserEnterUserCritSec的实现如下:
PWIN32THREAD UserEnterUserCritSec()
{
PWIN32THREAD pwin32Thread;
pwin32Thread = ExEnterPriorityRegionAndAcquireResourceExclusive(gpresUser);
gptiCurrent = pwin32Thread;
gbValidateHandleForIL = 1;
return pwin32Thread;
}
ExEnterPriorityRegionAndAcquireResourceShared是NTOSKRNL 导出一个提供给WIN32K使用的共享资源锁函数,这个函数将共享锁住gpresUser这个资源,同时返回当前线程的Win32Thread,即 KeGetCurrentThread->Win32Thread
同时内核函数ExEnterPriorityRegionAndAcquireResourceExclusive也与其类似。
(XP则是调用KeEnterCriticalRegion后,用ExAcquireResourceExclusiveLite锁住 gpresUser,然后用PsGetCurrentThread->PsGetThreadWin32Thread获得当前线程 win32kthread,存放到gptiCurrent)
而在windows 7 中,这两个函数进入前,改为了调用UserEnterSharedCrit,进入共享临界区
UserEntrySharedCirt的实现很简单
PWIN32THREAD EnterSharedCrit()
{
return ExEnterPriorityRegionAndAcquireResourceShared(gpresUser);
}
可以注意到,这里并不设置gptiCurrent,事实上,NtUserGetDc/NtUserGetDcEx会将这个函数保存在寄存器中以便使用CurrentWin32Thread中存放的数据
从关键临界转为共享临界,无疑这样的修改将提升NtUserGetDc/NtUserGetDcEx的效率,减少了锁竞争的可能,但是在这里这样修改是错误的.
因为在共享临界中,没有修改gptiCurrent,那么就很可能遇到gptiCurrent非法的状态,比如遇到一个没有做PsConvertToGuiThread的线程导致了gptiCurrent为空.
WIN32K中有大量内部例程(经常以zzz,xxx开头),他们都认为在调用自己之前,gptiCurrent是一个有效的状态。这其中就包括了xxxDestoryWindow
一个BSOD的例子是:NtUserGetDc->GetWindowDc->GetDcEx->SpbCheckDce->SpbCheckRect->SpbCheckRect2->FreeSpb
调用到FreeSpb时,这里要释放一个spb对象了
接着就到
FreeSpb->HMAssigmentUnlock->HMUnlockObject->HMUnlockObjectInternal->HMDestroyUnlockedObject, 最终调用到了ganti表中的函数,由于这里是GetWindowDc,所以将调用xxxDestroyWindow,xxxDestroyWindow 第一句代码就无检查引用了gptiCurrent指针中的数据,自然直接导致BSOD
解决方案:
等待微软更新官方补丁.
微软可能的更新手段:
牺牲效率将NtUserGetDc等中的不正确共享锁替换为关键临界锁,或者将所有NtUserGetDc等函数可能用到的内部函数中的gptiCurrent引用去掉或换为不引用gptiCurrent的其他函数
相关文章

深度花园 Ghost Windows7 旗舰装机版 2010(附可激活工具)
本系统以适合电脑公司和维护人员快速装机为目的,以微软090602官方发布的Windows XP SP3免激活VOL原版为母盘,精心制作而成,采用微软内部封装技术,实现Longhorn的detecth2010-04-06Windows Vista Ultimate SP1简体中文精简ghost极速安装版下载
2008-09-08windows2003 IIS占用CPU资源100%的解决办法
机器正在调试或允许IIS时,被异常中断服务(比如停电),然后再次IIS运行页面时,CPU资源占用100%,即使重新启动也无效2008-09-08- 抵制微软,支持开源。Ubuntu是从Debian Linux派生出来的Linux操作系统发布包。每6个月发布新的版本。使用 APT 包管理系统优雅地解决了依赖问题,并且可以从容的在线安装升级2008-11-03

QQ电脑管家 2合1杀毒版 v8.4(10040) 全面兼容windows8 中文官方安装版
QQ电脑管家安全保护全面可靠可查杀能力全面升级,云查杀和可疑智能检测技术二合一,强力查杀各类流行木马。2013-09-04- 1、下载工具包: FSWpart http://www.genunix.org/distribut ... iles/FSWpart.tar.gz FSWfsmisc http://www.genunix.org/distribut ... es/FSWfsmisc.t2008-09-08

竹林蹊径 深入浅出Windows驱动开发 张佩等著 中文 PDF版 [106M]
本书是作者根据多年的工作学习经验,总结的第一手驱动开发资料。本书更多的是经验之谈,一些实践中的小发现小意外,颇为书中内容添彩。2012-11-21- SQLiteManager是一个支持多国语言基于Web的SQLite数据库管理工具。它的特点包括多数据库管理,创建和连接;表格,数据,索引操作;视图,触发器,和自定义函数管理。数据导2012-02-27
- WINDOWS7-7100RC简体中文纯净安装版封装时用了最先进的工具,所以镜像大小:2.43G 说明一下几点: 想装双系统或多系统用这个最合适 1、本镜像由于制作时间短,安装过程2009-07-13
- 据国外媒体报道,微软新操作系统Windows 7发布期限日益临近,业内分析师认为Windows 7虽然承载了许多期望,但是它要想获得成功还必须解决下面一些问题.2009-10-18





最新评论