CPU的三种工作模式实模式、保护模式和386增强模式

科技知识普及篇:1981年IBM推出第一台个人计算机--286电脑

Intel 80286

1982年,英特尔公司在8086的基础上,研制出了80286微处理器,该微处理器的最大主频为20MHz,内、外部数据传输均为16位,使用24位内存储器的寻址,内存寻址能力为16MB。80286可工作于两种方式,一种叫实模式(相当于与MS DOS兼容,具有8086与8088芯片的限制),另一种叫保护方式(增加了微处理器的功能)。在实模式下,微处理器可以访问的内存总量限制在1兆字节;而在保护方式之下,80286可直接访问16兆字节的内存。此外, 80286工作在保护方式之下,可以保护操作系统,使之不像实模式或8086等不受保护的微处理器那样在遇到异常应用时会使系统遭到停机。IBM公司将 80286微处理器用在先进技术微机即AT机中,引起了极大的轰动。
80286在以下四个方面比它的前辈有显著的改进:支持更大的内存。达到了当时前所未有的16MB;能够模拟内存空间。这使得微处理器可以使用外存储设备模拟的大量存储空间,这样就大大扩展了80286所能胜任的工作范围;能同时运行多个任务。多任务是通过多任务硬件机构使微处理器在各种任务间来回快速切换;处理速度。最早PC机的速度是4MHz,第一台基于80286的AT机运行速度为 6MHz至8MHz,一些制造商还自行提高速度,使80286达到了20MHz,这确实意味着性能上有了重大的进步。
80286的封装是一种被称为PGA的正方形包装。PGA是源于PLCC的便宜封装,它有一块内部和外部固体插脚,在这个封装中,80286集成了大约130000个晶体管。IBM PC/AT微机的总线保持了XT的三层总线结构,并增加了高低位字节总线驱动器转换逻辑和高位字节总线。与XT机一样,CPU也是焊接在主板上的。
那时的原装机仅指IBM PC机,而兼容机就是除了IBM PC以外的其它机器。在当时,生产CPU的公司除英特尔外,还有AMD及西门子公司等,而人们对自己电脑用的什么CPU也不关心,因为AMD等公司生产的 CPU几乎同英特尔的一样,直到486时代人们才关心起自己的CPU来。
8086~80286这个时代是个人电脑起步的时代,当时在国内使用甚至见到过PC机的人很少,它在人们心中是一个神秘的东西。到九十年代初,国内才开始普及计算机。

简单介绍保护模式和实模式的原理

实模式

最早的IBM PC只能寻址1MB的系统内存,包括早期的DOS版本也是基于此而设计的。DOS是单任务操作系统,一次只能运行一个程序,这种模式源于Intel 8088芯片,被称作为实模式。
80186及早期的处理器都是运行在实模式下,但是为了向下兼容这些旧的CPU,80286及以后的x86系列兼容处理器仍然是在开机启动时以实模式工作,甚至最新的x86处理器在一开始打开电源处于实模式下也能运行为以前处理器芯片写的程序。因此80286及以后的CPU首先进入实模式,然后通过切换机制再进入到保护模式。
实模式被特殊定义为20位地址内存可访问空间上,这就意味着它的容量是2的20次幂(1M)的可访问内存空间(物理内存和BIOS-ROM),软件可通过这些地址直接访问BIOS程序和外围硬件。实模式下处理器没有硬件级的内存保护概念和多道任务的工作模式。

保护模式

286处理器体系结构引入了地址保护模式的概念,处理器能够对内存及一些其他外围设备做硬件级的保护设置(保护设置实质上就是屏蔽一些地址的访问)。
保护模式(处理器的本机模式)是一种80286系列和之后的x86兼容CPU操作模式,最早在IBM AT电脑的80286芯片上出现,但其流行起来则归功于microsoft的WINDOW操作系统的流行。DOS单任务操作系统工作在实模式下,而微软Windows操作系统早期的版本(它本质上是运行在DOS上的图形用户界面应用程序,实际上本身并不是一个操作系统)也是运行在实模式下,而Windows3.0及以后的系统运行在保护模式下,其多道程序并发执行从而诞生保护模式。因此保护模式比实模式功能更加强大,特别适合现代多任务操作系统。
保护模式实质上是对进程的内存进行隔离,是一种内存管理技术。
在多任务操作系统里,每个程序都运行在自己的内存空间里,这样可以保护程序间不会有冲突。如果一个程序试图访问不属于它的内存地址,就会导致保护模式错误。
保护模式的优点有:
1.可以存取系统内存的任意地址,这里没有"1 MB"的限制。
2.支持多任务,操作系统可以同时执行不同的程序。
3.支持虚拟内存,可以允许操作系统利用硬盘来虚拟额外的内存。
4.存取内存的速度(32位)更快,存取I/O的速度更快。

