想法@IT·互联网操作系统

从零开发操作系统-CPU的实模式和保护模式以及长模式

2024-11-13  本文已影响0人  shengjk1

你好,我是 shengjk1,多年大厂经验,努力构建 通俗易懂的、好玩的编程语言教程。 欢迎关注!你会有如下收益:

  1. 了解大厂经验
  2. 拥有和大厂相匹配的技术等

希望看什么,评论或者私信告诉我!

一、背景

其实也没有啥背景。
最主要的原因就像 《30天自制操作系统》一书作者说的那样,写一个操作系统,仅仅想想就是一件特别有趣的事情呢。一两年前曾经入手开始写过,但慢慢的就不了了之了。现在又有这个想法了,准备一直干下去,最终写一个操作系统出来,算是程序员生涯的一份礼物。

其次的原因,是因为我也认为未来初级程序员的岗位会越来越少,借助 LLM 人人都是初级程序员可能会变成现实。这个时候专业性和底层就会越来越重要。

二、实模式和保护模式以及长模式的背景

从零开发操作系统进入到了第3天,马上就可以通过 C 语言进行开发了。书中突然来了一句:CPU有16位和32位两种模式。感觉有些不可思议,不是还有 64 位吗?经了解之后总结如下:

2.1 模式分类

在 x86 架构中,CPU 有几种不同的模式,其中最常见的是实模式(Real Mode)和保护模式(Protected Mode)。此外,还有长模式(Long Mode),这是在引入 x86-64 架构时增加的。以下是这些模式的简要说明:

  1. 实模式(Real Mode)

    • 这是 x86 系统启动时的初始模式,对应书中的 16 位 CPU 模式。
    • 在实模式下,CPU 使用 20 位地址总线,可以寻址 1MB 的物理内存( 内存的最小单位是字节 )。
    • 段地址和偏移地址组合成物理地址,使用 16 位段寄存器和 16 位偏移量。
    • 实模式主要用于 BIOS 启动过程和早期的操作系统(如 DOS)。
    • 我们之前开发的所有汇编都是在实模式下运行的
    • 没有虚拟内存,没有GDT
  2. 保护模式(Protected Mode)

    • 保护模式是在 80286 及更高版本的 CPU 中引入的,对应书中的 32 位 CPU 模式
    • 在保护模式下,CPU 可以使用分段和分页机制来保护内存和提供更复杂的内存管理。
    • 虚拟地址
    • 保护模式支持 32 位的地址空间,可以寻址 4GB 的物理内存(在 80386 及更高版本的 CPU 中)。
    • 保护模式是现代操作系统(如 Windows, Linux)的基础。
    • 不能调用 BIOS
  3. 长模式(Long Mode)

    • 长模式是在 64 位 x86-64 架构中引入的。
    • 长模式允许 CPU 使用 64 位的地址空间,可以寻址超过 4GB 的物理内存。
    • 在长模式下,CPU 可以运行 64 位的操作系统和应用程序。
    • 长模式向下兼容保护模式,但不兼容实模式。

2.2 模式切换

三、总结

x86 架构的 CPU 有实模式、保护模式和长模式。实模式主要用于系统启动和早期操作系统,保护模式提供了更复杂的内存管理和更大的寻址空间,而长模式则支持 64 位的地址空间和更大的内存寻址能力。现代操作系统通常在保护模式或长模式下运行。

另外如果以16位模式启动的话,用AX和CX等16位寄存器会非常方便,但反过来,像EAX和ECX等32位的寄存器,使用起来就很麻烦。另外,16位模式和32位模式中,机器语言的命令代码不一样。同样的机器语言,解释的方法也不一样,所以16位模式的机器语言在32位模式下不能运行,反之亦然。

上一篇 下一篇

猜你喜欢

热点阅读