①简介
80836有32根地址线,在保护模式下, 它们都能发挥作用。所以可寻址的物理地址空间高达4G字节。在以80386及其以上处理器为CPU的PC兼容机系统中,把地址在1MB一下的内存称为常规内存;把地址在1MB以上的内存称为扩展内存。
80386为了运行大型程序和实现多任务,必须采用虚拟存储器。虚拟存储器是一种软硬结合的技术,用于提供比在计算机系统中实际可以使用的物理主存储器大得多的存储器空间。
80386还要对存放在存储器中的代码和数据的共享和保护提供支持。所以,80386既要支持任务隔离又要支持共享代码和数据的共享,还要支持特权保护。
②地址空间和地址转换
保护模式下的虚拟存储器由大小可变的存储块构成,这样的存储块称为‘段’。 80386采用称为‘描述符’的数据来表述段的位置、大小和使用情况,虚拟存储器的地址(逻辑地址)由指示描述符的‘选择子’和段内偏移构成。这样的地址集合称为虚拟地址空间。80386支持的虚拟地址空间可高达64T字节。
显然,只有在物理存储器中的程序才能执行;只有在物理存储器里的数据才能访问。所以,虚拟地址空间必须映射到物理地址空间,二维的虚拟地址必须转换成一维的物理地址。
每一个任务都有一个虚拟地址空间。为了避免多个并行任务的多个虚拟地址空间直接映射到同一物理地址空间,采用线性地址空间隔离虚拟地址空间和物理地址空间。线性地址空间由一维的线性地址构成,线性地址空间和物理地址空间对等。线性地址32位长,线性地址空间容量为4G字节。
80386分两步实现虚拟地址空间到物理地址空间的映射,也就是分两步实现虚拟地址到物理地址的转换。但是第二步的分页管理机制是可选的。通过描述符表和描述符,分段管理机制实现虚拟地址空间到线性地址空间的映射实现把二维的虚拟地址转换成一维的线性地址。这一步是必须的。
分段管理机制所使用的可变大小的块,使分段管理机制比较适宜处理复杂系统的逻辑分段。存储块的大小可以根据适当的逻辑含义进行定义,而不用考虑固定大小的页所强加的认为限制。每个段可作为独立的单位处理,以简化段的保护和共享。
- [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