- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
项目工程类经典参考学习文献
项目工程类经典参考学习文献
标题:【原创】rootkitring3进ring0之门系列[一]--调用门
作者:combojiang
时间:2008-03-31,14:52
链接::showthread.php?t=62263
今天我们来谈谈保护模式下的调用门。从而开始了我们的门系列内容。
先谈谈程序转移.,程序转移分为两种:?近转移和远转移?,其中近转移中又分为相对地址转移和绝对地址转移.?而远转移只有绝对地址转移.。可以通俗的讲,cs发生变化的转移称为远转移,cs不变的转移,我们称为近转移。例如:windows??ring3下cs是0x1b?,?ring0下cs通常是0x08.。?对于近转移,我们不需要进行特权级检查。由于windows是保护模式的操作系统,对于远转移如果跨层则需要进行特权级检查,看是否允许其调用。
为了在不同特权级的代码段之间进行控制访问,处理器特别提供了一组称为门描述符的描述符。我们可以通过这组门描述符中的任何一个进行远转移。门提供了受保护的间接调用,为任务内的特权转移提供了安全可靠的方法。
今天我们讲的调用门,就是这组门描述符中的一个。为了搞清楚调用门,我们需要看下调用门描述符的结构:
对应的结构体是:
????typedef?struct
????{
????????unsigned?short??offset_0_15;
????????unsigned?short??selector;
????????unsigned?char????param_count?:?4;
????????unsigned?char????some_bits???:?4;
????????unsigned?char????type????????:?4;
????????unsigned?char????app_system??:?1;
????????unsigned?char????dpl?????????:?2;
????????unsigned?char????present?????:?1;
????
????????unsigned?short??offset_16_31;
????}?CALLGATE_DESCRIPTOR;?
调用门描述符可以放在GDT、LDT中,但是不能放在IDT中。在WINDOWS?XP中,没有LDT.
在这里,我们举例说明其在GDT中的情况。尽管windows提供了多种不同的描述符,但是每种描述符中都有present位代表该描述符是否存在。它在每个描述符中的位置都是一样的,因此我们可以根据这个present位来在GDT中找出一个空白位置,在这个位置里面添加我们自己定义的描述符。内核中GDT的位置,我们可以用WINDBG看下:
lkd?!PCR
KPCR?for?Processor?0?at?ffdff000:
????Major?1?Minor?1
??NtTib.ExceptionList:?b1fa5c7c
??????NtTib.StackBase:?b1fa5df0
?????NtTib.StackLimit:?b1fa2000
???NtTib.SubSystemTib:????????NtTib.Version:????NtTib.UserPointer:????????NtTib.SelfTib:?7ffde000
??????????????SelfPcr:?ffdff000
?????????????????Prcb:?ffdff120
?????????????????Irql:??????????????????IRR:??????????????????IDR:?ffffffff
????????InterruptMode:??????????????????IDT:?8003f400
??????????????????GDT:?8003f000
??????????????????TSS:
????????CurrentThread:???????????NextThread:???????????IdleThread:?80552d20
可以看到我本机GDT的位置是?GDT:?8003f000
调用门的工作原理如图所示。
首先进行特权检查
根据selector,在GDT中找出CS段的范围。
根据offset_0_15和offset_16_31求出段中的偏移。
跳转到地址中执行。
特权检查需要检查的
您可能关注的文档
最近下载
- 阿里斯顿VL70VH3.0EVOAG+WH说明书.pdf
- GB50154-2009地下及覆土火药炸药仓库设计安全规范.docx VIP
- 软质岩岩土工程勘察技术标准DB62_T 3285-2024.docx VIP
- 《JJG1006-2005-煤中全硫测定仪检定规程》.pdf
- 华中师范大学841有机化学2018年考研真题.pdf VIP
- 高质量数据集 建设指南.pdf
- 新12J07室外工程-标准图集.docx VIP
- 基于PLC的全自动洗衣机控制系统设计.docx VIP
- KDOQI血液透析充分性临床实践指南2015更新版-开始血液透析的时机解读.pdf VIP
- T CALC 09—2025 免陪照护服务基本规范.pdf VIP
原创力文档


文档评论(0)