第2章 微处理器结构

2023-10-20 03:30
文章标签 结构 微处理器

本文主要是介绍第2章 微处理器结构,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 2.微处理器结构
    • 2.1 微处理器的发展概况
      • 2.1.1 发展历史
    • 2.2 微处理器的功能结构
      • 2.2.1 微处理器结构组成
        • 三者的联系
      • 2.2.2 Inter 8086 微处理器功能结构
        • 2.2.2.1 8086CPU内部结构
          • 总线接口单元(BIU):
            • 执行单元EU:
        • 2.2.2.2 8086CPU内部寄存器
          • 通用寄存器
          • 段寄存器
          • 地址指针与变址寄存器
          • 指令指针与标志寄存器
            • 6个状态标志位
            • 3个控制标志位
        • 2.2.2.3 8086CPU的存储器和内存端口
          • 存储器的分段结构和物理地址的形成
          • 8086的I/O端口

2.微处理器结构

2.1 微处理器的发展概况

2.1.1 发展历史

第一代:1971年开始,4位微处理器和低档8位微处理器

第二代:1973年开始,8位微处理器

第三代:1978年开始,16位微处理器

第四代:1981年开始,32位微处理器

2.2 微处理器的功能结构

在这里插入图片描述

微处理器的结构

2.2.1 微处理器结构组成

①运算器:包括算术逻辑单元(ALU)。 对数据进行算术和逻辑运算,运算结果的特征储存在标志寄存器中。

②控制器:包括指令寄存器、指令译码器、定时和控制电路。 根据指令译码结果,以一定时序发出译码信号,用来控制指令的执行。

③寄存器阵列:包括一组通用寄存器和专用寄存器。 通用寄存器——临时存放参与运算的数据;专用寄存器——通常有指令指针IP(或程序计数器PC)和堆栈指针SP。

三者的联系

这三部分之间的信息交换通过总线架构来实现。
总线:各组件之间信息传输的公告通路。这里的总线称为“内部总线”(或“片内总线”)。用户无法直接控制内部总线的工作

2.2.2 Inter 8086 微处理器功能结构

在这里插入图片描述

8086 CPU内部结构示意图

2.2.2.1 8086CPU内部结构
总线接口单元(BIU):

存储器和I/O设备之间的接口部件,负责对全部引脚的操作。
16位双向数据总线、20位地址总线、若干条控制总线

具体任务:负责从内存单元取出指令,并将它们送到指令队列缓冲器暂存。

CPU执行指令时,总线单元要配合执行单元,从指定的内存单元或I/O端口取出数据传送给执行单元,或者把执行单元的处理结构传送到指定的内存单元或I/O接口。

组成:20位地址加法器、4个段寄存器、16位指令指针IP、指令队列缓冲器和总线控制逻辑电路。

地址加法器: 16位的寄存器实现20位的地址寻址——由地址加法器将有关段寄存器的内容(段的起始地址)左移4位后,与偏移地址相加,形成20位的物理地址。

16位的指令指针IP:(Instruction Pointer) 用来存放下一条要执行指令在代码中的偏移地址,且与CS相结合,才能形成指向指令存放单元的物理地址。

指令缓冲队列: 在EU执行指令,且不需占用总线时,BIU会自动进行预取指令操作,将所取得的指令按先后次序存入一个6字节的指令队列寄存器,该队列寄存器按“先进先出”的方式工作,并按顺序取到EU中执行。

总线控制逻辑电路: 将8086 CPU的内部总线和外部总线相连,是8086 CPU与内存单元或I/O端口进行数据交换的必经之路。
包括16位数据总线、20位地址总线和若干条控制总线。

执行单元EU:

包含1个16位的运算器ALU、8个16位的寄存器、1个16位标志寄存器FLAGS、1个数据暂存寄存器和执行单元的控制电路

算术逻辑运算单元(ALU): 它是1个16位的运算器,可用于8位、16位二进制算术和逻辑运算,也可按指令的寻址方式计算寻址存储器所需的16位偏移量。

标志寄存器(FLAGS): 它是1个16位的寄存器,用来反映CPU运算的状态特征和存放某些控制标志。

运算暂存器: 它协助ALU完成运算,暂存参加运算的数据。

通用寄存器组: 包括4个16位的数据寄存器AX、BX、CX、DX和4个16位指针与变址寄存器SP、BP与SI、DI

EU控制电路: 负责从BIU的指令队列缓冲器中取指令,并对指令译码,根据指令要求向EU内部各部件发出控制命令,以完成各条指令规定的功能。

EU对指令的执行是从取指令操作码开始的

如果是运算操作,操作数据经过运算暂存器送入ALU,运算结果经过ALU数据总线送到相应寄存器,同时标志寄存器FLAGS根据运算结果改变状态。

2.2.2.2 8086CPU内部寄存器

包括14个16位寄存器
在这里插入图片描述

8086 CPU内部寄存器

通用寄存器

