- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
nt4源码剖析之nto严skrnl篇
TOC \o 1-3 \h \z \u HYPERLINK \l _Toc334642659 第一章 ntoskrnl PAGEREF _Toc334642659 \h 2
HYPERLINK \l _Toc334642660 一 系统启动 PAGEREF _Toc334642660 \h 3
HYPERLINK \l _Toc334642661 二 Idle进程 PAGEREF _Toc334642661 \h 6
HYPERLINK \l _Toc334642662 三 初始化内核 PAGEREF _Toc334642662 \h 7
HYPERLINK \l _Toc334642663 1 内核初始化综述 PAGEREF _Toc334642663 \h 7
HYPERLINK \l _Toc334642664 2初始化内核结构 PAGEREF _Toc334642664 \h 10
HYPERLINK \l _Toc334642665 3初始化进程对象 PAGEREF _Toc334642665 \h 11
HYPERLINK \l _Toc334642666 4初始化线程对象 PAGEREF _Toc334642666 \h 12
HYPERLINK \l _Toc334642667 5初始化执行体 PAGEREF _Toc334642667 \h 15
HYPERLINK \l _Toc334642668 6初始化硬件体系层 PAGEREF _Toc334642668 \h 18
HYPERLINK \l _Toc334642669 7初始化执行体组件 PAGEREF _Toc334642669 \h 21
第一章 ntoskrnl
Ntoskrnl程序位于private\ntos\init目录下,其入口有2个:ntkrnlmp.c、ntoskrnl.c,但ntkrnlmp.c只有一句代码:#include ntoskrnl.c,2个其实是1个。
ntoskrnl的主函数里仅仅调用了KiSystemStartup函数,ntoskrnl的入口函数还是要看KiSystemStartup函数了。
一 系统启动
KiSystemStartup函数
_KiSystemStartup函数的实现代码位于private\ntos\ke\i386\newsysbg.asm文件中。
这个模块是台湾的宗世麟(Shie-Lin Tzong (shielint))在1990年编写的,国立台湾大学82届资讯系毕业,他编写了nt4内核的X86汇编代码。(遐想:Windows内核代码居然有台湾人参与,但中国大陆却无人参与,可叹!难道中国只能开发应用软件,无人能做系统软件的开发吗?别跟我提那些只会做皮不会写瓤的中国Linux厂商。)
启用每个CPU时都会调用此函数,分2种情况:启动CPU、其他CPU,执行操作有细微不同。
CPU的数量保存在几个变量中(_KeNumberProcessors、KissPbNumber)。
CPU0使用的线程对象、堆栈空间是静态内存,线程对象(ETHREAD)是P0BootThread,堆栈空间是P0BootStack,大小03000H(12K)。
CPU0设置FS=KGDT_R0_PCR(030H)。
所有的CPU都调用KiInitializeMachineType函数获取机器类型,函数位于private\ntos\ke\i386\i386init.c文件中。
机器类型保存在加载参数块中(计算方法:KeLoaderBlock-u.I386.MachineType 0x000ff),各个字节的含义如下:
字节
含义
Byte 0
Machine Type, ISA, EISA or MCA
Byte 1
CPU type, i386 or i486
Byte 2
Cpu Step, A or B ... etc
Highest bit
indicates if NPX is present
调用GetMachineBootPointers函数获取相关的gdt、pcr、tss、idt地址,
调用sgdt指令加载gdt获取地址,通过FS保存的PCR选择子获取PCR地址,通过str指令加载TSS选择子获取TSS地址,通过sigt指令加载idt获取地址。
GDT中的TSS(28h) 描述符是16位的,需要修改为32位,初始化TSS,加载此TSS选择子到TR寄存器。
286CPU使用16位TSS格式。TSS描述符的第5个字节设置为89h(dpl=0, present, TSS32, not busy),则设置成了32位TSS。
初始化TSS分2种情况,1种
您可能关注的文档
最近下载
- 大麦EK318.操作手册.C01.220905.pdf
- 五马先生纪年.docx VIP
- 急救与心理技能(视频课)知到课后答案智慧树章节测试答案2025年春中南大学.docx VIP
- 应急救援员国家职业技能标准(2019年版).pdf VIP
- 场地设计作图题-一级建筑师场地设计(作图题)真题精选.docx VIP
- 小学环境教育:校园内水体污染调查与水质保护实践教学研究课题报告.docx
- 阿迪达斯(Adidas)品牌现状分析与二次增长战略规划.pptx
- 人教版七年级上册数学一元一次方程计算题及应用题.docx VIP
- 人教版2025八年级上册英语Unit3 same or different单元复习课件.pptx VIP
- 濒危古树评估与抢救保护技术规程.docx VIP
文档评论(0)