计算机组成原理第5章-中央处理器

2023-12-07 12:38

本文主要是介绍计算机组成原理第5章-中央处理器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

写在前面:本文经过王道论坛的计算机组成原理单科书整理而来。

文章目录

    • 5.1 CPU的功能和基本结构
    • 5.2 指令执行过程
      • 5.2.1 指令周期
      • 5.2.2 指令周期的数据流
    • 5.3 数据通路的功能和基本结构
      • 5.3.1 数据通路的功能
      • 5.3.2 数据通路的基本构成
    • 5.4 控制器的功能和工作原理
    • 5.5. 指令流水线
      • 5.5.1 指令流水线的基本概念
      • 5.5.2 流水线的分类
      • 5.5.3 影响流水线的因素

5.1 CPU的功能和基本结构

在这里插入图片描述

5.2 指令执行过程

5.2.1 指令周期

指令周期: CPU从主存中取出并执行一条指令的时间称为指令周期。

指令周期通常用若干机器周期来表示,机器周期又叫CPU周期

一个机器周期又包含若干时钟周期(也称为节拍,T周期或CPU时钟周期),它是CPU操作的最基本的单位

举个例子:购买电脑时候的指标 主频3.0GHz,意思是 这个CPU每秒钟可以发出3.0G次 时钟周期(节拍)

5.2.2 指令周期的数据流

数据流是根据指令要求依次访问的数据序列。在指令执行的不同阶段,要求依次访问的数据序列是不同的。

在这里插入图片描述

5.3 数据通路的功能和基本结构

5.3.1 数据通路的功能

数据在功能部件之间传送的路径称为数据通路。 数据通路描述了信息从什么地方开始,中间经过哪个寄存器或多路开关,最后传送到哪个寄存器,这些都需要加以控制。

数据通路中专门进行数据运算的部件称为执行部件功能部件。 数据通路由控制部件控制。 数据通路的功能是实现CPU内部的运算器与寄存器及寄存器之间的数据交换

5.3.2 数据通路的基本构成

内部总线是指同一部件,如CPU内部连接各寄存器及运算部件之间的总线;
系统总线是指同一台计算机系统的各部件,如CPU、内存、通道和各类I/O接口间相互连接的总线。

数据通路的基本结构主要有以下几种:

1)CPU 内部单总线方式。

将所有寄存器的输入端和输出端都连接到一条公共通路上,这种结构比较简单,但数据传输存在较多的冲突现象,性能较低。 连接各部件的总线只有一条时,称为但总线结构; CPU中有两条或者更多的总线时,构成双总线结构或多总线结构。图5.7所示的是CPU内部总线的数据通路和控制信号。

2)CPU内部三总线方式。

将所有寄存器的输入端和输出端都连接到多条公共通路上,相比之下,单总线中一个时钟内只允许传一个数据,因而指令执行效率较低,因此采用多总线方式,同时在多个总线上传送不同的数据,提高效率。

3) 专用数据通路方式。

格局指令执行过程中的数据和地址的流动方向安排连接线路,避免使用共享的总线,性能较高,但硬件量大。

在这里插入图片描述

典型例题如下
在这里插入图片描述
解答如下
其中 取指令阶段是公共部分,几乎所有的微操作序列都需要。本题的特殊之处是对于一个加数来说是寄存器间接寻址,R0.

在这里插入图片描述

在这里插入图片描述

需要注意的是:

MDRoutE,后面加个字母E表示的是MDR和 主存之间的数据通路控制信号;没有字母E,比如MDRout指的是MDR向数据总线的连通,不是和主存之间。

5.4 控制器的功能和工作原理

微程序控制器
在这里插入图片描述

微指令的设计

在这里插入图片描述

5.5. 指令流水线

5.5.1 指令流水线的基本概念

计算机的流水线把一个重复的过程分解为若干子过程,每个子过程与其他子过程并行执行。 由于采用流水线技术只需要增加少量硬件就能把计算机的运算速度提升几倍,因此成为计算机中普遍使用的一种并行处理技术。

流水线的表示方式

通常用时空图来直观地描述流水线的工作过程。

在时空图中,横坐标表示时间,即输入流水线中的各个任务在流水线中所经过的时间。流水线中各个流水段的执行时间都相等时,横坐标就被分割成相等长度的时间段。纵坐标表示空间,即流水线的每个流水段对应各执行部件

在这里插入图片描述

3 流水线的特点

和传统的串行执行方式相比,采用流水线方式具有如下特点:
1) 把一个任务(一条指令或者一个)分解为几个有联系的子任务,每个子任务由一个专门的功能部件来执行,并依靠多个功能部件并行工作来缩短程序的执行时间。

2)流水线每个功能段部件后面都要有一个缓冲寄存器(或称为锁存器),其作用是保存本流水段的执行结果,供给下一流水段使用。

3) 流水段中各功能段的时间应尽量相等,否则将引起堵塞、断流。

4) 只有连续不断地提供同一种任务时才能发挥流水线的效率,所以在流水线中处理的必须是连续任务。

5)流水线由装入时间和排空时间。装入时间是指第一个任务进入流水线到输出流水线的时间。排空时间是指最后一个任务进入流水线到输出流水线的时间。

5.5.2 流水线的分类

