WINDOWS 7 RC 7100 GDI驱动Win32k.sys内核D.O.S漏洞

- AV AC AU C I A
发布: 2025-04-13
修订: 2025-04-13

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,进入共享临界区...

0%
暂无可用Exp或PoC
当前有0条受影响产品信息