x86架构之实模式和保护模式的简单分析

x86的工作方式有实模式和保护模式两种。
在实模式下,段寄存器存放的都是段地址,是用于寻址的,实模式可寻址的空间为1MB,如图所示:
在这里插入图片描述
而在保护模式下,分段的思想仍然存在,但此时段寄存器的内容已不是段地址,而是段选择子, x86下可寻址的空间是4GB,保护模式下将这4GB的连续空间根据安全属性划分成段,段寄存器存放的是段选择子,而具体的段的安全属性需要64位的存储空间才能描述,这64位的数据称为段描述符,每个段有一个段描述符,所有的段的段描述符就构成了段描述符表,这个表存放于内存中。段描述符表在内存中的地址由描述符表寄存器指定,段描述符表寄存器有GDTR和LDTR之分,这两个寄存器分别指向全局描述符表和局部描述符表。段描述符表中存放着多个段描述符(每个描述符对应着一个段的安全属性),段寄存器存放着段描述符在段描述符表中的索引(或称位置)。保护模式下可寻址的空间如图:
在这里插入图片描述

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值