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

我的博客

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

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

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

[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) | 浏览次数(559) | 所属类型(汇编语言笔记)

[2010-09-28 10:59] 存储段描述符

用于表示定义段的三个参数的数据称为‘描述符’。每个描述符长8个字节。在保护模式下,每一个段都有一个相应的描述符来描述。
    存储段是存放可由程序直接进行访问的代码和数据的段。存储段描述符描述存储段,所以,存储段描述符也被称为代码和数据段描述符。长32位的段基地址(即段的开始地址)被安排在描述符的两个域中,其位0~23安排在描述符内第2~4字节中,其位24~31被安排在描述符的第7字节中。长20位的段界限也被安排在描述符的两个域中,其位0~15被安排在描述符内的第0~1字节,其位16~19被安排在描述符内的第6字节的低4位中。
    描述符的段属性也被安排在两个域中。其详细说明如下: ...
阅读全文 | 评论次数(1) | 浏览次数(637) | 所属类型(汇编语言笔记)

[2010-09-27 10:46] 段定义和虚拟地址到线性地址的转换

段是实现虚拟地址到线性地址转换机制的基础。 在保护模式下,每个段由三个参数进行定义:
段基地址(Base Address)
段界限(Limit)
段属性(Attribute)
    段基地址规定线性地址空间中段的开始地址。在保护模式下,段基地址长32位。因为基地址长度和寻址地址的产度相同, 所以任何一个段都可以从32位线性地址空间中的任何一个字节开始。
    段界限规定段的大小。 在保护模式下,段界限用20位表示,而且段界限可以是以字节为单位或以4K字节为单位。 在段属性中有一位对此进行定义,把该位称为粒度位,用G标记。G=0表示段界限以字节为单位,于是20位的界限可表示的范围是...
阅读全文 | 评论次数(0) | 浏览次数(711) | 所属类型(汇编语言笔记)

[2010-09-26 10:26] 保护机制

为了支持多任务,对各个任务试试保护是必须的。从80286开 始,处理器就具备了保护机制。保护机制能有效地实现不同任务之间的保护以及同一任务内的保护。

①不同任务之间的保护
    通过把每个任务放置在不同的虚拟地址空间的方法来实现任务与任务的隔离,从而达到任务之间保护的目的。对于两个不同的任务,尽管虚拟存储单元地址相同,但实际的物理存储单元地址可以不同。

②同一任务内的保护
    在每一个任务内部,定义有四种执行特权级别,用于限制对任务中的段进行访问。按照包含在段中的数据的重要性和代码的可信度,给段指定特权级别。把最高的特权级别分配给最重要的数据段和最可信任的代码段。具有最高...
阅读全文 | 评论次数(0) | 浏览次数(591) | 所属类型(汇编语言笔记)

[2010-09-25 10:12] 保护模式下的存储管理机制

①简介
    80836有32根地址线,在保护模式下, 它们都能发挥作用。所以可寻址的物理地址空间高达4G字节。在以80386及其以上处理器为CPU的PC兼容机系统中,把地址在1MB一下的内存称为常规内存;把地址在1MB以上的内存称为扩展内存。
    80386为了运行大型程序和实现多任务,必须采用虚拟存储器。虚拟存储器是一种软硬结合的技术,用于提供比在计算机系统中实际可以使用的物理主存储器大得多的存储器空间。
    80386还要对存放在存储器中的代码和数据的共享和保护提供支持。所以,80386既要支持任务隔离又要支持共享代码和数据的共享,还要支持特权保护。

②地址空间和地...
阅读全文 | 评论次数(0) | 浏览次数(614) | 所属类型(汇编语言笔记)

[2010-08-30 10:06] 标志寄存器在Debug中的表示

FLAG
 15 14 13 12 11 10 9  8  7  6  5  4  3  2  1  0  
|  |  |  |  |OF|DF|IF|TF|SF|ZF|  |AF|  |PF|  |CF|

在debug中的哥哥标志:
    OF  DF  IF  SF  ZF  AF PF CF
置1 OV  DN      NG  ZR  AC PE CY
置0 NV  UP      PL  NZ  NA PO NC...
阅读全文 | 评论次数(0) | 浏览次数(306) | 所属类型(汇编语言笔记)

[2010-08-16 21:29] 哪种算法好呢

设计一个串替换算法。在串S中,将第pos个字符开始的len个字符构成的子串用串T替换
例如:S=1234567890,T=ABC,pos=3,len=4,
替换后S=12ABC7890
书里的算法是:生成一个新串str,将S串的1~~pos个字符复制到str中,再将T串复制到pos+1的位置, 最后将S串的(pos+len)~~length个字符复制到str中T串的后面。
我的想法是:
①计算旧串old的长度
②计算新串new的长度
③计算新旧差值,old-new=N
④如果结果N为正,那么S串后移N位,如果为负,则S串前移N位,如果新旧字串长度相等,则直接复制。...
阅读全文 | 评论次数(1) | 浏览次数(375) | 所属类型(汇编语言笔记)

[2010-08-02 10:16] 关于local伪指令

local伪指令在过程内声明一个或多个命名局部变量,并同时赋予变量相应的尺寸属性。 local必须紧跟在proc伪指令所在行之后。格式如下:
subproc    proc 
           local var-list
其中变量列表是一系列的变量定义,之间用逗号分开。每个变量定义的格式如下;
           标号:类型
标号可以是任意有效的标识符,类型可以是标准类型(word,dword,byte)
例如:
subproc   proc
          local temp1:word,temp2:byte array[10]:dword
其中,这个过程定义...
阅读全文 | 评论次数(1) | 浏览次数(1001) | 所属类型(汇编语言笔记)
页码数(5):  1  2  3  4  5