系统地址寄存器 系统地址寄存器gdtr

全局描述符表GDT、局部描述符表LDT和中断描述符表IDT等都是保护模式下非常重要的特殊段。 他们包含有对段机制所用的重要表格。 为了方便定位这些段,处理器采用一些特殊的寄存器保存这些段的基地址和段界限。 这些特殊的寄存器就是系统地址寄存器。

①全局描述符表寄存器GDTR

全局描述符表寄存器长48位,其中高32位含基地址,低16位含段界限。由于GDT不能由其本身之内的描述符进行描述定义,所以处理器采用GDTR为GDT这一特殊的系统段提供一个伪描述符。利用结构类型定义伪描述符如下:
系统地址寄存器 系统地址寄存器gdtr

PDESC STRUC

LIMIT DW 0

BASE DD 0

PDESC ENDS

GDTR中的段界限以字节为单位。 由于段选择子中只有13位作为描述符索引,而每个描述符长8个字节, 所以用16位表示GDT的界限就足够了。通常对于含有N个描述符的描述符表的段界限赢设置为8*N-1

②局部描述符表寄存器LDTR

局部描述符寄存器LDTR规定当前任务使用的局部描述符表LDT。LDTR类似段寄存器,由可见的16位寄存器和不可见的告诉缓冲寄存器组成。 实际上,每个任务的局部描述符表LDT作为系统的一个特殊段, 由一个描述符描述,而用于描述LDT的描述符存放在GDT中。 在初始化或者任务切换中,把指示描述对应任务LDT的描述符的选择子装入LDTR,处理器根据装入LDTR可见部分的选择子,从GDT中取出对应的描述符,并把LDT的基地址和段界限等信息保存到LDTR的高速缓冲寄存器中。 随后对LDT的访问,就根据保存在高速缓冲寄存器中的相关信息进行合法性检查。

LDTR寄存器包含当前任务的LDT的选择子。 所以, 装入到LDTR的选择子必须确定一个位于GDT的类型为LDT的系统段描述符, 也即选择子中的TI必须是0,而且描述符中的类型字段所表示的类型必须是LDT。

可以用一个空选择子装入LDTR,这表示当前任务没有LDT。 在这种情况下,所有装入到段寄存器的选择子都必须指示GDT中的描述符,也即当前任务涉及的段都由GDT中的描述符来描述, 如果再把一个TI=1的选择子装入段寄存器,将引起异常。

③中断描述符寄存器IDTR

中断描述符表寄存器IDTR指向中断描述符表IDT。IDTR长48位,其中32位规定的基地址规定IDT的基地址,16位的界限规定IDT的段界限。由于80386只支持256个中断/异常,所以IDT表最大长度2K,以字节为单位的段界限为7FFH。IDTR指示IDT表的方式与GDTR指示GDT的方式相同。

④任务状态段寄存器TR

任务状态寄存器TR包含指示描述当前任务的任务状态段的描述符选择子,从而规定了当前任务的状态段。TR也分为可见的和不可见两部分。当把任务状态段的选择子装入TR可见部分时,处理器自动把选择子所索引的描述符中的段基地址等信息保存在不可见的高速缓冲寄存器中。 装入到TR的选择子不能为空,必须索引位于GDT中的描述符,切描述符类型必须是TSS。

  

爱华网本文地址 » http://www.aihuau.com/a/25101012/144638.html

更多阅读

MCS-51单片机有几个工作寄存器? 单片机特殊功能寄存器

工作寄存器有4组,每组都是8个工作寄存器R0~R7,通过PSW中的RS1、RS0两位来选择使用哪一组,如果不选,默认是选择第0组。RS1RS0组合为00时,选中第0组工作寄存器,R0~R7地址为00H~07H;RS1RS0组合为01时,选中第1组工作寄存器,R0~R7地址为08H~0FH;RS1

寄存器间接寻址 间接寻址的有效地址

在S7-300PLC中有两个专门存放地址的寄存器AR1和AR2通过这两个寄存器进行寻址的方式我们称之为寄存器间接寻址1、内部区域寄存器间接寻址1) 存储格式交叉区域寄存器间接寻址在地址寄存器中的排列可分为三个区域,分别是存储位信息的区

arm定义了的各寄存器地址 arm ip 寄存器

#ifndef __44B0X_H__#define __44B0X_H__#ifdef __cplusplusextern "C" {#endif#include "option.h"//定义了44b0的系统配置寄存器#definerSYSCFG(*(volatile unsigned *)0x1c00000)//定义了44b0中2个不可作为Cache存储区的

寄存器相关理解 寄存器

Register)是CPU内部的元件,所以在寄存器之间的数据传送非常快。用途:1.可将寄存器内的数据执行算术及逻辑运算。2.存于寄存器内的地址可用来指向内存的某个位置,即寻址。3.可以用来读写数据到电脑的周边设备。8086 有8个8位数据寄存器,这

寄存器变量 c语言变量类型

C语言提供了另一种变量,即寄存器变量。这种变量存放在CPU的寄存器中,使用时,不需要访问内存,而直接从寄存器中读写,这样可提高效率。寄存器变量是个临时变量,当调用完之后,会自动释放,以节约内存空间,提高程序效率。寄存器变量没有地址,没有

声明:《系统地址寄存器 系统地址寄存器gdtr》为网友慢性偏执小怪人分享!如侵犯到您的合法权益请联系我们删除