上周在XP系统上测试一个驱动的时候,发现驱动加载不上,“net start”命令只是给出一个无意义的错误代码,驱动的DriverEntry()入口程序还没有得到机会运行。
初步怀疑是引入函数的问题,用WDK工具Depends.exe查看了一下驱动文件,果然是由于_chkstk函数无法解析所导致。
_chkstk是个微软C编译器的辅助库函数,MSDN上对其介绍十分简略:
_chkstk Routine is a helper routine for the C compiler. For x86 compilers, _chkstk Routine is called when the local variables exceed 4096 bytes; for x64 compilers it is 8K.
当编译器察觉到局部变量太大超过限值时(X86系统限值是4K,X64t系统上是8K), 编译器会自动插入_chkstk这个函数以保证栈空间所使用页面在内存中。
问题是发现了,但要查出来究竟在哪个函数中还是要费些心思的。从用户层移植过来不少代码,基本锁定问题出在其中,但如果一个函数一个函数寻找实在是个不讨巧的笨办法,也不符合程序人的一贯风格,便用IDA反编译驱动sys文件,于汇编代码中搜索_chkstk字串,直接锁定出了问题函数。此函数所使用的一个结构体中定义了超大数组,对栈的超常使用在内核中是相当危险的。
解决办法很简单,直接将此结构的定义放在一个从内存分配的结构中即可。问题虽已解决,但对于DDK中有关_chkstk的描述,及其相关的疑问一直让我觉得困扰,比如,为什么X86上是4K,而AMD64架构上可以是8K。
这两天终于有了时间,可以彻底地了结这个疑问了。
要想解决这个问题,还要先从用户栈的分配开始。以ReactOS代码为例,当线程创建时,CreateThread()会调用BasepCreateStack()来创建用户栈,具体可以参见ReactOS源码:
~/ReactOS/lib/kernel32/misc/utils.c。
BasepCreateStack()函数主要做三件事:
- 1,分配栈空间所需的虚拟内存,大小为Stack Reserve Size
- 2,根据Stack Commit Size锁定内存页面,如果Stack Commit Size小于Stack Reserve Size的话,需要增加一个Page,这个额外申请的Page用作Guard Page之用。
- 3,将栈底部的Page设定为Guard Page。
当用户栈被用尽时,会访问到栈底部的Guard Page。而对Guard Page的任何访问都会导致Page Fault的发生。Page Fault处理函数MmAccessFault()可以分析出此次Page Fault是由Guard Page导致,便会默认由用户栈处理程序MiCheckForUserStackOverflow()来处理。如果用户栈并没有溢出的话,即Stack Commit Size小于Stack Reserve Size的情况,MiCheckForUserStackOverflow()会自动向下扩展栈空间,扩展大小为GUARD_PAGE_SIZE。 GUARD_PAGE_SIZE针对不同的CPU架构有不同的定义:
X64: #define GUARD_PAGE_SIZE (PAGE_SIZE * 2)
X86: #define GUARD_PAGE_SIZE PAGE_SIZE
这里便解释了为什么X86系统上的限制是4K(即PAGE_SIZE),而X64上却为8K的原因。
说到此处,该是解答_chkstk()倒底是干什么的时候了。Visual Studio中有_chkstk的源码,以x86为例:
输入参数eax是所需堆栈大小(字节)
labelP _chkstk, PUBLIC
push ecx ; save ecx
cmp eax,_PAGESIZE_ ; more than one page requested?
lea ecx,[esp] + 8 ; compute new stack pointer in ecx
; correct for return address and
; saved ecx
jb short lastpage ; no
;------------
probepages:
sub ecx,_PAGESIZE_ ; yes, move down a page
sub eax,_PAGESIZE_ ; adjust request and...
test dword ptr [ecx],eax ; ...probe it (如果是guard page,刚会导致page fault,最终用户栈
; 将向下扩展一个页面)
cmp eax,_PAGESIZE_ ; more than one page requested?
jae short probepages ; no
lastpage:
sub ecx,eax ; move stack down by eax
mov eax,esp ; save current tos and do a...
test dword ptr [ecx],eax ; ...probe in case a page was crossed
; 调用函数将要访问的堆栈底部 ,如果此页面为guard page,同
; 样会导致用户栈的向下延伸
mov esp,ecx ; set the new stack pointer
; 向下更改栈指针,其上直到原ESP的栈空间为调用函数局部变量
mov ecx,dword ptr [eax] ; recover ecx
mov eax,dword ptr [eax + 4] ; recover return address
; 将返回地址(调用函数中)放入eax
push eax ; prepare return address
; 将返回地址(调用函数中)放入当前栈中,准备返回
; ...probe in case a page was crossed
ret
end
_chkstk()的主要作用是保证栈向下连续的生长。如果没有_chkstk(),当局部变量太多并超过guard page下沿时,若再有压栈操作,将会导致Access violation错误。因为此时堆栈内存页面无效,压栈直接将导致page fault的发生,而page fault处理程序因不能识别此fault的发生原因从而不能做出正确判断和有效处理。
相对用户层,内核程序的处理则相当简单,就如Win7内核中_chkstk实际上就是个空函数。其原因就是内核线程的栈空间是固定的。其取值针对X86及X64架构亦有所不同:
X64: #define KERNEL_STACK_SIZE 0x6000 /* 6个内存页面 */
X86: #define KERNEL_STACK_SIZE 12288 /* 3个内存页面 */
内核中栈资源非常紧缺,并驱动程序的编写有较高的要求,特别是有递归的情况下,一定要注意嵌套的层数,否则很容易收到M$发来的蓝屏。
Windows内核中其实还有一种大堆栈机制,以确保一些对堆栈较高消耗的特殊情况能够得到满足,但这部分完全是黑箱,对用户不可见,不是常见情况,此处不再多述。
参考资料:
1, http://support.microsoft.com/kb/100775/en
2, http://msdn.microsoft.com/en-us/library/ms648426(v=vs.85).aspx
3, http://www.reactos.org ReactOS源码
Только свежие актуальные новости свежие новости политики, экономики, общества и технологий. Актуальные события, аналитика, обзоры и мнения экспертов. Следите за главными новостями страны и мира онлайн в удобном формате каждый день.
instalacja mostbet mostbet2004.help
мелбет лучшие слоты http://www.melbet64019.help
Строительные технологии https://universalstroi.su выгодные инвестиции в доступное жилье. Стабильный доход, перспективные проекты и высокий спрос. Получайте прибыль от инновационных решений в строительстве.
Монтажные работы https://montazhstroy.su услуги по установке инженерных систем и конструкций. Быстро, качественно и с гарантией. Выполняем задачи любой сложности для частных и коммерческих объектов.
mostbet jak usunąć konto mostbet jak usunąć konto
mostbet aviator oyini http://mostbet47183.help/
melbet Казахстан вход https://melbet15709.help
pin up slot yutuq yechish pin up slot yutuq yechish
Думаю попробовать SMM, пока собираю варианты — вот один из них: https://iwatt24.ru/uslugi-smm/
Монтажные работы https://montazhstroy.su услуги по установке инженерных систем и конструкций. Быстро, качественно и с гарантией. Выполняем задачи любой сложности для частных и коммерческих объектов.
убрать задний фон ии: https://vc.ru/aihub/2842596-kak-ubrat-fon-s-foto-neyrosetyu
акт приема ответственное хранение сколько стоит ответственное хранение
мелбет free bet киргизия мелбет free bet киргизия
1win apk Perú http://1win05634.help/
melbet kz линия футбол сегодня http://www.melbet15709.help
Всем привет! Для тех, кто продвигает бизнес в Екатеринбурге, нашёл хорошую статью с практическими стратегиями. Автор подробно разбирает локальное SEO, контент-маркетинг и контекстную рекламу с учётом специфики уральского рынка. Особенно полезен раздел про работу с отзывами и геотаргетинг. Рекомендую: https://avto-dom-tumen.ru/stati/prodvizhenie-sajtov-v-ekaterinburge-jeffektivnye-strategii-dlja-uspeshnogo-onlajn-prisutstvija/
mostbet lustro polska http://mostbet2004.help
мелбет кз ios app https://www.melbet15709.help
ответственное хранение тмц стоимость ответственного хранения груза
мелбет сайт https://melbet15709.help
melbet логин https://melbet15709.help/
mostbet plinko turnir mostbet plinko turnir
Сам уже несколько месяцев использую накрутку ПФ, но статья всё равно дала новую пищу для размышлений. Особенно понравился раздел про синергию с другими каналами: накрутка снижает стоимость клика в Директе на 20–40%, увеличивает брендовый трафик на 30–100% и ускоряет классическое SEO. Автор также объясняет косвенный эффект на Google — через улучшение внутренних поведенческих факторов. Очень глубокая аналитика. Рекомендую: https://yagla.ru/blog/drugoe-o-marketinge/nakrutka-povedencheskih-faktorov-v-2026–2604u119831/
1win póker 1win póker
mostbet elektron tolov https://mostbet47183.help
Капсульный дом оказался очень удобным решением для небольшого участка. Пространство организовано грамотно. Внутри комфортно даже при длительном проживании. Установка прошла быстро. Очень довольны: капсульный дом контейнер
mostbet ozbek operator https://mostbet47183.help
мелбет кз официальный сайт зеркало melbet15709.help
mostbet sayt ochilmayapti mostbet sayt ochilmayapti
mostbet payme yechish https://mostbet47183.help/
1 win https://1win05634.help/
Ищете надежную юридическую помощь? Рейтинг лучших юристов поможет быстро найти проверенных специалистов с высоким уровнем экспертизы и успешной практикой. Переходите по запросу список лучших адвокатов. В подборке — профессионалы, которым доверяют клиенты, с реальными отзывами и подтвержденной репутацией. Выбирайте юриста для решения любых правовых вопросов уверенно и без лишних рисков.
This site really has all the info I wanted about this subject and didn’t know who to ask.
https://teletype.in/@avtobloggerua/B8-lsvQ4Hyu
мелбет букмекер Казахстан мелбет букмекер Казахстан
mostbet depozit muammo payme http://mostbet47183.help
melbet kaspi вывод http://www.melbet15709.help
mostbet tez ochiladigan sayt http://mostbet47183.help
мелбет кз бонус за регистрацию мелбет кз бонус за регистрацию
Great blog here! Also your web site loads up very fast! What host are you using? Can I get your affiliate link to your host? I wish my website loaded up as fast as yours lol
pin-up sport bonus kod https://pinup08694.help/
Do you mind if I quote a couple of your articles as long as I provide credit and sources back to your webpage? My blog site is in the very same niche as yours and my users would definitely benefit from a lot of the information you present here. Please let me know if this okay with you. Thanks a lot!
1win app casino android https://1win05634.help
melbet kz ставки на виртуальный спорт http://www.melbet15709.help
1win cambiar idioma http://www.1win05634.help
pin-up bonus Oʻzbekiston http://pinup08694.help/
ответственное хранение приказ стоимость ответственного хранения
1win cashback Perú http://1win05634.help/
pin-up sayt ochilmayapti https://www.pinup08694.help
аренда ответственное хранение услуги ответственного хранения