TSS的数据结构:
TASKSS STRUC
DW ?,0 ;链接字
DD ? ;0级堆栈指针
DW ?,0
DD ? ;1级堆栈指针
DW ?,0
DD ? ;2级堆栈指针
DW ?,0
DD ? ;CR3
DD ? ;EIP
DW ?,? ;EFLAGS
DD ? ;EAX
DD...
- [somniumchase] 我一运行就说没有数字 01/01 11:44
- [游客] 为什么啊 08/07 15:36
- [游客] 如果想快一些 就改下面这里 dx值改成1H delay: push ax 04/19 02:53
- [lshhjx] 注释在程序中很重要,楼主不知道吗? 12/08 13:40
- [biaggi] 看不明白,在下還須學習 11/06 08:11
- [游客] 我运行的时候直接显示Unkown filename跳出了- -请问怎么改 06/16 21:44
- [游客] 勿庸置疑,注释是好习惯。与人方便自己方便。 04/12 10:33
- [游客] 老实说,看着真心累呀! 04/07 18:37
- [游客] 很无语,初学者就多看书,不要动不动要别人注释,基础打好了,再自己注释,这样比别人帮你注释好得多 12/17 19:43
- [dgkepu] 初学者:不懂,希望有多点注释带着学习学习! 12/07 20:52
- [游客] windows 7是一个64Bit操作系统,它不兼容DOS,无法识别16Bit系统。重装系统wind 02/28 21:05
- [游客] windows 7是一个64Bit操作系统,它不兼容DOS,无法识别16Bit系统。重装系统wind 02/28 21:05
- [466987333] 你好,高手,我想请教一个问题。 我用的是win7操作系统,32位的,里面没有找masm目录,是不是 12/12 17:30
- [lanfioncc] 那个太高级了。。。我还有点看不懂。。不过谢谢!!! 11/27 11:23
- [yc2010] 实验16中的 table: dw sub1,sub2,sub3,sub4 可不可以改成呢? 09/11 09:08
- [yc2010] mov bl,ah mov bh,0 add bx,bx ----------->这里为 09/07 21:03
- [yc2010] 为什么要add bx,bx呢? 09/07 20:55
- [yc2010] 那是不是像table[bx],ds[bx]....等(内存单元)都是表示一个字节呢? 09/06 21:10
- [masmaster] 杨季文的《80X86汇编语言程序设计教程》 09/01 12:52
- [游客] to masmaster shl左移4位,那al传进来的4,5,6位背景色不就没了. 为什 09/01 11:00
[2010-10-15 10:19] 任务状态段(5)
阅读全文 |
评论次数(2) |
浏览次数(1155) |
所属类型(汇编语言笔记)
[2010-10-14 10:04] 任务状态段(4)
④链接字段
链接字段被安排在TSS内偏移0开始的双字中。 其中高16位未使用。在起链接作用时,低16位保存前一任务的TSS描述符的选择子
如果当前的任务由段间调用指令call或者中断/异常而激活, 那么链接字段保存被挂起任务的TSS的选择子, 并且标志寄存器EFLAG中的NT位被置1,使链接字段有效。 在返回前,由于NT为1,中断返回指令IRET将使得控制沿着链接字段所指恢复到前一个任务。
⑤其他字段
为了实现输入/输出保护, 要是用I/O许可位图。 任务使用的I/O许可位图也存放在TSS中,作为TSS的扩展部分。 在TSS内偏移66H处的字用于存放I/O许可位...
链接字段被安排在TSS内偏移0开始的双字中。 其中高16位未使用。在起链接作用时,低16位保存前一任务的TSS描述符的选择子
如果当前的任务由段间调用指令call或者中断/异常而激活, 那么链接字段保存被挂起任务的TSS的选择子, 并且标志寄存器EFLAG中的NT位被置1,使链接字段有效。 在返回前,由于NT为1,中断返回指令IRET将使得控制沿着链接字段所指恢复到前一个任务。
⑤其他字段
为了实现输入/输出保护, 要是用I/O许可位图。 任务使用的I/O许可位图也存放在TSS中,作为TSS的扩展部分。 在TSS内偏移66H处的字用于存放I/O许可位...
阅读全文 |
评论次数(0) |
浏览次数(1100) |
所属类型(汇编语言笔记)
[2010-10-13 09:57] 任务状态段(3)
③地址映射寄存器区域
由虚拟地址空间到线性地址空间的映射由GDT和LDT确定,与特定任务相关的部分由LDT确定,而LDT又由LDTR确定。 如果采用分页机制,那么由线性地址空间到物理地址空间的映射由包含页目录起始物理地址的控制寄存器CR3确定。所以,与特定任务相关的虚拟地址空间到物理地址空间的映射由LDTR和CR3确定。 显然,随着任务的切换,地址映射关系也要切换。
TSS的地址映射寄存器区域由位于偏移1CH出的双字字段(CR3)和位于偏移60H处的字字段(LDT)组成。 在任务切换时, 处理器自动从轮到执行的任务的TSS中取出这两个字段,分别装入CR3和LDTR。 这...
由虚拟地址空间到线性地址空间的映射由GDT和LDT确定,与特定任务相关的部分由LDT确定,而LDT又由LDTR确定。 如果采用分页机制,那么由线性地址空间到物理地址空间的映射由包含页目录起始物理地址的控制寄存器CR3确定。所以,与特定任务相关的虚拟地址空间到物理地址空间的映射由LDTR和CR3确定。 显然,随着任务的切换,地址映射关系也要切换。
TSS的地址映射寄存器区域由位于偏移1CH出的双字字段(CR3)和位于偏移60H处的字字段(LDT)组成。 在任务切换时, 处理器自动从轮到执行的任务的TSS中取出这两个字段,分别装入CR3和LDTR。 这...
阅读全文 |
评论次数(0) |
浏览次数(1061) |
所属类型(汇编语言笔记)
[2010-10-12 10:13] 任务状态段(2)
1,寄存器保护区域
寄存器保存区域位于TSS内偏移20H至5FH处,用于保存通用寄存器、段寄存器、指令指针和标志寄存器。 当TSS对应的任务正在执行时,保存区域是未定义的;在当前任务被切换出时,这些寄存器的当前值就保存在该区域。当下次切换回原任务时,再从保存区域恢复出这些寄存器的值,从而使处理器恢复成该任务换出前的状态,最终使任务能够恢复执行。
2,内层堆栈指针区域
为了有效地实现保护, 一个任务在不同的特权级下使用不同的堆栈。比如当从外层特权级3变换到内层特权级0时,任务使用的堆栈也同时从3级堆栈变换到0级堆栈;当从内层特权级0变换到外层特权级3时,任务使用的堆栈也同...
寄存器保存区域位于TSS内偏移20H至5FH处,用于保存通用寄存器、段寄存器、指令指针和标志寄存器。 当TSS对应的任务正在执行时,保存区域是未定义的;在当前任务被切换出时,这些寄存器的当前值就保存在该区域。当下次切换回原任务时,再从保存区域恢复出这些寄存器的值,从而使处理器恢复成该任务换出前的状态,最终使任务能够恢复执行。
2,内层堆栈指针区域
为了有效地实现保护, 一个任务在不同的特权级下使用不同的堆栈。比如当从外层特权级3变换到内层特权级0时,任务使用的堆栈也同时从3级堆栈变换到0级堆栈;当从内层特权级0变换到外层特权级3时,任务使用的堆栈也同...
阅读全文 |
评论次数(0) |
浏览次数(1105) |
所属类型(汇编语言笔记)
[2010-10-11 09:44] 任务状态段(1)
任务状态段(TaskStateSegment)是保存一个任务主要信息的特殊段。 任务状态段描述符用于描述这样的系统段,任务状态段寄存器TR的可见部分含有当前任务的任务状态段描述符的选择子,TR的不可见部分含有当前任务状态段的段基地址和段界限等信息。
TSS在任务切换过程中起着主要的作用,通过它实现任务的挂起和切换。 所谓任务的切换是指,挂起当前正在执行的任务,恢复另外一个任务的执行。 在任务切换过程中,首先处理器中各寄存器的当前值被自动保存到TR所指定的TSS中,然后下一任务的TSS的选择子被装入TR;最后从TR所指定的TSS中取出各寄存器的值送到各个寄存器中。由此可见,通过在TSS...
TSS在任务切换过程中起着主要的作用,通过它实现任务的挂起和切换。 所谓任务的切换是指,挂起当前正在执行的任务,恢复另外一个任务的执行。 在任务切换过程中,首先处理器中各寄存器的当前值被自动保存到TR所指定的TSS中,然后下一任务的TSS的选择子被装入TR;最后从TR所指定的TSS中取出各寄存器的值送到各个寄存器中。由此可见,通过在TSS...
阅读全文 |
评论次数(0) |
浏览次数(604) |
所属类型(汇编语言笔记)
[2010-10-08 10:42] 门描述符
除了存储段描述符和系统段描述符外,还有一类门描述符。
门描述符并不描述某种内存段,而是描述控制转移的入口点。 这种描述符好比一个通向另一个代码段的门。 通过这种门,可实现任务特权级的变换和任务间的切换。因此,这种门描述符也称为控制门。
①门描述符的一般格式
门描述符只有位于描述符内偏移5的类型字节与系统段描述符保持一致,也由该字节标识门描述符和系统段描述符。 该字节内的P位和DPL位的含义与其他描述符中的意义相同。其他字节主要用于存放一个48位的全指针(16位的选择子和32位的偏移量)
其数据结构如下:
GATE STRUC
OFFSE...
门描述符并不描述某种内存段,而是描述控制转移的入口点。 这种描述符好比一个通向另一个代码段的门。 通过这种门,可实现任务特权级的变换和任务间的切换。因此,这种门描述符也称为控制门。
①门描述符的一般格式
门描述符只有位于描述符内偏移5的类型字节与系统段描述符保持一致,也由该字节标识门描述符和系统段描述符。 该字节内的P位和DPL位的含义与其他描述符中的意义相同。其他字节主要用于存放一个48位的全指针(16位的选择子和32位的偏移量)
其数据结构如下:
GATE STRUC
OFFSE...
阅读全文 |
评论次数(0) |
浏览次数(766) |
所属类型(汇编语言笔记)
[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的描述符才是真正的系统...
①系统段描述符的一般格式:
系统段描述符的格式与存储段描述符格式相似, 区分他们的标志是属性字节中描述符类型位DT的值。DT=1表示存储段;DT=0表示系统段。 系统段描述符中的段基地址和段界限字段与存储段描述符中意义完全相同;属性中G位,AVL位,P位和DPL字段的作用也完全相同,存储段中的D位在系统段中不使用。系统段描述符的类型字段TYPE仍然是4位,其编码以及表示的类型则与存储段描述符的类型完全不同。只有类型编码1,2,3,9和B的描述符才是真正的系统...
阅读全文 |
评论次数(0) |
浏览次数(789) |
所属类型(汇编语言笔记)
[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...
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) |
浏览次数(816) |
所属类型(汇编语言笔记)
[2010-10-04 10:17] 系统地址寄存器
全局描述符表GDT、局部描述符表LDT和中断描述符表IDT等都是保护模式下非常重要的特殊段。 他们包含有对段机制所用的重要表格。 为了方便定位这些段,处理器采用一些特殊的寄存器保存这些段的基地址和段界限。 这些特殊的寄存器就是系统地址寄存器。
①全局描述符表寄存器GDTR
全局描述符表寄存器长48位,其中高32位含基地址,低16位含段界限。由于GDT不能由其本身之内的描述符进行描述定义,所以处理器采用GDTR为GDT这一特殊的系统段提供一个伪描述符。利用结构类型定义伪描述符如下:
PDESC STRUC
LIMIT DW 0
BASE DD ...
①全局描述符表寄存器GDTR
全局描述符表寄存器长48位,其中高32位含基地址,低16位含段界限。由于GDT不能由其本身之内的描述符进行描述定义,所以处理器采用GDTR为GDT这一特殊的系统段提供一个伪描述符。利用结构类型定义伪描述符如下:
PDESC STRUC
LIMIT DW 0
BASE DD ...
阅读全文 |
评论次数(0) |
浏览次数(801) |
所属类型(汇编语言笔记)
[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用于控制分段管...
控制寄存器CR0中的位0用PE标记,位31用PG标记,他们分别控制分段和分页管理机制的操作。 所以,把它们成为保护控制位。PE用于控制分段管...
阅读全文 |
评论次数(0) |
浏览次数(552) |
所属类型(汇编语言笔记)