计算机组成原理(清华王诚)

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

为什么要学习计算机组成原理这门课程
计算机组成原理是计算机专业本科生的一门统设必修的专 业基础课程。在我们系强调培养计算机应用型人才,是把这门 课程作为计算机系统平台的内容之一来安排的。
不是只有设计计算机硬件系统的人才要学这门课, 计算机专业的人员都应该对其有所了解。选择了计算 机专业,终生要与计算机系统打交道、要使用好计算 机就应该学习这门课,否则就算不上一名合格的计算 机专业人员。总不该把计算机硬件系统看作为电视机 一样的产品,开一下电源选选台能看节目了就行了。
2000: sub R15, R15 sub R1, R1 mvrd R0, 0A inc R1 add R15, R1 cmp R1, R0 jrnz 2004 cala 0664 ret
15
2、计算机中的基本硬件系统
硬件系统由 5 个功能部件组成,是课程的核心内容
计算机的 CPU 数据运算 部件 计算机控制 部件 数据存储 部件
在计算机系统的6层结构中给出的基本软件包括操 作系统和3个级别的计算机语言。 操作系统主要完成对系统中的硬、软件资源的管理 与调度分配,并向程序设计人员和计算机的操作者提供 各种服务。 3个级别的语言是机器语言(二进制代码语言)、 汇编语言(符号语言)和高级语言(算法语言),使用 它们设计程序的难易程度和工作效率差别很大。
学生应该根据自己的实际水平和将来的工作要求, 恰当地确定对自己学习这门课程的要求。 2
课程教学定位和教学要求
计算机组成原理课程教学应该建立在硬、软件组 成大体完整的系统平台之上,无疑这是一门硬件内容 为主的课程,但需要兼顾一点基础软件的课程,认为 课程内容只限于纯硬件(裸机)是很过时的认识,至少 需要了解汇编语言以及计算机系统操作使用方面的基 础知识,把学习和使用硬件结合起来。 教学过程中,要把学习原理知识和应用原理解决 实际问题结合起来,避免泛泛地讲解书本内容,解决 问题可以首先从看别人怎么用已知原理设计实现实用 系统,再考虑自己能做些什么实际工作才会使学习更 有趣味,更有用。 学生可以对自己提出主要学懂基本 原理并能通过考试为底线要求,和还有一定应用能力 的正常要求。
3、计算机系统的主要技术与性能指标
(1)计算机的字长
在计算机系统内部,通常选用多少个二进制位来 表示一个数据或一条指令是一个关键技术指标,例如 16、32或者64位,这个位数被称为计算机的字长。例 如在32位字长的计算机系统中,一个整数、一条指令 通常都用32位二进制数表示,叫做一个字,运算器、 存储器、数据和地址总线等通常都被设计成32位。字 长对计算机的处理能力和运行性能有明显影响,字长较 长有利于提高计算机的性能,但需要使用更多的硬件, 7 计算机系统的价格也会高一些。
5
计算机系统的层次结构
可以从 6 个层次分析和看待 计算机系统的基本组成。
最低的2层属于硬件部分,硬件 系统用于实现每条指令的功能,解决 程序中指令间的衔接系。 上面的3层属于软件部分,软件 由按一定规则组织起来的许多条指令 组成,完成一定的数据运算或者事务 处理功能。
软 件 系 统
应用层
高级语言层
7
ቤተ መጻሕፍቲ ባይዱ
三个级别的程序设计语言语言
以计算从1到10的累加和为例,看一看3个级别语言的程序 例子,并简单介绍该机器语言程序在计算机内部的执行过程。 BASIC程序 10 sum=0 20 for i=1 to 10 30 sum=sum+i 40 next i 50 print sum 60 end 汇编语言程序 机器语言程序(16进制) 01FF 0111 8800 000A 0910 00F1 0310 47FC CE00 0064 8F00
第2章预备性知识,第9章 补充性读物,课上不讲。
9
外存设备
计算机组成原理课程教学内容的知识结构图
数据表示、运算 数据类型 (整型、浮点型、逻辑型、BCD码、字符型) 的表示,中文的输入码、内码、字形码 进位计数制,二进制与十进制数据之间的转换,二进制数据运算规则 整数、小数的原、反、补码的编码与表示,机器数和数的真值 补码加、减法运算规则与实现算法,原码一位乘、除法的规则与实现算法 3种常用的检错纠错码的实现原理与应用场所 运算器部件 算术与逻辑运算部件ALU的原理性线路设计,串行进位与并行进位的概念与实现思路 定点运算器的功能与组成(执行运算的部件ALU、暂存数据的寄存器组REGs、特征位寄存器) 补码加减法的线路实现与溢出判别方案、原码一位乘除法的实现原理性线路 浮点数的表示、编码,它的数据范围和精度,IEEE-754标准,浮点数的加、减、乘除运算规则 控制器部件 控制器的功能与组成(PC、IR、步骤标记与转换线路、产生与提供控制信号的部件) 两种控制器类型:组合逻辑控制器和微程序控制器,同异之处与应用场合 指令的执行过程(步骤),CPU周期,指令周期,指令的串行或并行执行 指令的串行执行过程:单指令周期方案方案,多单指令周期 典型指令的执行过程(步骤),与指令格式和功能、计算机的实际组成有关 通用原理需用一个简单实际系统来加深理解,CPU的性能计算:主频、CPI、MIPS RISC 和 CISC 两种计算机追求的基本目标和实现途径(RISC机的特点 ) 指令的并行执行:指令流水线技术,追求的主要目标,实现思路,表示方法 性能指标:吞吐率,加速比,效率 流水线中的结构相关、数据相关、控制相关的产生原因与解决思路
计算机主机
数据总线 地址总线 控制总线
接口线路 数据输入 设备
接口线路 结果输出 设备
计算机 外围设备
8
计算机中的基本硬件系统
硬件系统由5个功能部件组成。数据输入设备分担 对程序和原始数据的输入功能,数据存储部件分担对 程序和数据的存储功能,数据运算部件分担对数据的 运算处理功能,结果输出设备分担对运算处理结果的 输出功能。控制器部件则是依照每条指令的运行功能 的需要,向各个部件或设备提供它们协调运行所需要 的控制信号,在整个硬件系统中起到指挥、协调和控 制的作用。 图中间部位给出的是计算机的3种类型的总线, 可以看出,计算机的5个功能部件正是通过这3种类 型的总线被有机地连接在一起,从而构成一台完整的、 可以协调运行(执行程序)的计算机硬件系统。 8
计算机系统的主要技术与性能指标
CPU的速度(续)
当取T=1s,并假定 f 为300MHz,CPI为 4,则计算出CPU 系统的性能为300/4,即 75个MIPS,即每秒执行75个百万条整 数运算指令。若有办法使这台计算机的CPI尽量靠近1,则其运 行性能就可以提高近4倍,这正是精简指令系统计算机(RISC) 所追求的目标。 若进一步细化,可安如下办法计算出一个程序中全部指令 的平均 CPI :按照指令的执行步骤数对全部指令进行分类,同 类指令的条数×这类指令的CPI,再对各类指令的计算机结果求 累加和,则累加和除以总指令条数就得到平均CPI,可以表示为 CPI平均=∑CPIj×Ij / I,这里的 j 是指令的种类编号(从0~n)。
计算机系统的主要技术与性能指标
(2)CPU的速度
衡量CPU速度,通常有两种方式。 第一种方式是使用CPU主频,即每一秒钟提供给CPU的时 钟脉冲的个数,通常用赫兹(Hz)表示,例如500MHz。但对不 同厂家、不同系列的计算机系统,只用CPU主频来说明其运行 速度则未必准确。 第二种方式是使用CPU每一秒钟能执行的指令条数,单位 是MIPS(million instructions per second),其计算公式可 以通过如下方式推导出来,T=CPI×T_IC×I,这里的T是执行一 个程序占用的时间,CPI是执行一条指令平均使用的CPU时钟个 数,T_IC是一个CPU时钟的时间长度,是CPU主频 f 的倒数 1/f, I 是这个程序的指令条数,3个数值的乘积就等于这个程序总的 7 运行时间T。由此得到:I = T / (CPI×1/f) = T×f/CPI.
从计算机组成原理的内容来讲,实在没有太多难 懂的原理,与生活中遇到的许多很平常的现象大有同 工异曲之处,它不像数学,没有多少理论推导,也没 有物理学中的高深理论,不用冥思苦想,接受它的规 定和实现方案即可。如果说难,难就难在计算机中的 问题是我们平时从未接触到、更没亲眼看见过事物, 尚未碰到先怕三分,把本来简单的问题折腾复杂了; 教师缺乏计算机系统设计的工程背景进一步加剧了这 个矛盾。
7
计算机系统的主要技术与性能指标
(4)输入输出设备的入出速度
计算机的输入输出设备是计算机系统中比较复杂的部分, 不同设备组成和运行原理各不相同,与计算机主机的连接与控 制方式也多有差异,在电子线路之外还涉及到精密机械、光学、 激光、电磁转换等许多知识。 不同的输入输出设备的运行速度各不相同,例如针式打印 机每秒只能打印几个字符,而激光打印机则可以打印多行甚至 几页打印纸的信息,键盘输入则主要取决于人员打字的速度。 显示器的屏幕大小、分辨率高低、显示字符还是图形的不同内 容、屏幕刷新频率等都对系统性能有重要影响。
计算机组成原理教学课件
王 诚 教授 清华大学计算机系
2009年10月
第 1 章
计算机系统概述
(为何要学习这门课程,怎么学,如何要求, 课程主要内容简介)
1.1 计算机系统的基本组成及其层次结构
1.2 计算机硬件的5个功能部件及其功能
1.3 计算机系统主要的技术与性能指标
1.4 1.5 计算机的体系结构、组成和实现概述 计算机发展进步、分类和拓展应用进程
汇编语言层
操作系统层 指令系统层 微体系结构层 微体系结构层
数字逻辑层 指令系统处在硬件系统和软件系 统之间,是硬、软件之间的接口部分, 计算机系统的层次结构 对两部分都有重要影响。
6
硬 件 系 统
计算机中的基本软件系统
软件是为了使用计算机而编写的各种系统的和用户 的程序,程序由一个序列的计算机指令组成。
目前的输入输出设备包含的种类特别多,远远超出了传统 入出设备的概念,特别是随着多媒体技术的发展和应用,大量 7 的电子设备已经成为现代计算机的外围设备。
4、本课程各章教学内容简介
第5、6章 第3、4章
控 制 器
第7章
运 算 器 总 线 和 入 出 接 口
第8章
高速缓存 主存储器
虚拟存储器
输入设备 输出设备
计算机中有许多知识是到处都会用到的,是学习后续多门 课程 (系统结构, 操作系统,编译原理,高级语言程序设计, 计 算机网络,数据库) 的基础,将来工作中如何想清楚、如何解决 遇到的许多问题都会涉及到计算机的硬件问题。 1
课程有多难,能不能学好
说计算机组成原理课程不是太难学是不能令人信 服的,说根本无法学好也缺乏足够的理由和证据。
“通用”一词表明计算机本身功能多样 ( 并非专用 于某种特定功能 ) ,具有完成各种运算或数据处理能力 。
4
计算机系统概述
计算机系统由硬件和软件两大部分组成。 硬件指由中央处理器、存储器以及外围设备等组成 的实际装置,硬件的作用是完成每条指令规定的功能。 指令是计算机运行的最小的功能单位,指令是指示计算 机硬件执行某种运算、处理功能的命令。 软件是为了使用计算机而编写的各种系统的和用户 的程序,程序由一个序列的计算机指令组成。指令是用 于设计程序的一种计算机语言。 一台计算机提供的全部指令构成该计算机的指令系 统。指令系统的设计质量关系到厂家和用户的利益。 硬、软件系统相互依存,分工互动,缺一不可,如 同一个健全人的物质性的肉体和精神性的智力与思维。
可以用 MFLOPS 表示对浮点数指令的运算速度。
7
计算机系统的主要技术与性能指标
(3)存储容量和读写速度
计算机中的存储器通常包括内存储器和外存储器两大类。 内存储器又被称为主存储器,通常用半导体器件实现,读写速度快,价 格较高,通常容量要小一些,例如几百MB或几到十几GB,可供CPU通过指 令直接访问。 外存储器又称辅助存储器、海量存储器等,主要包括磁盘设备、光盘设 备、磁带设备等,读写速度要慢得多,价格较低,容量很大,例如几十、几 百GB或几十TB,外存储器上的信息需要经过操作系统成批量地(而不是以 字为单位)与内存储器进行交换。 内存储器的读写周期通常为几十ns到一二百ns,读写外存储器中的几百 个字节数据的时间通常要几到十几ms,而连续读出辅存中的一大批数据所用 时间平均到每个数据上可能要更短得多。 通常还关心单位时间内能够对主存储器读写数据的总量,单位时间内能 对辅助存储器交换设据的总量。 当前的计算机系统中都采取了许多增加存储器容量和速度的技术措施。
计算机中的基本硬件系统
可以把计算机想象为一个加工处理数据的工厂, 则数据运算部件就是数据加工车间,数据存储部件就 是存放原材料、半成品和产品的库房,输入设备相当 于运入原材料的卡车,输出设备相当于运出最终产品 的卡车,控制部件则相当于承担领导指挥功能的厂长 和各个职能办公室。在领导的正确指挥下,如果能够 源源不断地取得原材料,工厂内又有存放的场所,车 间能够对这些原材料进行指定的加工处理,加工后的 产品可以畅通地运出去销售,则这个工厂(计算机) 就纳入正常运行的轨道。 前面说的还只限于硬件,当然号必须有配套的软 件系统,例如工厂就需要有管理制度、运营策略等。 8
3
1、计算机系统概述
这里说的计算机系统(computer system),是 指电子数字通用计算机系统,三个定语各自表明了计算 机系统的一个方面的特性。 “电子”一词表明使用电子线路(不同于机械、 继电器等)来实现计算机硬件的关键逻辑功能;
“数字”一词表明使用的电子线路是数字式电路 (不同于模拟电路),运算和处理的数据是二进制的离 散数据(不同于连续的电压或电流量);
相关文档
最新文档