计算机组成原理第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

相关文章

Java编译生成多个.class文件的原理和作用

《Java编译生成多个.class文件的原理和作用》作为一名经验丰富的开发者,在Java项目中执行编译后,可能会发现一个.java源文件有时会产生多个.class文件,从技术实现层面详细剖析这一现象... 目录一、内部类机制与.class文件生成成员内部类(常规内部类)局部内部类(方法内部类)匿名内部类二、

Python中随机休眠技术原理与应用详解

《Python中随机休眠技术原理与应用详解》在编程中,让程序暂停执行特定时间是常见需求,当需要引入不确定性时,随机休眠就成为关键技巧,下面我们就来看看Python中随机休眠技术的具体实现与应用吧... 目录引言一、实现原理与基础方法1.1 核心函数解析1.2 基础实现模板1.3 整数版实现二、典型应用场景2

Java的IO模型、Netty原理解析

《Java的IO模型、Netty原理解析》Java的I/O是以流的方式进行数据输入输出的,Java的类库涉及很多领域的IO内容:标准的输入输出,文件的操作、网络上的数据传输流、字符串流、对象流等,这篇... 目录1.什么是IO2.同步与异步、阻塞与非阻塞3.三种IO模型BIO(blocking I/O)NI

JAVA封装多线程实现的方式及原理

《JAVA封装多线程实现的方式及原理》:本文主要介绍Java中封装多线程的原理和常见方式,通过封装可以简化多线程的使用,提高安全性,并增强代码的可维护性和可扩展性,需要的朋友可以参考下... 目录前言一、封装的目标二、常见的封装方式及原理总结前言在 Java 中,封装多线程的原理主要围绕着将多线程相关的操

kotlin中的模块化结构组件及工作原理

《kotlin中的模块化结构组件及工作原理》本文介绍了Kotlin中模块化结构组件,包括ViewModel、LiveData、Room和Navigation的工作原理和基础使用,本文通过实例代码给大家... 目录ViewModel 工作原理LiveData 工作原理Room 工作原理Navigation 工

Java的volatile和sychronized底层实现原理解析

《Java的volatile和sychronized底层实现原理解析》文章详细介绍了Java中的synchronized和volatile关键字的底层实现原理,包括字节码层面、JVM层面的实现细节,以... 目录1. 概览2. Synchronized2.1 字节码层面2.2 JVM层面2.2.1 ente

MySQL的隐式锁(Implicit Lock)原理实现

《MySQL的隐式锁(ImplicitLock)原理实现》MySQL的InnoDB存储引擎中隐式锁是一种自动管理的锁,用于保证事务在行级别操作时的数据一致性和安全性,本文主要介绍了MySQL的隐式锁... 目录1. 背景:什么是隐式锁?2. 隐式锁的工作原理3. 隐式锁的类型4. 隐式锁的实现与源代码分析4

MySQL中Next-Key Lock底层原理实现

《MySQL中Next-KeyLock底层原理实现》Next-KeyLock是MySQLInnoDB存储引擎中的一种锁机制,结合记录锁和间隙锁,用于高效并发控制并避免幻读,本文主要介绍了MySQL中... 目录一、Next-Key Lock 的定义与作用二、底层原理三、源代码解析四、总结Next-Key L

Spring Cloud Hystrix原理与注意事项小结

《SpringCloudHystrix原理与注意事项小结》本文介绍了Hystrix的基本概念、工作原理以及其在实际开发中的应用方式,通过对Hystrix的深入学习,开发者可以在分布式系统中实现精细... 目录一、Spring Cloud Hystrix概述和设计目标(一)Spring Cloud Hystr

MySQL中的MVCC底层原理解读

《MySQL中的MVCC底层原理解读》本文详细介绍了MySQL中的多版本并发控制(MVCC)机制,包括版本链、ReadView以及在不同事务隔离级别下MVCC的工作原理,通过一个具体的示例演示了在可重... 目录简介ReadView版本链演示过程总结简介MVCC(Multi-Version Concurr