实模式与保护模式的寻址方式

一、实模式寻址

  • CPU 在实模式下,地址总线只有 20 位,寻址空间为 1 M。

  • 20 位的目标物理地址取决于两个条件,一是 16 位的段基址,二是 16 位的偏移地址。

  • 20 位目标物理地址 = ( 16 位段基址 << 4 ) + 16 位偏移地址

  • 段基址由 16 位段寄存器给出,偏移地址由机器指令操作数给出。

二、保护模式寻址

  • CPU 在保护模式下,地址总线有 32 位,寻址空间为 4 G。

  • 32 位的目标物理地址取决于两个条件,一是 16 位的段选择子 S S S,二是 32 位的偏移地址 O O O

  • 16 位的段选择子由 16 位段寄存器给出,偏移地址由机器指令操作数给出。

  • 16 位段寄存器的高 13 位(第 3~15 位共 13 位)作为全局描述符表中对应段描述符的索引,找到段描述符后,取出其中的 32 位段基址 B B B,20 位段界限 L L L 和 1 位粒度标志 G G G,设段最大长度为 X X X,若 G G G 为 1,则 X = L X = L X=L,若 G G G 为 0,则 X = L × G X = L\times G X=L×G。通过特权级检查后,则取出偏移地址 O,若 O &gt; X O &gt; X O>X,则触发异常,若 O &lt; = X O &lt;= X O<=X,则允许访问。

三、参考资料

《深入分析 Linux 内核源代码》 陈莉君 编著
《计算机组成与系统结构(第 2 版)》袁春风 主编

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 这段视频介绍了x86汇编语言下,如何从模式切换到保护模式。 首先,视频介绍了模式的特点和局限性。模式下,CPU只能寻址1MB的内存空间,同时所有的程序都需要运行在同一个特权级下,对于大型程序和操作系统而言非常不利。 接着,视频介绍了如何切换到保护模式保护模式下,CPU可以通过基地址和段选择器来访问4GB的内存空间,同时程序可以运行在不同的特权级下。切换到保护模式的关键步骤包括:设置GDT和IDT表、开启A20线、设置CR0寄存器、跳转到保护模式代码段等。 最后,视频演示了如何编写汇编代码来保护模式的切换。代码包括定义GDT和IDT表、开启A20线的函数、设置CR0寄存器的函数,以及跳转到保护模式代码段的函数。通过这段视频的学习,我们了解了从模式保护模式的切换原理和现方法,对于深入理解操作系统和底层编程有着重要的意义。 ### 回答2: x86汇编语言是计算机的底层语言,包括模式保护模式两种运行模式模式是早期计算机的一种运行模式,它的内存访问方式简单,容易理解。在模式下,整个物理内存空间可以直接寻址,但同时也带来一些安全问题。为了保护内存和提高计算机运行的稳定性,最终出现了保护模式保护模式是x86汇编语言的一种运行模式,它可以让计算机利用内存管理单元(MMU)来对内存进行隔离和保护。在保护模式下,内存空间被分为多个段,并为每个段赋予相应的权限和特权级别。这样可以有效保护计算机的内存空间,避免程序之间相互侵入和破坏。 保护模式的运行需要经过一系列的初始化,包括:打开地址线扩展、禁用中断、打开分页等操作。这些操作可以通过设置控制寄存器和描述符表来现。 在保护模式下,程序运行的特权级别由RPL(Requested Privilege Level)和CPL(Current Privilege Level)两个标志位来控制。CPL位于代码段和数据段的选择子中,代表当前运行程序的权限级别,而RPL位于代码选择子和数据选择子中,用来判断程序是否有权访问对应的段。 在保护模式下,虚拟地址需要经过地址转换才能转换成物理地址,这需要使用页表来对虚拟地址进行映射。页表和页目录存储在内存中,需要通过控制寄存器来取出相应的值进行地址转换。 总之,x86汇编语言的模式保护模式都有各自的特点和应用场合,学习x86汇编语言需要深入理解这两种运行模式的原理和现过程。 ### 回答3: x86汇编语言是计算机硬件操作指令的编程语言,是本质上依赖于CPU架构和指令集的语言。根据其中对内存的处理方式的不同,x86汇编语言可以分为模式保护模式模式是指CPU直接访问物理内存,地址总线是20位,内存寻址空间最大为1MB。模式下的程序可以访问系统资源,例如中断处理、内存读写等操作。但模式下内存空间过小,程序出错容易导致系统崩溃。 保护模式是一种更加灵活和安全的工作状态,地址总线扩展到了32位,理论内存访问空间可以达到4GB以上。保护模式下内存被划分为多个段,程序可以在相互独立的段之间进行操作,可以在段级别上分配权限,从而提高代码的安全性。同时,保护模式也支持虚存技术,通过硬件的支持,可以将程序的际运行数据放入物理内存和虚拟内存的组合体内,从而可以利用硬盘来进行虚拟内存的支持,使得多个程序在同一系统上运行时不会相互干扰,同时提高系统的稳定性。 因此,在现代操作系统上,保护模式是必需的。x86汇编语言需要不同的功能选项来在模式保护模式之间进行转换。在视频中,我们可以学习如何从模式切换到保护模式,并掌握如何在保护模式下使用不同的功能选项。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值