汇编网首页登录博客注册
masmaster的学习博客
博客首页博客互动【做检测题】论坛求助

我的博客

个人首页 |  我的文章 |  我的相册 |  我的好友 |  最新访客 |  文章收藏 |  论坛提问 |  友情链接 |  给我留言  
图片载入中
文章收藏

[2010-10-11 09:44] 任务状态段(1)

任务状态段(TaskStateSegment)是保存一个任务主要信息的特殊段。 任务状态段描述符用于描述这样的系统段,任务状态段寄存器TR的可见部分含有当前任务的任务状态段描述符的选择子,TR的不可见部分含有当前任务状态段的段基地址和段界限等信息。
    TSS在任务切换过程中起着主要的作用,通过它实现任务的挂起和切换。 所谓任务的切换是指,挂起当前正在执行的任务,恢复另外一个任务的执行。 在任务切换过程中,首先处理器中各寄存器的当前值被自动保存到TR所指定的TSS中,然后下一任务的TSS的选择子被装入TR;最后从TR所指定的TSS中取出各寄存器的值送到各个寄存器中。由此可见,通过在TSS...
阅读全文 | 评论次数(0) | 浏览次数(612) | 所属类型(汇编语言笔记)

[2010-10-09 17:14] 郁闷并纠结中

保护模式下, 太多的概念需要我去理解,可是我的脑子转速不够快容量不够大,唉, 啥时候能把这段学完呀。。。。。。郁闷纠结。。。...
阅读全文 | 评论次数(0) | 浏览次数(583) | 所属类型(杂七杂八)

[2010-10-08 10:42] 门描述符

除了存储段描述符和系统段描述符外,还有一类门描述符。
    门描述符并不描述某种内存段,而是描述控制转移的入口点。 这种描述符好比一个通向另一个代码段的门。 通过这种门,可实现任务特权级的变换和任务间的切换。因此,这种门描述符也称为控制门。
    
①门描述符的一般格式
    门描述符只有位于描述符内偏移5的类型字节与系统段描述符保持一致,也由该字节标识门描述符和系统段描述符。 该字节内的P位和DPL位的含义与其他描述符中的意义相同。其他字节主要用于存放一个48位的全指针(16位的选择子和32位的偏移量)

其数据结构如下:
GATE        STRUC
OFFSE...
阅读全文 | 评论次数(0) | 浏览次数(774) | 所属类型(汇编语言笔记)

[2010-10-07 10:31] 系统段描述符

系统段是为实现存储管理机制所使用的一种特别的段。 在80386中,有两种系统段:任务状态段TSS和局部描述符表LDT段。

①系统段描述符的一般格式:
    系统段描述符的格式与存储段描述符格式相似, 区分他们的标志是属性字节中描述符类型位DT的值。DT=1表示存储段;DT=0表示系统段。 系统段描述符中的段基地址和段界限字段与存储段描述符中意义完全相同;属性中G位,AVL位,P位和DPL字段的作用也完全相同,存储段中的D位在系统段中不使用。系统段描述符的类型字段TYPE仍然是4位,其编码以及表示的类型则与存储段描述符的类型完全不同。只有类型编码1,2,3,9和B的描述符才是真正的系统...
阅读全文 | 评论次数(0) | 浏览次数(797) | 所属类型(汇编语言笔记)

[2010-10-05 10:15] 实模式与保护切换实例

.386p                                        
assume                cs:codeseg,ds:dataseg        
;
jump                macro selector,offsetv        ;定义一条段间转移宏指令
                db 0eah                        ;jmp操作码
                dw offsetv                ;偏移
                dw selector                ;选择子
                endm

descriptor        struc                                ;存储段描述符结构定义
limitl                dw 0                        ;段界限
basel                dw 0                        ;段基地低16位
basem                db 0                        ;段基地址中8位
attrib                dw 0                        ;段属性(含段界限的高4位)
baseh...
阅读全文 | 评论次数(0) | 浏览次数(822) | 所属类型(汇编语言笔记)