称数据寄存器,既可作为16位数据寄存器使用,也可作为两个8位数据寄存器使用。当用作16位时,称为AX、BX、CX、DX。当用作8位时,AH、BH、CH、DH存放高字节,AL、BL、CL、DL存放低字节,并且可独立寻址。

段寄存器

对物理地址的计算是在BIU中进行的,它先将段地址左移4位,然后与16位的偏移值相加。

段寄存器共有4个(CS、DS、SS、ES)。

CS(代码段寄存器): 当前使用的指令代码可以从该段寄存器指定的存储器段中取得,相应的偏移值则由IP提供。
SS(堆栈段寄存器): 指定当前堆栈的起始地址。
DS(数据段寄存器): 指示当前程序使用的数据所存放段的起始地址。
ES(附加段寄存器): 指出当前程序使用附加段地址的起始位置,该段一般用来存放原始数据或运算结果。

地址指针与变址寄存器

地址指针与变址寄存器都是16位寄存器,一般用来存放地址的偏移量(即相对于段起始地址的距离)。

堆栈指针SP用以指出在堆栈段中当前栈顶的地址。入栈(PUSH)和出栈(POP)指令SP给出栈顶的偏移地址。
基址指针BP指出要处理的数据在堆栈段中的基地址,故称为基址指针寄存器。
变址寄存器SI和DI用来存放当前数据段中某个单元的偏移量。

指令指针与标志寄存器

正常运行时,指令指针IP中存放的是BIU要取的下一条指令的偏移地址。
它具有自动加1功能,每当执行一次取指令操作时,它将自动加1,使它指向要取的下一内存单元,每取一个字节后IP内容加1,而取一个字后IP内容则加2。

标志寄存器FLAGS是16位的寄存器,8086共使用了9个有效位。6位是状态标志位,3位为控制标志位。

6个状态标志位

CF(Carry Flag)——进位标志位。当执行一个加法(或减法)运算,使最高位产生进位(或借位)时,CF为1;否则为0。
PF(Parity Flag)——奇偶标志位。该标志位反映运算结果中1的个数是偶数还是奇数。当指令执行结果的低8位中含有偶数个1时,PF=1;否则PF=0。
AF(Auxiliary carry Flag)——辅助进位标志位。当执行一个加法(或减法)运算,使结果的低4位向高4位有进位(或借位)时,AF=1;否则AF=0。
ZF(Zero Flag)——零标志位。若当前的运算结果为零,ZF=1;否则ZF=0。
SF(Sign Flag)——符号标志位。它和运算结果的最高位相同。
OF(Overflow Flag)——溢出标志位。当补码运算有溢出时,OF=1;否则OF=0。

3个控制标志位

DF(Direction Flag)——方向标志位。它用以指定字符串处理时的方向,当该位置“1”时,字符串以递减顺序处理,即地址以从高到低顺序递减。反之,则以递增顺序处理。
IF(Interrupt enable Flag)——中断允许标志位。它用来控制8086是否允许接收外部中断请求。若IF=1,8086能响应外部中断,反之则不响应外部中断。
IF的状态不影响非屏蔽中断请求(NMI)和CPU内部中断请求。
TF(Trap Flag)——跟踪标志位。它是为调试程序而设定的陷阱控制位。当该位置“1”时,8086 CPU处于单步状态,此时CPU每执行完一条指令就自动产生一次内部中断。当该位复位后,CPU恢复正常工作。

2.2.2.3 8086CPU的存储器和内存端口

8086 CPU能寻址1 MB的存储单元,在此存储空间中是以8位为一个字节顺序排序存放的。
每一字节用惟一的一个地址码标识,地址码是一个不带符号的整数,其地址范围为0~220-1,但习惯用十六进制数表示,即00000H~FFFFFH
将存储器空间按字节地址号顺序排列的方式称==“字节编址”==。
规定字的高8位字节存放在高地址单元,字的低8位字节存放在低地址单元。
低位字节的地址作为这个字的地址。

一个字数据总是位于偶地址,即偶地址对应低位字节,奇地址对应高位字节,符合这种规则存放的字数据称为 “规则字”

存储器的分段结构和物理地址的形成

将1 MB的存储空间分成若干个逻辑段,而4个当前逻辑段的基地址设置在CPU内的4个段寄存器中,即代码段寄存器CS、数据段寄存器DS、堆栈段寄存器SS和附加段寄存器ES

逻辑地址是程序使用的地址。
物理地址是指CPU和存储器进行数据交换时实际所使用的地址。由两部分组成:段基址(段起始地址高16位)和偏移地址
前者由段寄存器给出,后者是指存储单元所在的位置离段起始地址的偏移距离。当CPU寻址某个存储单元时,先将段寄存器的内容左移4位,然后加上指令中提供的16位偏移地址而形成20位物理地址。
在取指令时,CPU自动选择代码段寄存器CS,左移4位后,加上指令提供的16位偏移地址,计算出要取指令的物理地址。
堆栈操作时,CPU自动选择堆栈段寄存器SS,将其内容左移4位后,加上指令提供的16位偏移地址,计算出栈顶单元的物理地址。
每当存取操作数时,CPU会自动选择数据段寄存器(或附加段寄存器ES),将段基值左移4位后加上16位偏移地址,得到操作数在内存的物理地址。

