1、计算机系统结构计算机系统结构计算机系统结构计算机系统结构 Computer Architecture计算机系统结构计算机系统结构研究内容研究内容 从外部来研究计算机系统从外部来研究计算机系统 使用者所看到的物理计算机的抽象使用者所看到的物理计算机的抽象 编写出能够在机器上正确运行的程序所必须了解到的编写出能够在机器上正确运行的程序所必须了解到的计算机属性计算机属性学习目的学习目的建立计算机系统的建立计算机系统的完整概念完整概念学习计算机系统的学习计算机系统的分析方法和设计方法分析方法和设计方法了解计算机系统的了解计算机系统的最新研究成果最新研究成果计算机系统结构计算机系统结构第一章第一章 基本
2、概念基本概念 介绍计算机系统结构的一些基本知识。包括定性知识和定介绍计算机系统结构的一些基本知识。包括定性知识和定量知识两大内容。量知识两大内容。 定性知识:本课程经常使用的一些名词概念,以及对计算定性知识:本课程经常使用的一些名词概念,以及对计算机的定性认识、分析方法。机的定性认识、分析方法。 定量知识:对计算机性能进行定量评价的几个重要公式。定量知识:对计算机性能进行定量评价的几个重要公式。计算机系统结构计算机系统结构v 计算机发展的五个阶段计算机发展的五个阶段 1、19451954:电子管、继电器,定点运算、机器:电子管、继电器,定点运算、机器/汇编汇编语言语言 2、19551964:分
3、立式晶体管、铁磁心存储器、单层:分立式晶体管、铁磁心存储器、单层PCB,变址寄存器,浮点运算,高级语言批处理监控;,变址寄存器,浮点运算,高级语言批处理监控; 3、19651974:SSI、MSI,多层,多层PCB,微程序控制,微程序控制,Cache,多道程序并行,分时,多道程序并行,分时OS,IBM360/370; 4、19751990:LSI、VLSI,半导体存储器,并行处理,半导体存储器,并行处理,分布处理;分布处理; 5、1991 :VLSI,ULSI,大规模并行处理,大规模并行处理计算机系统结构计算机系统结构v 推动计算机性能提高的两个关键因素推动计算机性能提高的两个关键因素: 组成
4、器件:电子管晶体管集成电路组成器件:电子管晶体管集成电路 系统结构的改进系统结构的改进计算机系统结构计算机系统结构第一台电子计算机:第一台电子计算机:ENIAC计算机系统结构计算机系统结构ENIAC的总成本为的总成本为48万万6千千8百美元。它是一个有百美元。它是一个有18000多多只电子管,只电子管,7200只晶体二极管,只晶体二极管,10000多只电容,多只电容,7000多多只电阻,只电阻,5万多个焊点,万多个焊点,长长30.4830.48米,宽米,宽1 1米,占地面积约米,占地面积约170170平方米,平方米,3030个操作台,约相当于个操作台,约相当于1010间普通房间的大小,间普通房
5、间的大小,重达重达3030吨,消耗功率吨,消耗功率150kW150kW。计算机系统结构计算机系统结构Intel 的第一块的第一块CPU40044004,Intel4004,Intel最早的最早的CPUCPU,集成有,集成有2 2,250250个晶体管,个晶体管,晶体管之晶体管之间的距离是间的距离是10微米微米(即(即10000纳米),纳米),主频主频0.74MHz。计算机系统结构计算机系统结构 第第 6 级级 : 应应 用用 程程 序序 第第 5 级级 : 高高 级级 语语 言言 第第 4 级级 : 汇汇 编编 语语 言言 第第 3 级级 : 操操 作作 系系 统统 第第 2 级级 : 机机
6、器器 语语 言言 第第 1 级级 : 微微 程程 序序 第第 0 级级 : 硬硬 联联 逻逻 辑辑 应应 用用 软软 件件 系系 统统 软软 件件 硬硬 件件 软软 硬硬 件件 分分 界界 1.1.1 计算机系统的多级层次模型计算机系统的多级层次模型 1.1 1.1 计算机系统结构计算机系统结构计算机系统结构计算机系统结构 应应用用语语言言 第第 6 6 级级 应应用用程程序序 应应用用程程序序 信信息息处处理理系系统统 用用 户户 高高级级语语言言 第第 5 5 级级 高高级级语语言言 解解释释程程序序 编编译译程程序序 可可执执行行程程序序 高高级级语语言言程程序序员员 汇汇编编语语言言
7、第第 4 4 级级 汇汇编编语语言言 汇汇编编程程序序 可可执执行行程程序序 汇汇编编语语言言程程序序员员 系系统统原原语语 键键盘盘命命令令 第第 3 3 级级 操操作作系系统统 操操作作系系统统 系系统统资资源源 系系统统操操作作员员 计算机系统结构计算机系统结构 指指令令系系统统 第第2 2 级级 机机器器语语言言 中中央央处处理理机机 目目标标程程序序 机机器器语语言言程程序序员员 指指令令时时序序 第第1 1 级级 微微程程序序控控制制 微微程程序序控控制制 寄寄存存器器逻逻辑辑 逻逻辑辑设设计计员员 操操作作时时序序 第第0 0 级级 硬硬联联逻逻辑辑 硬硬联联逻逻辑辑 逻逻辑辑线
8、线路路 硬硬件件设设计计员员 计算机系统结构计算机系统结构 1.1.2 计算机系统结构定义计算机系统结构定义 计算机软件硬件计算机软件硬件两种定义:两种定义:u定义定义1:Amdahl于于1964年提出:年提出:程序员所看到的程序员所看到的计算机系统属性计算机系统属性,即,即概念性结构概念性结构和和功能特性功能特性看到的看到的:编写出能在机器上正确运行的程序所必编写出能在机器上正确运行的程序所必须须 了解到的。了解到的。计算机系统结构计算机系统结构主主存存储储器器主主存存控控制制器器打打印印机机磁磁盘盘机机卡卡片片机机磁磁带带机机终终 端端概念结构概念结构IOP:IO控制器控制器计算机系统结构
9、计算机系统结构功能特性:指令系统及其执行模式功能特性:指令系统及其执行模式 数据表示:数据表示:硬件能够直接认别和处理的数据类型和硬件能够直接认别和处理的数据类型和格式;格式; 寻址方式:寻址方式:最小寻址单位、寻址方式的种类和地址最小寻址单位、寻址方式的种类和地址运算等;运算等; 寄存器组织:寄存器组织:操作数寄存器、变址寄存器、控制寄操作数寄存器、变址寄存器、控制寄存器及专用寄存器的定义、数量和使用规则等;存器及专用寄存器的定义、数量和使用规则等; 指令系统:指令系统:机器指令的操作类型、格式,指令间的机器指令的操作类型、格式,指令间的排序和控制机制;排序和控制机制;计算机系统结构计算机系
10、统结构中断系统:中断系统:中断类型、中断级别和中断响应方式等;中断类型、中断级别和中断响应方式等;存储系统:存储系统:最小编址单位、编址方式、主存容量、最最小编址单位、编址方式、主存容量、最大寻址空间等;大寻址空间等;输入输出系统:输入输出系统:连接方式、数据交换方式、数据交换连接方式、数据交换方式、数据交换过程的控制等;过程的控制等;信息保护信息保护: 信息保护方式和硬件对信息保护的支持等。信息保护方式和硬件对信息保护的支持等。计算机系统结构计算机系统结构透明性概念透明性概念 本来存在的事物或属性,从某种角度看似乎不存在本来存在的事物或属性,从某种角度看似乎不存在例如:浮点数表示、乘法指令例
11、如:浮点数表示、乘法指令 对高级语言程序员、应用程序员透明对高级语言程序员、应用程序员透明 对汇编语言程序员、机器语言程序员不透明对汇编语言程序员、机器语言程序员不透明例如:数据总线宽度、微程序例如:数据总线宽度、微程序 对汇编语言程序员、机器语言程序员透明对汇编语言程序员、机器语言程序员透明 对硬件设计者、计算机维修人员不透明对硬件设计者、计算机维修人员不透明 透明度越高,编程越简单,执行效率降低透明度越高,编程越简单,执行效率降低 透明度越低,编程越复杂,执行效率提高透明度越低,编程越复杂,执行效率提高计算机系统结构计算机系统结构u定义定义2: 计算机系统结构主要研究软硬件功能分配和对软计
12、算机系统结构主要研究软硬件功能分配和对软硬件界面的确定硬件界面的确定 计算机系统由软件、硬件和固件组成,它们在功计算机系统由软件、硬件和固件组成,它们在功能上是同等的。能上是同等的。 同一种功能可以用硬件实现,也可以用软件或固同一种功能可以用硬件实现,也可以用软件或固件实现。件实现。系列计算机概念:系列计算机概念:相同系统结构,不同组成和实现相同系统结构,不同组成和实现的一系列计算机系统。的一系列计算机系统。计算机系统结构计算机系统结构 1.1.3 计算机组成计算机组成 计算机组成计算机组成指计算机系统结构的逻辑实现,主要包括指计算机系统结构的逻辑实现,主要包括: 确定数据通路的宽度确定数据通
13、路的宽度 确定各种操作对功能部件的共享程度确定各种操作对功能部件的共享程度 确定专用的功能部件确定专用的功能部件 确定功能部件的并行度确定功能部件的并行度 设计缓冲和排队策略设计缓冲和排队策略 设计控制机构设计控制机构 确定采用何种可靠性技术确定采用何种可靠性技术计算机系统结构计算机系统结构1.1.4 计算机实现计算机实现 计算机实现计算机实现是指计算机组成的物理实现,包括:是指计算机组成的物理实现,包括: 处理机、主存储器等部件的物理结构处理机、主存储器等部件的物理结构 器件的集成度和速度器件的集成度和速度 专用器件的设计专用器件的设计 器件、模块、插件、底版的划分与连接器件、模块、插件、底
14、版的划分与连接 信号传输技术信号传输技术 电源、冷却及装配技术,相关制造工艺及技术等电源、冷却及装配技术,相关制造工艺及技术等计算机系统结构计算机系统结构计算机系统结构、计算机组成和计算机实现之间的关系:计算机系统结构、计算机组成和计算机实现之间的关系: 系统结构组成实现,组成和实现的改进推动系统结系统结构组成实现,组成和实现的改进推动系统结构的进步;构的进步; 随着技术、器件和应用的发展,三者间界限越来越模糊。随着技术、器件和应用的发展,三者间界限越来越模糊。计算机系统结构计算机系统结构计算机组成计算机组成计算机实现计算机实现计算机系统结构计算机系统结构1.2.1 性能评测的常用方法性能评测
15、的常用方法 1.2.2 其他性能其他性能1.2.3 价格标准价格标准1.2 计算机系统的评价标准计算机系统的评价标准计算机系统结构计算机系统结构1.2.1 性能评测的常用方法性能评测的常用方法 以运算速度为主以运算速度为主1、时钟频率(主频)时钟频率(主频):如:只表示只表示CPU的指令处理能力的指令处理能力实际运算速度还与实际运算速度还与Cache、内存、内存、I/O、被执行程序、被执行程序等均有关等均有关计算机系统结构计算机系统结构2、指令执行速度、指令执行速度一种经典的表示运算速度的方法一种经典的表示运算速度的方法MIPS(Million Instructions Per Second)
16、以及)以及 KIPS、GIPS、TIPS其中:其中:Fz为处理机的工作主频为处理机的工作主频 CPI(Cycles Per Instruction)为为 每条指令所需的平均时钟周期数每条指令所需的平均时钟周期数 IPC为每个时钟周期平均执行的指令条数为每个时钟周期平均执行的指令条数Fz IPCCPIFz10MIPS6执行时间指令条数MFLOPS、GFLOPS、 TFLOPS计算机系统结构计算机系统结构例例1:计算:计算PentiumII 450处理机的运算速度。处理机的运算速度。解:由于解:由于PentiumII 450处理机的处理机的IPC2(或(或CPI0.5),),Fz450MHz (1
17、)不同指令的速度差别很大)不同指令的速度差别很大(2)指令使用频度差别很大)指令使用频度差别很大 MIPS9004502 Fz IPCMIPS450PentiumII主要优点:直观、方便。目前还经常使用主要优点:直观、方便。目前还经常使用 主要缺点主要缺点:计算机系统结构计算机系统结构3、等效指令速度:吉普森(、等效指令速度:吉普森(Gibson)法)法其中:其中:Wi:指令使用频度,:指令使用频度,i:指令种类:指令种类静态指令使用频度:在程序中直接统计静态指令使用频度:在程序中直接统计动态指令使用频度:在程序执行过程中统计动态指令使用频度:在程序执行过程中统计在计算机发展的早期,用加法指令
18、的运算速度来衡量计算机的在计算机发展的早期,用加法指令的运算速度来衡量计算机的速度。速度。通常:加、减法通常:加、减法50,乘法,乘法15,除法,除法5,程序控制,程序控制15,其,其他他15)(等效等效指令速度等效指令执行时间niiiniiiniiiWCPICPIMIPSWMIPSTWT1111)(计算机系统结构计算机系统结构例例2:我国最早研制的小型计算机:我国最早研制的小型计算机DJS-130,定点,定点16位,位,加法速度每秒加法速度每秒50万次,但没有硬件乘法和除法等指令。万次,但没有硬件乘法和除法等指令。用软件实现乘法和除法,速度降低用软件实现乘法和除法,速度降低100倍左右,求定
19、倍左右,求定点等效速度。点等效速度。解:解: 即每秒即每秒2万次,由于乘法和除法用软件实现,等效速万次,由于乘法和除法用软件实现,等效速度降低了度降低了25倍。倍。 MIPS0.02100/0.50.200.50.80/1MIPS)(等效指令速度计算机系统结构计算机系统结构例例3:如果浮点开平方操作:如果浮点开平方操作FPSQR的比例为的比例为2%,CPI为为100,其他浮点操作的比例为其他浮点操作的比例为23%,CPI4.0,其余指令的,其余指令的CPI1.33,计算该处理机的等效,计算该处理机的等效CPI。如果。如果FPSQR操作操作的的CPI也为也为4.0,重新计算等效,重新计算等效CP
20、I。解:解: 等效等效CPI1100 2 4 23 1.33 753.92 等效等效CPI24 251.33 752.00 由于改进了仅占由于改进了仅占2的的FPSQR操作的操作的CPI,使等效速度提,使等效速度提高了近一倍高了近一倍计算机系统结构计算机系统结构4、数据处理速率、数据处理速率PDR(processing data rate) PDRL/R其中:其中:L0.85G0.15H0.4J0.15K;R0.85M0.09N0.06P其中:其中:G是每条定点指令的位数是每条定点指令的位数M是平均定点加法时间是平均定点加法时间H是每条浮点指令的位数是每条浮点指令的位数N是平均浮点加法时间是平
21、均浮点加法时间J是定点操作数的位数是定点操作数的位数P是平均浮点乘法时间是平均浮点乘法时间K是浮点操作数的位数是浮点操作数的位数计算机系统结构计算机系统结构5、核心程序法、核心程序法 把应用程序中用的最频繁那部分核心程序作为评价计算机把应用程序中用的最频繁那部分核心程序作为评价计算机性能的标准程序。称为性能的标准程序。称为基准程序基准程序benchmark 整数测试程序:整数测试程序:Dhrystone 浮点测试程序:浮点测试程序:Linpack用用FORTRAN语言编写,主要是浮点加法和浮点乘法操作。语言编写,主要是浮点加法和浮点乘法操作。用用MFLOPS(Million Floating
22、Point Operations Per Second)表示表示GFLOPS、TFLOPS Whetstone基准测试程序基准测试程序计算机系统结构计算机系统结构6、基准测试程序套件(、基准测试程序套件(SPEC基准程序基准程序 )SPEC:System performance evaluation Cooperative目前使用最为广泛、最具权威性的测试规矩目前使用最为广泛、最具权威性的测试规矩www.spec.org 由约由约30个世界知名计算机大厂商所支持的非盈利合作组织,个世界知名计算机大厂商所支持的非盈利合作组织,包括:包括:IBM、AT&T、BULL、Compaq、CDC、DG、D
23、EC、Fujitsu、HP、Intel、MIPS、Motolola、SGI、SUN、Unisys等;等;SPEC能够全面反映机器的性能,具有很高的参考价值;能够全面反映机器的性能,具有很高的参考价值;计算机系统结构计算机系统结构1.2.2 其他性能其他性能1存储能力存储能力存储容量,速度,编址单位,编址方式,寻址方式存储容量,速度,编址单位,编址方式,寻址方式2字长字长 关键问题:指令字长与数据字长的协调关键问题:指令字长与数据字长的协调原因:程序与数据共用同一个主存储器原因:程序与数据共用同一个主存储器早期:由指令字长决定早期:由指令字长决定当前:由数据字长决定,当前:由数据字长决定,8的倍
24、数,如:的倍数,如:32位、位、64位等位等可变字长:任意组合可变字长:任意组合计算机系统结构计算机系统结构3数据类型数据类型目前常用:定点、浮点、逻辑、目前常用:定点、浮点、逻辑、已有类型:向量、串、栈、树、已有类型:向量、串、栈、树、发展方向:自定义发展方向:自定义数据表示数据表示4、指令系统、指令系统CISC:复杂指令集计算机:复杂指令集计算机RISC:精简指令集计算机:精简指令集计算机 VLIW:超长指令字:超长指令字(Very Long Instruction Word) 计算机系统结构计算机系统结构5、输入输出能力、输入输出能力输入输出方式输入输出方式中断系统中断系统输入输出接口输
25、入输出接口6、兼容性、兼容性共分共分12级:级:011,0级为完全不兼容,级为完全不兼容,11级为自身级为自身7、保护和诊断能力、保护和诊断能力程序与数据的保护程序与数据的保护诊断能力:检错、纠错、冗余、自诊断能力诊断能力:检错、纠错、冗余、自诊断能力可靠性:可靠性:RAS技术技术,可靠性,可靠性R、可用性、可用性A、可维护性、可维护性S计算机系统结构计算机系统结构1.2.3 价格标准价格标准1价格与性能的关系:价格与性能的关系:摩尔定理:摩尔定理:每隔每隔3 年芯片的集成度翻两翻年芯片的集成度翻两翻 用同样的价格,五年之后能买到性能高十倍的机器用同样的价格,五年之后能买到性能高十倍的机器 计
26、算机系统每年的折旧率为计算机系统每年的折旧率为75左右左右2硬件与软件的价格比例:硬件与软件的价格比例: 硬件的比例下降,软件的比例上升硬件的比例下降,软件的比例上升 目前软件价格已经超过硬件价格目前软件价格已经超过硬件价格计算机系统结构计算机系统结构微电子发展的神奇规律微电子发展的神奇规律Moores Law成本 硬件 软件 年代 70 年代软件所占的成本越来越高软件所占的成本越来越高计算机系统结构计算机系统结构1.3 计算机系统的设计技术计算机系统的设计技术1.3.1 几个定量原理几个定量原理 1.3.2 软硬件取舍软硬件取舍1.3.3 软件兼容性软件兼容性1.3.4 计算机系统设计方法计
27、算机系统设计方法 计算机系统结构计算机系统结构1 1、AmdahlAmdahl定律(加快经常性事件原理定律(加快经常性事件原理)其中:其中:S Sn n 全局加速比;全局加速比; T To o 原执行时间(原执行时间(oldold);); T Tn n 新执行时间(新执行时间(newnew);); S Se e 被改进部分的局部加速比;被改进部分的局部加速比; F Fe e 被改进部分原执行时间占原来总时间被改进部分原执行时间占原来总时间的百分比。的百分比。eeenonSFFTTS)1(11.3.1 几个定量原理几个定量原理性能改善的极限值受Fe值限制。计算机系统结构计算机系统结构 例例4:假
28、设将某一部件的处理速度加快到:假设将某一部件的处理速度加快到10倍,该部倍,该部件的原处理时间为整个运行时间的件的原处理时间为整个运行时间的40%,则采用加快,则采用加快措施后能使整个系统的性能提高多少?措施后能使整个系统的性能提高多少?Sn10 60 41 010 6 41 5 6.解:解: 由题意可知:由题意可知:Fe=0.4, Se=10,根据,根据Amdahl定律,定律,计算机系统结构计算机系统结构2、 CPI与程序执行时间与程序执行时间Te CPI是衡量是衡量CPU执行指令效率的重要指标。执行指令效率的重要指标。的加权平均值。为所有,它表明)(或者写为)(的关系与一式,可以得到比较上
29、面第一式与最后写另一方面,我们又可以,iniiiniiiniiiniiiniieniiiiieCPICPICPIICICCPICPIICCPIICCYCLECPIICCYCLECPIICTTICICfCYCLECYCLECPIICTCYCLECPIICT CPICPI)()( 1 其中: 11i1111计算机系统结构计算机系统结构3、 存储器访问的局部性原理存储器访问的局部性原理实质:实质:根据程序运行的最近情况,可以较为精确的预测出最根据程序运行的最近情况,可以较为精确的预测出最近的将来将要访问哪些指令和数据。近的将来将要访问哪些指令和数据。访问的局部性原理是构成层次化存储系统的理论基础。访
30、问的局部性原理是构成层次化存储系统的理论基础。时间局部性:时间局部性:最近访问过的代码在很短的时间内有可能最近访问过的代码在很短的时间内有可能被再次访问;主要对应于循环语句;被再次访问;主要对应于循环语句;空间局部性:空间局部性:与刚被访问过的指令或数据相邻的指令或数与刚被访问过的指令或数据相邻的指令或数据有可能马上被访问;主要对应于顺序执行的语句。据有可能马上被访问;主要对应于顺序执行的语句。计算机系统结构计算机系统结构1.3.2 软硬件取舍软硬件取舍关键问题:关键问题:性能与价格的关系性能与价格的关系软件与硬件实现的特点:软件与硬件实现的特点:硬件实现:速度快、成本高;灵活性差、占用内存少
31、硬件实现:速度快、成本高;灵活性差、占用内存少软件实现:速度低、复制费用低;灵活性好、占用内存多软件实现:速度低、复制费用低;灵活性好、占用内存多计算机系统结构计算机系统结构兼容种类:兼容种类:1)向后兼容:在某一时间生产的机器上运行的目标软件能)向后兼容:在某一时间生产的机器上运行的目标软件能够直接运行于更晚生产的机器上。够直接运行于更晚生产的机器上。2)向前兼容:)向前兼容:3)向上兼容:在低档机器上运行的目标软件能够直接运行)向上兼容:在低档机器上运行的目标软件能够直接运行于高档机器上。于高档机器上。4)向下兼容:)向下兼容:其中向后兼容是最根本特征,必须做到。其中向后兼容是最根本特征,
32、必须做到。原因原因:软件相对于硬件的成本越来越贵:软件相对于硬件的成本越来越贵已积累了大量成熟的系统软件和应用软件。已积累了大量成熟的系统软件和应用软件。1.3.3 软件兼容性设计方法软件兼容性设计方法计算机系统结构计算机系统结构 实现方法:实现方法:在系统结构基本不变的基础上,根据不同在系统结构基本不变的基础上,根据不同性能的要求和当时的器件发展情况,设计出各种性能、性能的要求和当时的器件发展情况,设计出各种性能、价格不同的计算机系统。价格不同的计算机系统。 一种系统结构可以有多种组成,一种组成可以有多种一种系统结构可以有多种组成,一种组成可以有多种物理实现。物理实现。 系列机定义:系列机定
33、义:具有相同的系统结构,不同组成和实现具有相同的系统结构,不同组成和实现的一系列计算机系统的一系列计算机系统方法方法1:系列机方法:系列机方法计算机系统结构计算机系统结构 采用系列机的主要优点:采用系列机的主要优点: 软件兼容,可移植性好软件兼容,可移植性好 插件、接口等兼容插件、接口等兼容 便于实现机间通信便于实现机间通信 便于维修、培训便于维修、培训 有利于提高产量、降低成本有利于提高产量、降低成本 采用系列机的主要缺点:采用系列机的主要缺点:限制了系统结构的发展限制了系统结构的发展计算机系统结构计算机系统结构方法方法2:模拟与仿真:模拟与仿真 Simulation vs Emulatio
34、n 定义:定义:在一台现有的计算机上实现另一台计算机的指在一台现有的计算机上实现另一台计算机的指令系统。令系统。全部用软件实现的叫全部用软件实现的叫模拟模拟用硬件、固件或软件、硬件、固件混合实现的叫用硬件、固件或软件、硬件、固件混合实现的叫仿真仿真计算机系统结构计算机系统结构 模拟的实现方法模拟的实现方法 在在A计算机上通过解释方法实现计算机上通过解释方法实现B计算机的指令系统,计算机的指令系统,即即B机器的每一条指令用一段机器的每一条指令用一段A机器的程序进行解释执机器的程序进行解释执行。行。 A机器称为宿主机,机器称为宿主机,B机器称为虚拟机。机器称为虚拟机。 仿真的实现方法仿真的实现方法
35、直接用直接用A机器的一段微程序解释执行机器的一段微程序解释执行B机器的每条指令。机器的每条指令。A机器称为宿主机,机器称为宿主机,B机称为目标机。机称为目标机。计算机系统结构计算机系统结构 优缺点比较优缺点比较模拟方法速度低,仿真方法速度高模拟方法速度低,仿真方法速度高仿真需要较多的硬件(包括控制存储器)仿真需要较多的硬件(包括控制存储器)系统结构差别大的机器难于完全用仿真方法来实现系统结构差别大的机器难于完全用仿真方法来实现除了解释方法之外,也可以通过编译方法实现除了解释方法之外,也可以通过编译方法实现计算机系统结构计算机系统结构方法方法3:统一高级语言:统一高级语言 方法:采用同一种不依赖
36、于任何具体机器的高级语方法:采用同一种不依赖于任何具体机器的高级语言编写各种系统软件和应用软件。言编写各种系统软件和应用软件。 短期内很难实现。短期内很难实现。 计算机系统结构计算机系统结构 三种方法比较:三种方法比较: 采用统一高级语言最好,是努力的目标采用统一高级语言最好,是努力的目标 系列机是暂时性方法,也是目前最好的方法系列机是暂时性方法,也是目前最好的方法仿真的速度低,芯片设计的负担重仿真的速度低,芯片设计的负担重计算机系统结构计算机系统结构1.3.4 计算机系统设计过程计算机系统设计过程方法方法1:由上向下(:由上向下(Top-Down) 设计过程:由上向下设计过程:由上向下 面向
37、应用的数学模型面向应用的数学模型面向应用的高级语言面向应用的高级语言面向这种应面向这种应用的操作系统用的操作系统面向操作系统和高级语言的机器语言面向操作系统和高级语言的机器语言面面向机器语言的微指令系统和硬件实现向机器语言的微指令系统和硬件实现 应用场合:应用场合: 专用计算机的设计(早期计算机的设计)专用计算机的设计(早期计算机的设计) 特点:特点: 对于所面向的应用领域,性能(性能价格比)很高对于所面向的应用领域,性能(性能价格比)很高 随着通用计算机价格降低,目前已经很少采用随着通用计算机价格降低,目前已经很少采用计算机系统结构计算机系统结构方法方法2:由下向上(:由下向上(Bottom
38、-Up) 设计过程:设计过程:1)根据当时的器件水平,设计微程序机器级和传统机器根据当时的器件水平,设计微程序机器级和传统机器2)根据不同的应用领域设计多种操作系统、汇编语言、高根据不同的应用领域设计多种操作系统、汇编语言、高级语言编译器等级语言编译器等3)最后设计面向应用的虚拟机器级。最后设计面向应用的虚拟机器级。 应用场合:应用场合:在计算机早期设计中(在计算机早期设计中(6070年代)广为采用年代)广为采用 特点:特点:容易使软件和硬件脱节,整个计算机系统的效率降低。容易使软件和硬件脱节,整个计算机系统的效率降低。计算机系统结构计算机系统结构方法方法3:中间开始(:中间开始(Middle
39、-Out)用于系列计算机的设计过程中用于系列计算机的设计过程中应用虚拟机应用虚拟机高级语言虚拟机高级语言虚拟机汇编语言虚拟机汇编语言虚拟机 向上向上操作系统虚拟机操作系统虚拟机 从中间开始从中间开始传统机器级传统机器级微程序级微程序级 向下向下硬联逻辑级硬联逻辑级计算机系统结构计算机系统结构1.4 计算机系统结构的发展计算机系统结构的发展1.4.1 冯冯诺依曼结构诺依曼结构1.4.2 器件发展的影响器件发展的影响计算机系统结构计算机系统结构 于于1936年年1946年形成,冯年形成,冯诺依曼等人于诺依曼等人于1946年提出年提出输 入 设 备输 出 设 备运 算 器ALU控 制 器存 储 器1
40、.4.1 冯冯诺依曼结构诺依曼结构计算机系统结构计算机系统结构1、特点:存储程序,运算器为中心、特点:存储程序,运算器为中心1)存储器是字长固定的、顺序线性编址的一维结构。存储器是字长固定的、顺序线性编址的一维结构。2)存储器提供可按地址访问的一级地址空间,每个地址存储器提供可按地址访问的一级地址空间,每个地址是唯一定义的。是唯一定义的。3)由指令形式的低级机器语言驱动。由指令形式的低级机器语言驱动。4)指令顺序执行,即一般按照指令在存储器中存放的顺指令顺序执行,即一般按照指令在存储器中存放的顺序执行,程序分支由转移指令实现。序执行,程序分支由转移指令实现。5)运算器为中心,输入输出设备与存储
41、器之间的数据传运算器为中心,输入输出设备与存储器之间的数据传送都途经运算器。运算器、存储器、输入输出设备的送都途经运算器。运算器、存储器、输入输出设备的操作以及它们之间的联系都由控制器集中控制。操作以及它们之间的联系都由控制器集中控制。计算机系统结构计算机系统结构 不变的:不变的:存储程序存储程序 改变的:改变的:存储器为中心存储器为中心1) 从基于串行算法变为适应并行算法,出现了向量计从基于串行算法变为适应并行算法,出现了向量计算机,并行计算机、多处理机等。算机,并行计算机、多处理机等。2) 高级语言与机器语言的语义距离缩小。高级语言与机器语言的语义距离缩小。3) 硬件子系统与操作系统和数据
42、库管理系统软件相适硬件子系统与操作系统和数据库管理系统软件相适应,出现了面向操作系统机器和数据库计算机等。应,出现了面向操作系统机器和数据库计算机等。4) 从传统的指令驱动型改变为数据驱动型和需求驱动从传统的指令驱动型改变为数据驱动型和需求驱动型,出现了数据流机器和归约机。型,出现了数据流机器和归约机。2、现代处理机对冯、现代处理机对冯诺依曼结构的改进诺依曼结构的改进计算机系统结构计算机系统结构5) 为适应特定应用环境而出现了各种专用计算机,如为适应特定应用环境而出现了各种专用计算机,如过程控制计算机等。过程控制计算机等。6) 为获得高可靠性而研制容错计算机。为获得高可靠性而研制容错计算机。7
43、) 功能分散化、专业化,出现了各种功能分布计算机,功能分散化、专业化,出现了各种功能分布计算机,包含外围处理机、通信处理机等。包含外围处理机、通信处理机等。8) 出现了与大规模、超大规模集成电路相适应的计算出现了与大规模、超大规模集成电路相适应的计算机系统结构。机系统结构。9) 出现了处理非数值化信息的智能计算机,例如自然出现了处理非数值化信息的智能计算机,例如自然语言、声音、图形和图象处理等。语言、声音、图形和图象处理等。计算机系统结构计算机系统结构1.4.2 器件发展对系统结构的影响器件发展对系统结构的影响第第1代至第代至第4代计算机以器件来划分代计算机以器件来划分: 第一代:电子管第一代
44、:电子管(Valve) 第二代:晶体管第二代:晶体管(Transistor) 第三代:集成电路第三代:集成电路(LSI) 第四代:大规模集成电路第四代:大规模集成电路(VLSI)在相当长时间内,是提高计算机速度的主要途径在相当长时间内,是提高计算机速度的主要途径 计算机系统结构计算机系统结构1、器件发展的特点:、器件发展的特点:1) 集成度迅速提高集成度迅速提高摩尔定律摩尔定律可从系统结构的两个方面提高处理机速度:可从系统结构的两个方面提高处理机速度: 提高提高IPC,提高到,提高到8以上,以上, 采用更深度的流水线和并行处理技术采用更深度的流水线和并行处理技术2) 提高提高速度空间不大速度空
45、间不大器件速度提高的余地已经很小,将来提高处理机速度更多依靠器件速度提高的余地已经很小,将来提高处理机速度更多依靠系统结构系统结构、组成和实现技术、组成和实现技术的发展的发展 计算机系统结构计算机系统结构(3) 价格直线下降价格直线下降 CPU芯片的价格每年要下降芯片的价格每年要下降80%(4) 可靠性越来越高可靠性越来越高 芯片可靠性达到芯片可靠性达到108小时。小时。计算机系统结构计算机系统结构 器件速度与处理机工作主频器件速度与处理机工作主频2、器件发展对组成技术的影响、器件发展对组成技术的影响 器件速度与指令执行时间器件速度与指令执行时间40多年来,器件速度提高小于多年来,器件速度提高
46、小于104;指令执行加快;指令执行加快108。计算机系统结构计算机系统结构3、器件发展对设计方法的影响、器件发展对设计方法的影响 计算机组成技术下移计算机组成技术下移原来只有在巨型机、大型机种采用的技术,已经用到微型机中原来只有在巨型机、大型机种采用的技术,已经用到微型机中 计算机设计方法下移计算机设计方法下移第第1代计算机,几乎全部由硬件人员设计代计算机,几乎全部由硬件人员设计第第2、3、4代,由软件、硬件人员共同设计代,由软件、硬件人员共同设计将来:除器件设计之外,主要是软件设计将来:除器件设计之外,主要是软件设计 逻辑设计方法改变逻辑设计方法改变过去逻辑设计很重要,尽量节省每一个芯片,每
47、一个门过去逻辑设计很重要,尽量节省每一个芯片,每一个门目前的设计主要考虑:了解市场,尽量选择通用芯片、标准芯片目前的设计主要考虑:了解市场,尽量选择通用芯片、标准芯片结构化设计,规整、易读、易诊断结构化设计,规整、易读、易诊断计算机系统结构计算机系统结构1.5.1 常见分类方法常见分类方法1.5.2 三三种通用分类方法种通用分类方法1.5 计算机系统的分类计算机系统的分类 计算机系统结构计算机系统结构1.5 计算机系统的分类计算机系统的分类 1.5.1 常见分类方法常见分类方法1、按规模划分、按规模划分 种类:巨型机、大型机、中型机、小型机、微型种类:巨型机、大型机、中型机、小型机、微型机等。
48、机等。 划分原则:以性能为表征,按价格来划分划分原则:以性能为表征,按价格来划分 存在问题:划分的标准是随时间而变化,存在问题:划分的标准是随时间而变化,每年每年左右降低一个等级左右降低一个等级计算机系统结构计算机系统结构2、按用途划分、按用途划分 种类:科学计算、事务处理、实时控制、工作站、服务器种类:科学计算、事务处理、实时控制、工作站、服务器、家用计算机等。、家用计算机等。 发展方向:具备上述所有功能的通用处理机发展方向:具备上述所有功能的通用处理机3、按数据类型划分、按数据类型划分 种类:定点机、浮点机、向量机等。种类:定点机、浮点机、向量机等。计算机系统结构计算机系统结构4、按处理机
49、个数和种类划分、按处理机个数和种类划分 种类:单处理机、并行处理机、多处理机、分布处理机、种类:单处理机、并行处理机、多处理机、分布处理机、关联处理机、超标量处理机、超流水线处理机、关联处理机、超标量处理机、超流水线处理机、SMP(对(对称多处理机)、称多处理机)、MPP(大规模并行处理机)、机群(大规模并行处理机)、机群(Cluster)系统等。)系统等。5、按所使用的器件划分、按所使用的器件划分 种类:第一代(种类:第一代(Valve)、第二代()、第二代(Transitor)、第三代()、第三代(SSI和和MSI)、第四)、第四代(代(LSI和和VLSI)等。)等。计算机系统结构计算机系
50、统结构1、佛林(、佛林(Flynn)分类法)分类法1966年年Michael J Flynn提出提出按指令流和数据流的多倍性特征对计算机系统进行分类按指令流和数据流的多倍性特征对计算机系统进行分类指令流:指令流:机器执行的指令序列机器执行的指令序列数据流:数据流:指令流调用的数据序列,包括输入数据和中间结果指令流调用的数据序列,包括输入数据和中间结果多倍性(多倍性(multiplicity):):在系统性能瓶颈部件上同时处于同一在系统性能瓶颈部件上同时处于同一执行阶段的指令或数据的最大可能个数执行阶段的指令或数据的最大可能个数1.5.2 三种通用分类方法三种通用分类方法计算机系统结构计算机系统