[2010-10-04 10:17] 系统地址寄存器

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

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

PDESC    STRUC
LIMIT    DW    0
BASE     DD ...
阅读全文 | 评论次数(0) | 浏览次数(810) | 所属类型(汇编语言笔记)

[2010-10-02 10:27] 控制寄存器

80386有四个32位的控制寄存器,他们是:CR0、CR1、CR2和CR3。CR1保留,用于今后开房的处理器使用,在80386中不能使用CF1,否则将引起无效指令操作异常;CR0包含指示处理器工作方式 的控制位,包含启用和禁用分页管理机制的保护控制位,包含控制浮点协处理器操作的控制位;CR2和CR3由分页管理机制使用。CR0中的位5~位30及CR3中的位0~位11是保留位。必须置0。控制寄存器CR0的低16位等同于80286的机器状态字MSW。
    控制寄存器CR0中的位0用PE标记,位31用PG标记,他们分别控制分段和分页管理机制的操作。 所以,把它们成为保护控制位。PE用于控制分段管...
阅读全文 | 评论次数(0) | 浏览次数(558) | 所属类型(汇编语言笔记)

[2010-10-01 10:00] 段描述符高速缓冲寄存器

在实模式下,段寄存器含有段值,为访问存储器形成物理地址时,处理器引用相应的某个段寄存器得到段值。 
    在保护模式下,段寄存器含有段选择子。为访问存储器形成线性地址时,处理器要是用选择子所指定的描述符中的基地址等信息。 为了避免在每次存储器访问时,都要访问描述符表而获得对应的段描述符,从80286开始每个段寄存器都配有一个高速缓冲寄存器,称之为段描述符高速缓冲寄存器,对程序员是不可见的。每当把一根哦选择子装入到某个段寄存器时,处理器自动从描述符表中取出相应的描述符,把描述符中的信息保存在对应的高速缓冲寄存器中。此后在对该段访问时,处理器都使用对应高速缓冲寄存器中的描述符信息。而不再从描述...
阅读全文 | 评论次数(0) | 浏览次数(536) | 所属类型(汇编语言笔记)

[2010-09-30 09:57] 段选择子

在实模式下,逻辑地址空间中存储单元的地址由段值和段内偏移两部分组成。 在保护模式下,虚拟地址空间(相当于逻辑地址空间)中存储单元的地址由段选择子和段内偏移两部分组成。 与实模式相比,段选择子取代了段值。
    段选择子1长6位。其高13位是描述符索引(Index)。 所谓描述符索引是指描述符在描述符表中的序号。 段选择子的第2位是引用描述符指示位,标记为Ti,TI=0指示从全局描述符表GDT中读取描述符;TI=1指示从局部描述符表LDT中读取描述符。 选择子最低两位是请求特权级RPL,用于特权检查。
    选择子确定描述符,描述符确定段基地址,段基地址和段内偏移之和就是线性地址。 所以...
阅读全文 | 评论次数(0) | 浏览次数(1909) | 所属类型(汇编语言笔记)

[2010-09-29 09:46] 全局和局部描述符表

一个任务会涉及多个段,每个段都需要一个描述符来描述。 为了方便组织管理,80386把描述符组织线性表,由描述符组成的线性表称为描述符表。
    在80386中,有三种类型的描述符表:全局描述符表GDT;局部描述符表LDT和中断描述符表IDT。整个系统中,全局描述符表GDT和中断描述符表IDT只有一张,而局部描述符表可以有若干张。
    每个描述符表本身形成一个特殊的数据段。这样的特殊数据段最多可以含有8096个描述符。
    每个任务的局部描述符表LDT含有该任务自己的代码段、数据段和堆栈段的描述符,也包含该任务所使用的一些门描述符。随着任务的切换,系统当前的局部描述符表LDT也随...
阅读全文 | 评论次数(0) | 浏览次数(560) | 所属类型(汇编语言笔记)
页码数(28):  1  2  3  4  5  6  7  8  9  10   >>