你知道如何才能使自己快乐起来吗?最好的办法我认为是做一件自己喜欢的事!周末的第一天上午,我在为公司做事,周末的第一天下午,我收拾了家里,洗了衣服,陪女儿看了无聊的《》;周末的第二天,我想做点自己的事,那就是自己启动一个OS核心,到目前为止,成功了,很顺利,自己终于有了自己的OS核心。OS核心并不重要,关键是要理解Intel处理器的几个感念,本文就希望将它们阐述清楚。几个概念当然不不包括为何将代码加载到0x7c00这种问题(由于中午喝了酒-本人已经几近崩溃,语无伦次敬请见谅!!),核心在于什么是保护模式,什么是分段,什么是分页。
计算机OS的运行,最终要落实到访问物理内存,毕竟所有的数据都是来自于物理内存,而访问物理内存就需要先知道物理内存的地址,这个地址是实实在在的地址。然而我们的程序中使用的地址却并不一定要和这个最终的物理地址相等,那么如何将程序中使用的地址对应到实实在在的物理地址,这是一门技术,不知其所以然的人只能将其当成一种魔法!
物理内存地址生成方式:
虚拟地址概念:所谓虚拟地址,那是处理器为应用程序提供的一个概念,对于Intel处理器来讲,它要么是分段虚拟地址,要么是分页虚拟地址。对于什么是分段和分页,我相信能看到这篇文章的家伙一定都很并且可能比我更了解。
分段模式的物理地址形成:定位段寄存器-〉找到段选择子-〉找到段-〉定位段的base地址-〉base地址加上指令值即offset-〉得到物理地址。
分页模式的物理地址形成:定位cr3寄存器指示的内存-〉读取其值-〉虚拟地址拆分为几个段-〉查找页表-〉得到物理地址。
我们看到,分段模式和分页模式得到物理地址的方式截然不同,它们到底有什么区别和联系呢?本质上,Intel处理器32位保护模式的宗旨在于一个概念,那就是特权环,一个程序仅仅可以在被允许的特权环内运行,而特权环的实现就是分段。
保护模式的分段机制包括两个方面:
1.特权环的概念:旨在分离系统和应用程序
2.GDT/LDT:隔离各个任务
除却分段机制,32位保护模式还有一个概念,那就是分页:
分页:提供了对虚拟内存的支持,可以使进程可用的地址空间突破物理内存的限制,整个磁盘空间被认为是虚拟的内存(如果不使用file map,那么只是整个swap空间)。在不启用分页的情况下,所有的进程共享整个内存,你必须在GDT中为每一个进程预留一个位置,还要事先预知每个进程大致需要多大的内存...而是用虚拟内存,则整个4G的地址空间为一个进程独占。
Intel 32位保护模式分为两个层次,一个是分段,一个是分页
分页是位于分段之上更强的针对应用程序的保护,然而并不能完全抛弃分段。
分段:针对整部机器的特权保护,分为了几个特权环
分页:针对进程的内存隔离保护,一个进程使用一个页表
二者结合使用才是真正的带有虚拟内存的32位保护模式
关于TSS:任务切换
进程的概念:进程就是一个执行绪,其指令是必须保存于内存当中的,如果OS是无虚拟内存支持的,那么GDT/LDT的重要性就会很大,必须为每一个进程单独开辟一块内存,使用LDT来将此块内存与其他进程的内存隔离开来,如果使能了虚拟内存,那么就由CR3寄存器指示的页目录来完成内存隔离。在没有虚拟内存的情况下,所谓的进程就是一个任务,其切换方式就是Intel定义的任务切换,也就是一个long jmp,jmp到哪里呢?当然是jmp到目标进程的LDT所指示的内存区域了。
任务切换:Intel并没有将任务和进程等同起来。所谓的任务切换,Intel定义为就是一个long jmp,所谓的long jmp就是一个切换段寄存器的jmp,因此Intel定义的任务着重在于和GDT的关系而非和进程的关系。Intel的任务切换是一个广义的概念,涉及特权级的切换也是任务切换的一种,因为一般而言,OS核心和应用程序不在一个特权环,当然也不在一个段中,因此在切换时肯定涉及到了段寄存器的重载,当然TR寄存器指示的TSS也被看作是一般的段,CPU能区分目标段是一般的GDT/LDT段还是TSS,如果是TSS,那么就相当于切换了一个“进程”。对于进程切换,更重要的是页表的切换,也就是CR3寄存器的重载,因此对于进程切换,TSS切换的意义并不是很大,只要能保证寄存器上下文以及进程栈的正确save/restore即可,而这些东西完全可以都保存在栈上,因此只需要能保证栈的切换即可
32位OS的实现:
不带有虚拟内存保护:完全的以分段为依托的实现,仅仅实现OS和应用程序的隔离,并且整个应用程序的内存空间受制于安装的物理内存大小。也只能这样,否则多出去的内存数据放在哪里呢?
带有虚拟内存保护:以分段为依托(如果愿意的话,你可以最小化使用分段),仅仅将分段用于OS核心与应用程序之间的隔离,因此只需要两个代码段和两个数据段即可,对于所有进程,共享一个段,因为进程之间可以使用分页机制来互相隔离。使用分段来把这个系统分为系统空间和用户空间,然后再用分页机制将用户空间划分为不同的进程空间...后面的我就不说了吧
其实,我们不要被书籍欺骗
千万不要觉得只要实现一个32位的OS,就要想尽一切办法打开A20总线,开启分页...这也许是因为你看了于渊那个学院派学者的著作,如果你再看看轻量级编程大师的著作,比如《30天自制操作系统》,你就会发现,编写一个OS其实真的很简单,没有必要打开A20,也并不一定非要开启分页...一个纯分段的OS,仍然是一个32位保护模式的OS!
分享到:
相关推荐
在保护模式下,处理器可以利用虚拟内存管理、分页机制等技术来提高系统的安全性、稳定性和效率。 #### 2. 保护模式的特点 - **虚拟内存管理**:通过分段和分页技术实现,允许操作系统管理和使用比实际物理内存大得...
该卷详细介绍了IA-32架构的基础,包括处理器的组织结构、内存模型、总线接口以及处理器的工作模式(如实模式、保护模式、虚拟8086模式、系统管理模式等)。其中,处理器的寄存器体系结构是关键,包括通用寄存器、段...
总结,Intel 80x86保护模式是现代计算机系统的核心组成部分,它的分段和分页机制、特权级设计以及内存保护策略,为复杂操作系统的高效运行提供了坚实的硬件基础。理解并熟练掌握这些概念,对于进行系统级编程和底层...
随着处理器的发展,80286引入了保护模式,其最大特点是引入了分段和分页机制,提供了内存保护、任务隔离和虚拟内存等功能。每个进程都有独立的地址空间,可以运行在自己的虚拟地址空间内,互不影响。此外,保护模式...
随着技术的发展,保护模式应运而生,它引入了内存分段和分页机制,实现了内存保护和多任务并行,使得现代操作系统得以实现。 从实模式切换到保护模式的过程涉及到以下关键步骤: 1. 初始化控制寄存器:如控制寄存器...
保护模式引入了复杂的内存管理和保护机制,包括分段和分页机制,以及多级特权级控制。 在保护模式中,段寄存器的作用发生了变化,它们不再直接参与地址计算,而是用作指向全局描述符表(GDT)或局部描述符表(LDT)...
80x86保护模式是Intel 80386及其后续处理器的一种核心特性,它扩展了早期的8086实模式的功能,为操作系统提供了更高级别的内存管理和硬件资源的保护。这篇教程将深入探讨保护模式的工作原理、内存管理、权限控制以及...
逻辑地址由段地址和偏移量组成,而在保护模式下,这个转换过程分为两个阶段:分段和分页(分页是可选的)。分段机制通过段描述符来定义每个段的基地址、大小和属性,允许实现虚拟地址到线性地址的转换,提供内存保护...
《英特尔® 64 和 IA-32 架构软件开发人员手册卷 3A:系统编程指南》是为软件开发者提供深入理解英特尔处理器体系结构和系统编程接口的重要参考资料。该手册详细阐述了如何在英特尔® 64 和 IA-32 平台上进行高效的...
《保护模式下的80386及其编程》这本书主要探讨了Intel 80386处理器在保护模式下的工作原理及编程技术。80386是Intel公司推出的32位微处理器,它极大地扩展了早期8086和80286的功能,特别是在内存管理和任务调度方面...
3. 内存管理:理解实模式的线性地址和保护模式下的分段分页机制,以及如何通过这些机制来管理和保护内存。 4. 模式切换:学习如何在代码中实现实模式到保护模式的切换,包括设置控制寄存器和初始化内存管理结构。 5....
保护模式下,处理器支持虚拟地址、多任务和内存分段与分页机制。通过分段,系统可以将不同的内存区域分配给不同的任务或用户,而分页则允许更精细的内存管理和权限控制。此外,保护模式还引入了中断描述符表和任务...
《x86汇编从实模式到保护模式》是一本深入探讨x86架构处理器从实模式转换到保护模式的书籍。这本书旨在帮助读者理解计算机系统底层的工作原理,特别是涉及x86架构的低级编程技术。源码及工具.zip压缩包包含书中提到...
此外,保护模式引入了分段和分页管理机制,不仅支持存储器共享和保护,还为虚拟存储器提供了硬件基础。这种机制使得多个任务可以并行运行,任务切换速度快且能保护任务环境,同时,四个特权级别和严格的权限检查机制...
保护模式下,CPU使用分段和分页机制来管理内存,通过设置不同的特权级,可以限制对系统资源的访问,确保系统稳定性和安全性。每个程序可以拥有自己的独立地址空间,这为实现虚拟内存和多任务并行处理奠定了基础。 ...
80x86保护模式是Intel 80x86处理器家族的一种运行模式,它相对于实地址模式提供了更高级别的内存管理和系统安全特性。在这个模式下,CPU可以支持多任务处理,虚拟内存,并且提供了对硬件资源的权限控制。本教程将...
而保护模式则引入了内存分段和分页机制,提供了内存保护和多任务处理的能力,是现代操作系统的基础。 保护模式下,80386处理器的寄存器结构和寻址方式发生了显著变化。主要的通用寄存器包括EAX、EBX、ECX、EDX、ESI...
80x86是Intel公司早期的CPU系列,广泛应用于个人计算机,而保护模式是这些处理器运行操作系统和复杂应用的主要工作模式。 在80x86处理器中,实模式是最基础的操作模式,它提供了1MB的地址空间,但没有内存保护和多...