8086的I/O端口

每个I/O接口都有一个端口或几个端口。在微机系统中给每个端口分配一个地址,称为端口地址。
8086 CPU利用地址总线的低16位作为对8位I/O端口的寻址线,8086系统访问的8位I/O端口最多有==65 536(64 KB)==个。
为便于数据总线的负载相平衡,接在高8位和低8位上的设备数目最好相等。

这篇关于第2章 微处理器结构的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/244333

相关文章

usaco 1.3 Mixing Milk (结构体排序 qsort) and hdu 2020(sort)

到了这题学会了结构体排序 于是回去修改了 1.2 milking cows 的算法~ 结构体排序核心: 1.结构体定义 struct Milk{int price;int milks;}milk[5000]; 2.自定义的比较函数,若返回值为正,qsort 函数判定a>b ;为负,a<b;为0,a==b; int milkcmp(const void *va,c

自定义类型:结构体(续)

目录 一. 结构体的内存对齐 1.1 为什么存在内存对齐? 1.2 修改默认对齐数 二. 结构体传参 三. 结构体实现位段 一. 结构体的内存对齐 在前面的文章里我们已经讲过一部分的内存对齐的知识,并举出了两个例子,我们再举出两个例子继续说明: struct S3{double a;int b;char c;};int mian(){printf("%zd\n",s

OpenCV结构分析与形状描述符(11)椭圆拟合函数fitEllipse()的使用

操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C++11 算法描述 围绕一组2D点拟合一个椭圆。 该函数计算出一个椭圆,该椭圆在最小二乘意义上最好地拟合一组2D点。它返回一个内切椭圆的旋转矩形。使用了由[90]描述的第一个算法。开发者应该注意,由于数据点靠近包含的 Mat 元素的边界,返回的椭圆/旋转矩形数据

C语言程序设计(选择结构程序设计)

一、关系运算符和关系表达式 1.1关系运算符及其优先次序 ①<(小于) ②<=(小于或等于) ③>(大于) ④>=(大于或等于 ) ⑤==(等于) ⑥!=(不等于) 说明: 前4个优先级相同,后2个优先级相同,关系运算符的优先级低于算术运算符,关系运算符的优先级高于赋值运算符 1.2关系表达式 用关系运算符将两个表达式(可以是算术表达式或关系表达式,逻辑表达式,赋值表达式,字符

Science|癌症中三级淋巴结构的免疫调节作用与治疗潜力|顶刊精析·24-09-08

小罗碎碎念 Science文献精析 今天精析的这一篇综述,于2022-01-07发表于Science,主要讨论了癌症中的三级淋巴结构(Tertiary Lymphoid Structures, TLS)及其在肿瘤免疫反应中的作用。 作者类型作者姓名单位名称(中文)通讯作者介绍第一作者Ton N. Schumacher荷兰癌症研究所通讯作者之一通讯作者Daniela S. Thomm

oracle11.2g递归查询(树形结构查询)

转自: 一 二 简单语法介绍 一、树型表结构:节点ID 上级ID 节点名称二、公式: select 节点ID,节点名称,levelfrom 表connect by prior 节点ID=上级节点IDstart with 上级节点ID=节点值 oracle官网解说 开发人员:SQL 递归: 在 Oracle Database 11g 第 2 版中查询层次结构数据的快速

Tomcat下载压缩包解压后应有如下文件结构

1、bin:存放启动和关闭Tomcat的命令的路径。 2、conf:存放Tomcat的配置,所有的Tomcat的配置都在该路径下设置。 3、lib:存放Tomcat服务器的核心类库(JAR文件),如果需要扩展Tomcat功能,也可将第三方类库复制到该路径下。 4、logs:这是一个空路径,该路径用于保存Tomcat每次运行后产生的日志。 5、temp:保存Web应用运行过程中生成的临时文件

C和指针:结构体(struct)和联合(union)

结构体和联合 结构体 结构体包含一些数据成员,每个成员可能具有不同的类型。 数组的元素长度相同,可以通过下标访问(转换为指针)。但是结构体的成员可能长度不同,所以不能用下标来访问它们。成员有自己的名字,可以通过名字访问成员。 结构声明 在声明结构时,必须列出它包含的所有成员。 struct tag {member-list} variable-list ; 定义一个结构体变量x(包含

Java Web应用程序的推荐目录结构

以前没有用过maven管理过项目的依赖,最后使用上了maven,发现通过不能方式建立出来的web应用程序目录结构基本都不一样,既然每次都要到网上搜索如何建立maven管理的Web应用程序,不如自己找百度谷歌一下。 找了半天 ,感觉比较好的maven管理的web应用程序目录结构是这个: ├── pom.xml└── src├── main│ ├── java│ │ └── myg

mysql 修改表结构语句

主要还是要参考mysql的官方网站 http://dev.mysql.com/doc/refman/5.7/en/alter-table.html 简单例子: alter table_name alter column old_column_name new_column_name int unsigned;