按照不同的分类标准,可以把流水线份成多种不同的种类。

1 按使用级别分
部件功能级流水:将复杂的算术逻辑运算组成流水线工作方式。
例如,将浮点数加法操作分车给求阶差、对阶、尾数相加级结果规格化等4个子过程。

处理机级流水:把一条指令解释过程分成多个子过程,比如取指、译码、执行、访存和写回5个子过程。

处理机间流水:是一种宏流水,其中每个处理机完成某一专门任务,各个处理机得到的结果需要存放在与下一个处理机共享的存储器中。

2 按完成功能分

单功能流水: 只能实现一种固定的专门功能的流水线

多功能流水: 通过各段间的不同连接方式可以同时或不同时地实现多种功能的流水线。

3 按连接方式分

静态流水线: 在同一时间内,流水线的各段只能按同一种功能的连接方式工作。

动态流水线: 在同一时间内,当某些段正在实现某种运算时,另一些段却正在进行另一种运算

4按有无反馈信号分

线性流水线: 从输入到输出,每个功能段只允许经过一次,不存在反馈回路。

非线性流水线:存在反馈回路,从输入到输出的过程中,某些功能段将数次通过流水段,这种流水线适合进行线性递归的运算。

5.5.3 影响流水线的因素

在这里插入图片描述

其中数据相关也叫数据冒险,指的是在一个程序中,下一条指令会用到这一条指令计算出的结果。

这篇关于计算机组成原理第5章-中央处理器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Spring Boot 实现 IP 限流的原理、实践与利弊解析

《SpringBoot实现IP限流的原理、实践与利弊解析》在SpringBoot中实现IP限流是一种简单而有效的方式来保障系统的稳定性和可用性,本文给大家介绍SpringBoot实现IP限... 目录一、引言二、IP 限流原理2.1 令牌桶算法2.2 漏桶算法三、使用场景3.1 防止恶意攻击3.2 控制资源

Python中使用uv创建环境及原理举例详解

《Python中使用uv创建环境及原理举例详解》uv是Astral团队开发的高性能Python工具,整合包管理、虚拟环境、Python版本控制等功能,:本文主要介绍Python中使用uv创建环境及... 目录一、uv工具简介核心特点:二、安装uv1. 通过pip安装2. 通过脚本安装验证安装:配置镜像源(可

Mysql的主从同步/复制的原理分析

《Mysql的主从同步/复制的原理分析》:本文主要介绍Mysql的主从同步/复制的原理分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录为什么要主从同步?mysql主从同步架构有哪些?Mysql主从复制的原理/整体流程级联复制架构为什么好?Mysql主从复制注意

Nacos注册中心和配置中心的底层原理全面解读

《Nacos注册中心和配置中心的底层原理全面解读》:本文主要介绍Nacos注册中心和配置中心的底层原理的全面解读,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录临时实例和永久实例为什么 Nacos 要将服务实例分为临时实例和永久实例?1.x 版本和2.x版本的区别

apache的commons-pool2原理与使用实践记录

《apache的commons-pool2原理与使用实践记录》ApacheCommonsPool2是一个高效的对象池化框架,通过复用昂贵资源(如数据库连接、线程、网络连接)优化系统性能,这篇文章主... 目录一、核心原理与组件二、使用步骤详解(以数据库连接池为例)三、高级配置与优化四、典型应用场景五、注意事

电脑系统Hosts文件原理和应用分享

《电脑系统Hosts文件原理和应用分享》Hosts是一个没有扩展名的系统文件,当用户在浏览器中输入一个需要登录的网址时,系统会首先自动从Hosts文件中寻找对应的IP地址,一旦找到,系统会立即打开对应... Hosts是一个没有扩展名的系统文件,可以用记事本等工具打开,其作用就是将一些常用的网址域名与其对应

无法启动此程序因为计算机丢失api-ms-win-core-path-l1-1-0.dll修复方案

《无法启动此程序因为计算机丢失api-ms-win-core-path-l1-1-0.dll修复方案》:本文主要介绍了无法启动此程序,详细内容请阅读本文,希望能对你有所帮助... 在计算机使用过程中,我们经常会遇到一些错误提示,其中之一就是"api-ms-win-core-path-l1-1-0.dll丢失

Dubbo之SPI机制的实现原理和优势分析

《Dubbo之SPI机制的实现原理和优势分析》:本文主要介绍Dubbo之SPI机制的实现原理和优势,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Dubbo中SPI机制的实现原理和优势JDK 中的 SPI 机制解析Dubbo 中的 SPI 机制解析总结Dubbo中

Android与iOS设备MAC地址生成原理及Java实现详解

《Android与iOS设备MAC地址生成原理及Java实现详解》在无线网络通信中,MAC(MediaAccessControl)地址是设备的唯一网络标识符,本文主要介绍了Android与iOS设备M... 目录引言1. MAC地址基础1.1 MAC地址的组成1.2 MAC地址的分类2. android与I

Spring框架中@Lazy延迟加载原理和使用详解

《Spring框架中@Lazy延迟加载原理和使用详解》:本文主要介绍Spring框架中@Lazy延迟加载原理和使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、@Lazy延迟加载原理1.延迟加载原理1.1 @Lazy三种配置方法1.2 @Component