段选择符 段寄存器

突然在书上看到CSDSSSES叫做段选择符,不知所云,google了下,疑云终于解开:

8086中有416位的段寄存器:CSDSSSES,分别用于存放可执行代码的代码段、数据段、堆栈段和其他段的基地址。

80386中,有616位的段寄存器,但是,这些段寄存器中存放的不再是某个段的基地址,而是某个段的选择符(Selector)。因

16位的寄存器无法存放32位的段基地址,段基地址只好存放在一个叫做描述符表(Descriptor)的表中。因此,在80386中,我们把

段寄存器叫做选择符。下面给出6个段寄存器的名称和用途:

CS 代码段寄存器

DS 数据段寄存器

SS 堆栈段寄存器

ESFSGS 附加数据段寄存器

下面是对选择符和描述符的介绍:(来自:www.kerneltravel.net/kernel-book/%E7%AC%AC%E4%BA%8C%E7%AB%

A0%20Linux%E8%BF%90%E8%A1%8C%E7%9A%84%E7%A1%AC%E4%BB%B6%E5%9F%BA%E7%A1%80/2.3.5.htm

选择符与描述符表寄存器

在实模式下,段寄存器存储的是真实的段地址,在保护模式下,16位的段寄存器无法放32位的段地址,因此,它们被称为

选择符,即段寄存器的作用是用来选择描述符。选择符的结构如图2.16所示:

段选择符 段寄存器 - di_yang@yeah - 烟雨亭

图 2.16选择符的结构

可以看出,选择符有三个域:第15~3位这13位是索引域,表示的数

据为0~8129,用于指向全局描述符表中相应的描述符。第二位为

选择域,如果TI=1,就从局部描述符表中选择相应的描述符,如果TI=0,就从全局描述符表中选择描述符。第10位是

特权级,表示选择符的特权级,被称为请求者特权级RPL(Requestor Privilege Level)。只有请求者特权级RPL高于(

字低于)或等于相应的描述符特权级DPL,描述符才能被存取,这就可以实现一定程度的保护。

我们知道,实模式下是直接在段寄存器中放置段基地址,现在则是通过它来存取相应的描述符来获得段基地址和其它信

息,这样以来,存取速度会不会变慢呢?为了解决这个问题,386的每一个段选择符都有一个程序员不可见(也就是说程

序员不能直接操纵)88位(8*8+24)宽的段描述符高速缓冲寄存器与之对应。无论什么时候改变了段寄存器的内容,

只要特权级合理,描述符表中的相应的8字节描述符就会自动从描述符表中取出来,装入高速缓冲寄存器中(还有24位其

他内容)。一旦装入,以后对那个段的访问就都使用高速缓冲寄存器的描述符信息,而不会再重新从表中去取,这就大大

加快了执行的时间,如图2.17所示

段选择符 段寄存器 - di_yang@yeah - 烟雨亭

图 2.17 段描述符高速缓冲寄存器的作用

由于段描述符高速缓冲寄存器的内容只有在重新设

置选择符时才被重新装入,所以,当你修改了选

择符所选择的描述符后,必须对相应的选择符重新

装入,这样,88位描述符高速缓冲寄存器的内容才

会发生变化。无论如何,当选择符的值改变时,处理

器自动装载不可见部分。

下面讲一下在没有分页操作时,寻址一个存储器操作数的步骤:

1. 段选择符中装入16位数,同时给出32位地址偏移量(

比如在ESIEDI中等等)

2. 根据段选择符中的索引值、TIRPL值,再根据相

应描述符表寄存器中的段地址和段界限,进行一系列合

法性检查(特权级检查、界限检查),该段无问题,就

取出相应的描述符放入段描述符高速缓冲寄存器中。

4. 将描述符中的32位段基地址和放在ESIEDI等中的32位有效地址相加,就形成了32位物理地址。

注意:在保护模式下,32位段基地址不必向左移4位,而是直接和偏移量相加形成32位物理地址(只要溢出)。这样做

的好处是:段不必再定位在被16整除的地址上,也不必左移4位再相加。

寻址过程如图 2.18所示。

段选择符 段寄存器 - di_yang@yeah - 烟雨亭

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值