系统架构师《计算机组成原理》
一.计算机硬件组成
计算机系统是一个硬件和软件的综合体,可以把它看成按功能划分的多级层次结构。
硬件通常是指一切看得见,摸得着的设备实体。原始的冯诺依曼计算机在结构上是以运算器为中心的,二发展到现在,已转向以存储器为中心了。如下图:
1.控制器。
控制器是分析和执行指令的部件,也是统一指挥并控制计算机各部件协调工作的中心部件,所依存的是机器指令。控制器的组成如下:
- 程序计数器PC:存储下一条要执行指令的地址。
- 指令寄存器IR:存储即将执行的指令。
- 指令译码器ID:对指令中的操作码字段进行分析解释。
- 时序部件:提供时序控制信号。
2.运算器。运算器也称为算术逻辑单元ALU,其主要功能是在控制器的控制下完成各种算术运算和逻辑运算。运算器的组成包含如下:
- 算术逻辑单元ALU:数据的算术运算和逻辑运算。
- 累加寄存器AC:通用寄存器,为ALU提供一个工作区,用在暂存数据。
- 数据缓冲寄存器DR:写内存时,暂存指令或数据。
- 状态条件寄存器PSW:存状态标志与控制标志【争议:也有将其归为控制器的】。
3.主存储器:主存储器也称为内存储器【通常简称为内存或主存】。存储现场操作的信息与中间结果,包括机器指令和数据。
4.辅助存储器。辅助存储器也称为外存储器,通常简称为外存或辅存。存储需要长期保存的各种信息。
5.输入设备:输入设备的任务是把人们编好的程序和原始数据输入到计算机中,并且将它们转换成计算机内部所能识别和接受的信息方式。按输入信息的形态可分为字符输入,图形输入,图像输入及语音输入等。目前,常见的输入设备有键盘,鼠标,扫描仪等。
6.输出设备:输出设备的任务是将计算机的处理结果以人或其他设备所能接受的形式输出计算机。目前,最常用的输出设备是打印机和显示器。有些设备既可以是输入设备,同时也可以是输出设备,例如,辅助存储器,自动控制和检测系统中使用的数模转换装置等。
二.计算机系统结构的分类
计算机的发展经历了电子管和晶体管时代,集成电路时代【中小规模,大规模,超大规模,甚大规模,极大规模】。目前,世界最高水平的单片集成电路芯片上所能容纳的元器件数已经达到80多亿个。
1.存储程序的概念
存储程序的概念是冯·诺依曼等人于1946年6月首先提出的,它简要地概括为以下几点:
- 计算机硬件应由运算器,存储器,控制器,输入设备,输出设备五大基本部件组成。
- 计算机内部采用二进制来表示指令和数据。
- 将编好的程序和原始数据事先存入存储器中,然后再启动计算机工作。这就是存储程序的基本含义。冯·诺依曼对计算机的最大贡献在于“存储程序控制”概念的提出和实现。通常把符合存储程序概念的计算机统称为冯·诺依曼型计算机。当然,现代计算机与早期计算机相比,在结构上有很多改进。冯·诺依曼型计算机的主要弱点在于存储器访问会成为瓶颈。目前,已出现了一些突破存储程序控制的计算机,统称为非冯·诺依曼型计算机,例如,数据驱动的数据流计算机,需求驱动的规约计算机和模式匹配驱动的智能计算机等等。
2.Flynn分类
根据指令流,数据流的多倍性特征对计算机系统进行分类:
1.指令流:指机器执行的指令序列。
2.数据流:指由指令流调用的数据序列,包括输入数据和中间结果,但不包括输出数据。
Flynn根据不同的指令流-数据流组织方式,把计算机系统分成以下四类。
- 单指令单数据流SISD:传统的顺序执行的单处理器计算机,其指令部件每次只对一条指令进行译码,并只对一个操作部件分配数据。
- 单指令多数据流SIMD:以并行处理机【矩阵处理机】为代表,并行处理机包括多个重复的处理单元,由单一指令部件控制,按照同一指令流的要求为它们分配各自所需的不同数据。
- 多指令流单数据流MISD:具有多个处理单元,每个处理单元按不同的指令对同一数据流及其中间结果进行不同的处理。一个处理单元的输出又作为另一个处理单元的输入。这类系统实际上很少见。
- 多指令多数据流MIMD:指能实现作业,任务,指令等各级全面并行的多机系统。如多核处理器,多处理机属于MIMD。
三.复杂指令集系统与精简指令集系统
在计算机系统结构发展的过程中,指令系统的优化设计有两个截然不同的方向,一个是增强指令的功能,设置一些功能复杂的指令,把一些原来由软件实现的,常用的功能改用硬件的指令系统来实现,这种计算机统称为复杂指令系统计算机CISC;另一个是尽量简化指令功能,只保留那些功能简单,能在一个节拍内执行完成的指令,较复杂的功能用一段子程序来实现,这种计算机系统统称为精简指令系统计算机RISC;
1.CISC指令的特点:
- 指令数量众多。指令系统拥有大量的指令,通常有100~250条。
- 指令使用频率相差悬殊。最常用的是一些比较简单的指令,仅占指令总数的20%,但在程序中出现的频率却占80%。而大部分复杂指令却很少使用。
- 支持很多种寻址方式。支持的寻址方式通常为5~20种。
- 变长的指令。指令长度不是固定的,变长的指令增加指令译码电路的复杂性。
- 指令可以对主存单元中的数据直接进行处理。典型的CISC通常都有指令能够直接对主存单元中的数据进行处理,其执行速度较慢。
- 以微程序控制为主。CISC的指令系统很复杂,难以用硬布线逻辑【组合逻辑】电路实现控制器,通常采用微程序控制。
2.RISC指令系统的特点
RISC要求指令系统简化,操作在单周期内完成,指令格式要求一致,寻址方式尽可能减少,并提高编译的效率,最终达到加快机器处理速度的目的。RISC指令系统的主要特点如下:
- 指令数量少。优先选取使用频率最高的一些简单指令和一些常用指令,避免使用复杂指令。只提供了LOAD【从存储器只读数】和STORE【把数据写入存储器】两条指令对存储器操作,其余所有的操作都在CPU的寄存器之间进行。
- 指令的寻址方式少。通常只支持寄存器寻址方式,立即寻址方式和相对寻址方式。
- 指令长度固定,指令格式种类少。因为RISC指令数量少,格式少,相对简单,其指令长度固定,指令之间各字段的划分比较一致,译码相对容易。
- 以硬布线逻辑控制为主。为了提高操作的执行速度,通常采用硬布线逻辑来构建控制器。
- 单周期指令执行采用流水线技术。因为简化了指令系统,很容易利用流水线技术,使得大部分指令都能在一个机器周期内完成。少数指令可能会需要多周期,例如,LOAD/STORE指令因为需要访问存储器,执行时间就会长一些。
- 优化的编译器:RISC的精简指令集使编译工作简单化。因为指令长度固定,格式少,寻址方式少,编译时不必具有相似功能的许多指令中进行选择,也不必为寻址方式的选择而费心,同时易于实现优化,从而可以生成高效率执行的机器代码。
- CPU中的通用寄存器数量多,一般在32个以上,有的可达上千个。
大多数RISC采用了Cache方案,使用Cache来提高取指令的速度。而且,有的RISC使用两个独立的Cache来改善性能。一个称为指令Cache,另一个称为数据Cache。这样,取指令和取数据可以同时进行,互不干扰。
四.总线
总线是一组能为多个部件分时共享的公共信息传送线路。共享是指总线上可以挂接多个部件,各个部件之间相互交换信息都可以通过这组公共线路传送;分时是指同一时刻只允许有一个部件向总线发送消息,如果出现两个或两个以上部件同时向总线发送信息,势必导致信号冲突。当然,在同一时刻,允许多个部件同时从总线上接收相同的信息。
按总线相对于CPU或其他芯片的位置可分为内部总线和外部总线两种。在CPU内部,寄存器之间和算术逻辑部件ALU与控制部件之间传输数据所用的总线称为内部总线;外部总线是指CPU与内存RAM,ROM和输入/输出设备接口之间进行通信的通路。由于CPU通过总线实现程序取指令、内存/外设的数据交换,在CPU与外设一定的情况下,总线速度是制约计算机整体性能的最大因素。
按总线功能来划分,又可分为地址总线、数据总线、控制总线三类,人们通常所说的总线都包括这三个组成部分,地址总线用来传送地址信息,数据总线用来传送数据信息,控制总线用来传送各种控制信号。
五. 真题
1. 某指令流水线由5段组成,各段所需要的时间如下:
连续输入100条指令时的吞吐率为(C)。
A.100/800?t
B.100/495?t
C.100/305?t
D.100/300?t
【解析】吞吐率是指单位时间里流水线处理机流出的结果数。对指令而言即为单位时间里执行的指令数。对于这一题,流水线的子过程所用时间不同,所以指令第一次执行时间应该为(1+3+1+2+1)△t,从第二次开始,指令在流水操作中应该看最长子过程所用时间,一共有(n-1)次,所以总时问为(1+3+1+2+1)△t+3(n-1)△t。
本题中连续输入100条指令,所以完成这100个任务所需的时间为(1+3+1+2+1)△t+3(100-1)△t=305△t,所以吞吐率为100/305△t。
版权声明:
作者: freeclashnode
链接: https://www.freeclashnode.com/news/article-1692.htm
来源: FreeClashNode
文章版权归作者所有,未经允许请勿转载。
热门文章
- 9月1日|21M/S,Shadowrocket/SSR/V2ray/Clash免费节点订阅链接每天更新
- 9月15日|20.4M/S,Shadowrocket/V2ray/SSR/Clash免费节点订阅链接每天更新
- 8月31日|20.3M/S,V2ray/Shadowrocket/SSR/Clash免费节点订阅链接每天更新
- 8月30日|22.8M/S,SSR/Clash/Shadowrocket/V2ray免费节点订阅链接每天更新
- 8月29日|22.2M/S,V2ray/Clash/SSR/Shadowrocket免费节点订阅链接每天更新
- 8月24日|19.3M/S,Shadowrocket/V2ray/Clash/SSR免费节点订阅链接每天更新
- 9月2日|21.4M/S,SSR/Shadowrocket/Clash/V2ray免费节点订阅链接每天更新
- 8月28日|20.4M/S,SSR/Clash/Shadowrocket/V2ray免费节点订阅链接每天更新
- 8月27日|21.5M/S,Clash/V2ray/SSR/Shadowrocket免费节点订阅链接每天更新
- 9月16日|18M/S,SSR/Shadowrocket/Clash/V2ray免费节点订阅链接每天更新
最新文章
- 9月20日|19.4M/S,V2ray/SSR/Shadowrocket/Clash免费节点订阅链接每天更新
- 9月19日|23M/S,Clash/SSR/Shadowrocket/V2ray免费节点订阅链接每天更新
- 9月18日|22.9M/S,Clash/Shadowrocket/V2ray/SSR免费节点订阅链接每天更新
- 9月17日|21.6M/S,SSR/Shadowrocket/V2ray/Clash免费节点订阅链接每天更新
- 9月16日|18M/S,SSR/Shadowrocket/Clash/V2ray免费节点订阅链接每天更新
- 9月15日|20.4M/S,Shadowrocket/V2ray/SSR/Clash免费节点订阅链接每天更新
- 9月14日|20M/S,Shadowrocket/SSR/Clash/V2ray免费节点订阅链接每天更新
- 9月13日|22.3M/S,Shadowrocket/V2ray/Clash/SSR免费节点订阅链接每天更新
- 9月12日|22.9M/S,Clash/V2ray/Shadowrocket/SSR免费节点订阅链接每天更新
- 9月11日|20.4M/S,Shadowrocket/Clash/SSR/V2ray免费节点订阅链接每天更新