浅谈CPU进入保护模式的方法

发布时间:2024年01月19日

看程序要想思路不乱,最重要的就是要抓到程序的主线,不要被一些只是用来保护的代码打乱。如何抓到主线呢?比较法学习代码是比较有效的,比如对于CPU如何进入保护模式的理解。

不同的操作系统作者有自己的方法,代码看起来也是有很大差异。但是让CPU进入保护模式最终还是要向GdtPtr寄存器中写入全局描述表GDT地址。以及向CPU下达切换保护模式的指令,也就说向CPU的CR0寄存器写如固定的值。

下面这篇博主是这样解释进入CPU进入保护模式的
https://www.cnblogs.com/chuganghong/p/15415208.html
在这里插入图片描述

《30天自制操作系统》中是这样写的:
在这里插入图片描述

两文相同的关键代码就是LGDT和MOV CR0,EAX.

  1. LGDT指令就是设置Gdtptr寄存器,把GDT地址写入到Gdtptr基础器中。
  2. MOV CR0,EAX指令就是把CR0寄存器把CR0最高位置0,最低位置1.

上面两部就是CPU进入保护模式的必要条件。

文章来源:https://blog.csdn.net/katerdaisy/article/details/135688579
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。