RootKit基础学习

本文介绍了RootKit的基础知识,重点讲解了Ring0的概念,它是x86平台权限最高的层,通常用于运行系统内核和驱动。文章还探讨了Windows系统对Ring0和Ring3的使用,并详细阐述了内存管理和访问控制,包括全局描述符表(GDT)、本地描述符表(LDT)、中断描述符表(IDT)、系统服务调度表(SSDT)以及内存分页机制。通过对页目录、页表和页表项的解析,解释了虚拟地址转化为物理地址的过程。
摘要由CSDN通过智能技术生成

很多RootKit都是运行在Ring0层的,所以我们必须先了解Ring0是个什么东西。

其实Ring(环)就是x86平台进行访问控制的概念,Ring0层也叫作环0层,win平台下一共就有4个环,不用说肯定是Ring0,Ring1,Ring2,Ring3了,权限最高的就是Ring0层,也叫做内核层,权限最低的就是Ring3层了呀,也叫作用户层。Windows系统就仅仅使用了Ring0层和Ring3层,试想Windows系统用4个环来实现访问控制那么难度大大上升了。内核层权限运行系统内核和驱动程序,而用户层权限运行普通程序。当一个程序执行的时候系统会分配一个环编号,环编号高的程序不能直接访问环编号低的程序,就是Ring3层的程序不能访问Ring0层的程序,当然除了程序外还有汇编语言,有的汇编指令也是需要Ring0权限的。

就比如读写硬件端口的in,out指令和控制CPU状态的cli,sti指令。

除了需要了解Ring0层概念,还需要了解关键表的概念。

CPU除了使用Ring分层机制进行访问限制外还需要对正在运行的代码进行管理控制。发出中断,程序崩溃,发出硬件信号都是有的CPU处理的而不是系统,所以CPU要实现这些功能就必须维护管理很多数据,而这些数据一般都是以表的形式存放的,这些表如下:

1.全局描述符表,英文全称Global Descriptor Table,简称GDT,有且仅有一个,用于映射内存地址。

2.本地描述符表,英文全称Local Descriptor Table,简称LDT,也是用于映射内存地址。

3.页目录,英文全称Page Directory,也是用于映射内存。

4.中断描述符表,英文全称Int

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值