intel 80386

80386的广泛应用,将PC从16位时代带入了32位时代
80386时代,CPU出现了三种工作方式:实模式,保护模式和虚拟8086模式(也称为386增强模式)。
只有在刚刚启动的时候是real-mode,等到操作系统运行起来以后就切换到protected-mode。

实模式只能访问地址在1M以下的内存称为常规内存,我们把地址在1M 以上的内存称为扩展内存。

在保护模式下,全部32条地址线有效,可寻址高达4G字节的物理地址空间;

出现了扩充的存储器分段管理机制和可选的存储器分页管理机制,不仅为存储器共享和保护提供了硬件支持,而且为实现虚拟存储器提供了硬件支持;

定义了4个特权级和完善的特权检查机制。在保护模式下,各进程的地址空间被分成了用户空间和系统空间两部分,而Windows使用了两种访问模式:内核模式与用户模式,用户程序在用户模式下运行,系统程序(服务、驱动)在内核模式下运行,既能实现资源共享又能保证代码和数据的安全和保密及任务的隔离;

image.png

支持虚拟8086方式,便于执行8086程序。
为了保证保护模式的兼容性,处理器允许在受保护的,多任务的环境下执行实模式程序,这就是虚拟8086模式。
虚拟8086模式只是保护模式的一种属性,但它并不是一个真正的处理器模式。在保护模式下CPU可以进入虚拟8086的工作模式,这是一种在保护模式下的实模式程序的运行环境,因此cpu可以在32位保护模式下执行纯16位程序。

支持多任务,可使用任务寄存器来管理任务的内存段实现任务切换。
虚拟86模式可以同时模拟多个8086处理器来加强多任务处理能力,能够快速地进行任务切换(switch)和保护任务环境(context)。Windows/386就是利用了这个特性,将每一个应用程序都运行在这个模式下,它允许多个MS-DOS程序以“虚拟8086”CPU模式并行运行,而不是总是挂起成为后台应用程;

image.png
CPU支持的内存寻址空间大小

8080、8085 :8位芯片(数据线的个数),地址总线都是16条,寻址2^16=64K
8086、80186:16位芯片,地址总线是20位,寻址2^20=1M
80386的内部和外部数据总线都是32位,地址总线也是32位,可寻址高达4GB内存
8086时候操作系统不存在权限控制,访问模式为实模式,直接访问物理地址

For example:

Dos--->实模式
windows---->保护模式
win下调用dos--->虚拟模式

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,496评论 6 501
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,407评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,632评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,180评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,198评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,165评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,052评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,910评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,324评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,542评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,711评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,424评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,017评论 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,668评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,823评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,722评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,611评论 2 353

推荐阅读更多精彩内容

  • 原文链接 16位微处理器 8086寄存器组成 8086/8088包括:4个16位的数据寄存器,2个16位的指针寄存...
    Quinton_Lau阅读 2,922评论 0 1
  • 本文试图用有限的篇幅来阐述80386保护模式重要知识点。本文不是一个系统全面的知识介绍,您可能需要了解相关的803...
    JeffreyLi阅读 2,105评论 0 10
  • 王爽汇编全书知识点大纲 第一章 基础知识 机器语言 汇编语言的产生 汇编语言的组成 存储器 cpu对存储器的读写 ...
    2c3ba901516f阅读 2,417评论 0 1
  • 汇编语言的一些注意点 汇编语言是直接在硬件之上工作的编程语言。 CPU(Central Processing Un...
    BackSpace8阅读 1,781评论 0 1
  • 课题分离,这是阿德勒心理学派的一个重要观点。 就是要把自己和他人所负责的事情分割来。每个人只需要对自己的课题负责,...
    秋原花实阅读 535评论 0 1