逆向脱壳之保护模式学习三 段描述符和段选择子

本文深入探讨了保护模式下的段描述符和段选择子。通过段选择子在全局描述符表(GDT)中定位段描述符,详细解释了段选择子的结构,包括索引、表指示器和请求特权等级。同时介绍了如何通过段选择子和GDT获取段描述符以实现内存寻址。最后,提到了段寄存器的加载及修改指令,并预告了后续将讨论的段描述符结构和剩余80位的填充问题。
摘要由CSDN通过智能技术生成

前言

先前了解了段寄存器,现在继续深入学习段寄存器


段描述符

引出问题

首先要解决的就是上个笔记遗留下来的问题:

mov bx,ds                //将段寄存器ds的Selector部分保存到bx(ecx的低16位)
mov ax,cs                //将段寄存器cs的Selector部分保存到ax(eax的低16位)
mov ds,ax                //将先前读出来的段寄存器去写ds这个段寄存器,也就是用cs段寄存器覆盖ds段寄存器

写寄存器是对整个96位的段寄存器进行修改,但是这里只给出了16位的段选择子Selector,剩下的80位呢


在回答问题之前,还需要了解两个结构:GDT(全局描述符表)和 LDT(局部描述符表)

为什么要了解这两张表?

因为当执行类似前面对段寄存器进行修改的指令:MOV DS,AX时,CPU会先查表,根据AX的值(段选择子)来决定查找GDT还是LDT

但在Windows中LDT并没有被使用,于是AX的值(段选择子)是用来决定查询表中的哪个位置


GDT

什么是GDT

GDT全称:Global Descriptor Table,为全局描述符表,表中存储的数据项为段描述符


GDT的数量

一个处理器对应一个GDT


定位GDT

大致了解了GDT是一张表,接下来则要定位到这张表,查看其内容

想要定位GDT表的位置,可以通过gdtr寄存器来定位

gdtr寄存器存储了GDT表的起始位置和GDT表的大小


通过windbg定位GDT

通过在windbg中输入下列指令查看有关GDT的信息:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

大神论坛

喜欢作者

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值