计算机系统结构(2008年春).ppt

上传人:ga****84 文档编号:389381 上传时间:2018-09-30 格式:PPT 页数:58 大小:505.29KB
下载 相关 举报
计算机系统结构(2008年春).ppt_第1页
第1页 / 共58页
计算机系统结构(2008年春).ppt_第2页
第2页 / 共58页
计算机系统结构(2008年春).ppt_第3页
第3页 / 共58页
计算机系统结构(2008年春).ppt_第4页
第4页 / 共58页
计算机系统结构(2008年春).ppt_第5页
第5页 / 共58页
点击查看更多>>
资源描述

1、计算机系统结构(2012年春)-指令集设计:基础知识,山东大学计算机学院 戴鸿君 ,大纲,数据表示CISC与RISCLi-2.1,Li-2.2,Li-2.4Pa-B.2, Pa-B.3,2018/9/30,,2,数据表示,数据表示与数据结构 高级数据表示 浮点数尾数基值大小和下溢处理方法的选择(选讲),2018/9/30,3,,数据表示,定义:机器硬件能直接识别和引用的数据类型。条件:相应的运算指令和运算硬件(处理部件)。分类:基本数据表示、高级数据表示、自定义数据表示。目标:缩小高级语言和机器语言间的语义差别提高性能/价格比节省处理时间和存储空间实现:最小的存储空间、最简单的存取算法。,20

2、18/9/30,4,,数据表示与数据结构,数据表示:由硬件实现的数据类型数据结构:面向计算机系统软件、面向应用领域所需处理的数据类型。由软件实现的数据类型。目标:最大限度满足应用要求、最简化的方法实现。实现:通过数据表示和软件映象相结合方法实现。数据表示是数据类型的子集。数据表示的确定实质上是软、硬件的取舍问题数据结构和数据表示是软、硬件的界面,2018/9/30,5,,数据类型,定义:具有一组值的集合,且定义了作用于该集合的操作集。目的:防止不同类型数据间的误操作。分类:基本类型、结构类型。基本数据类型内容:二进制位、二进制位串、整数、十进制数、浮点数、字符、布尔数等。结构数据类型定义:由一

3、组相互有关的数据元素复合而成的数据类型。分类:系统数据类型、用户自定义数据类型内容:数组、字符串、向量、堆栈、队列、记录等,2018/9/30,6,,数据表示中应表达的内容,数值的表达进位制数、负数、小数点的方式 字符和符号的表达 ASCII码 数据单位的表达 字:逻辑单位,一条指令处理的数据单位。字节、半字、字、双字 数据的属性类型、存放的位置、对数据的约束,2018/9/30,7,,数据表示的发展,定点数据表示用定点数表示浮点数不方便而低效 50年代提出变址操作,为向量、阵列提供方便。用循环遍历向量和阵列可变长字符串数据表示 支持串数据结构的实现用于输入、输出、事务处理和编译,2018/9

4、/30,8,,高级数据表示,自定义数据表示(Self_defining)带标识符的数据表示 数据描述符 向量数组数据表示 堆栈数据表示,2018/9/30,9,,带标识符的数据表示,主要用于指明数据类型(如二进制整数、十进制整数等,也可用于指明及其内部所用信息的各种类型。 对高级程序员透明。,2018/9/30,10,,带标识符的数据表示的优缺点,优点:简化指令系统和程序设计简化编译程序便于一致性校验能由硬件自动完成数据类型的变换支持数据库系统的实现与数据类型无关的要求为软件调试和应用软件开发提供支持;,缺点:使程序所占用的主存空间增加(如下图)降低指令的执行速度;,2018/9/30,11,

5、,采用标识符缩短操作码而节省程序空间,通常有面积B面积A,2018/9/30,12,,数据描述符,000,数据,描述符,数据,目的:描述复杂和多维的结构类型。,2018/9/30,13,,数据描述符与带标识符的区别,标识符是和每一个数据相连的,合存在一个存储单元中,描述单个数据的类型特征。 描述符是和数据分开存放的,专门用来描述所要访问的数据是整块数据还是单个数据,访问该数据块或数据元素需要的地址以及其他特征信息等。,2018/9/30,14,,数据描述符,实现阵列数据的索引比变址方法实现的好,而且能检查程序设计中阵列越界错误。 为向量、数组数据结构的实现提供一定的支持,有利于简化编译中的代码

6、生成。工作过程:如下图,2018/9/30,15,,描述符的工作过程,2018/9/30,16,,2018/9/30,17,,堆栈数据表示,有利于编译和子程序调用。 堆栈机器:具有堆栈数据表示的机器。有若干高速寄存器组成的硬件堆栈,并附加控制电路让它与主存中的堆栈区在逻辑上组成一个整体,使堆栈的访问速度是寄存器的,堆栈的容量是主存的;有很丰富的堆栈操作类指令(数十条)且功能很强,直接可对堆栈中的数据进行各种运算和处理;,2018/9/30,18,,堆栈数据表示(续),有力地支持高级语言程序的编译;算术赋值表达式 F=A*B+C/(D-E)逆波兰表达式 AB*CDE-/+有力地支持子程序的嵌套和

7、递归调用。减少大量辅助性工作多使用零地址指令存储效率高,2018/9/30,19,,浮点数,二进制的定点数符号数值、反码、补码浮点数数据表示IEEE标准754 1985年 提出三部分:符号位、指数、尾数浮点数尾数基值的选择浮点数尾数下溢处理方法,2018/9/30,20,,IEEE 754标准,William Kahan加州大学伯克利分校数学系教授帮助Intel公司设计了8087浮点处理器1989年图灵奖This standard defines a family of commercially feasible ways for new systems to perform binary f

8、loating-point arithmetic,2018/9/30,,21,IEEE754表示:,若E=0且M=0,N为0若E=0且M0,N=(-1)S2-126 (0.M),非规格化数;若1E254,N=(-1)S2E-127 (1.M),规格化数;若E=255且M 0,N=NaN(非数值);若E=255且M = 0,N= (-1)S (无穷大),2018/9/30,22,,浮点数尾数下溢处理方法,2018/9/30,23,,寻址方式,寻址方式:是指令按什么方式寻找(访问)到所需的操作数或信息的。寻址方式分析 逻辑地址与主存物理地址,2018/9/30,24,,寻址方式分析,面向主存:主要

9、访问内存,少量访问寄存器面向通用寄存器:多数在寄存器,少量在内存面向堆栈:主要在堆栈,可减轻编译负担,2018/9/30,25,,寻址方式分析,寻址方式的种类立即寻址、直接寻址、间接寻址、相对寻址、变址寻址、寄存器寻址 寻址方式在指令中的指明方式 操作码占用位:DJS200地址码设置寻址方式字段:VAX-11寻址灵活、操作码短,2018/9/30,26,,逻辑地址与主存物理地址,逻辑地址:程序员编写程序时使用的地址。物理地址:程序在主存中的实际地址。早期,二者一致一般来讲,逻辑地址的空间大于物理地址的空间。 因此,映射实际上是压缩。,2018/9/30,27,,再定微技术,静态再定位:用软件方

10、法把目标程序的逻辑地址变换成物理地址,而在程序的执行过程中,物理地址不再改变。动态再定位:在执行每条指令时才形成访存物理地址的方法。通过基址寻址。,2018/9/30,28,,变址寻址与基址寻址区别,变址寻址:支持向量、数组,实现循环;基址寻址:支持逻辑地址到物理地址的变换,实现动态再定位;存储保护:设置多对上、下界寄存器。,2018/9/30,29,,整数边界存储概念,信息在存储器中按整数边界存储的概念让任何时候所需的信息都只用一个存储周期访问到,要求信息在主存中存放的地址必须使该信息宽度的整数倍。即字节信息地址:XXXXX半字信息地址:XXXX0单字信息地址:XXX00双字信息地址:XX0

11、00保证访存速度造成浪费,2018/9/30,30,,对齐的概念,2018/9/30,31,,2018/9/30,,32,指令集的形式,堆栈型累加器型存储器-寄存器型寄存器-寄存器型,2018/9/30,,33,2018/9/30,,34,2018/9/30,,35,大小端的概念,如果将一个32位的整数0x12345678存放到一个整型变量(int)中,这个整型变量采用大端或者小端模式在内存中的存储由下表所示。地址偏移 大端模式 小端模式 0x00 12(OP0) 78(OP3) 0x01 34(OP1) 56(OP2) 0x02 56(OP2) 34(OP1) 0x03 78(OP3) 12

12、(OP0),2018/9/30,,36,2018/9/30,,37,按简化指令功能的方向发展,精简指令系统思想的提出IBM公司的John Cocke设计一个电话交换系统的控制器,1979年研制出32位的IBM 801 小型计算机,120条指令,10MIPS(1千万条指令/秒)。1979年,美国加州大学伯克利分校David Patterson研究小组开始研究RISC系统。1981年Patterson等人研制了32位RISC I微处理器,共31种指令,3种数据类型,2种寻址方式;研制周期10个月,比当时最先进的MC68000和Z8002快3至4倍;1983年又研制了RISC II,指令种类扩充到3

13、9种,单一的变址寻址方式,通用寄存器138个,CISC的主要特点,指令系统庞大,指令功能复杂,指令格式、寻址方式多;绝大多数指令需多个机器周期完成;各种指令都可访问存储器;采用微程序控制;有专用寄存器,少量;难以用优化编译技术生成高效的目标代码程序;,CISC存在的问题,指令系统庞大,指令功能复杂,指令格式、寻址方式多;执行速度慢;难以优化编译,编译程序复杂;80%的指令在20%的运行时间使用;无法并行;无法兼容;,从CISC到RISC,CISC指令系统存在的问题:20与80规律CISC中,大约20的指令占据了80的处理机时间。其余80指令:使用频度只占20的处理机运行时间VLSI技术的发展引

14、起的问题VLSI工艺要求规整性,RISC正好适应了VLSI工艺的要求主存与控存的速度相当,简单指令没有必要用微程序实现,复杂指令用微程序实现与用简单指令组成的子程序实现没有多大区别;由于VLSI的集成度迅速提高,使得生产单芯片处理机成为可能。,从CISC到RISC(续),软硬件的功能分配问题复杂的指令使指令的执行周期大大加长一般CISC处理机的指令平均执行周期都在4以上,有些在10以上CISC增强了指令系统功能,简化了软件,但硬件复杂了,设计周期加长。,减少CPI是RISC思想的精华,程序执行时间的计算公式: P = I CPI T 其中:P是执行这个程序所使用的总的时间;I是这个程序所需执行

15、的总的指令条数;CPI 是每条指令执行的平均周期数T是一个周期的时间长度。RISC的速度要比CISC快3倍左右,关键是RISC的CPI减小了,硬件方面:采用硬布线控制逻辑,减少指令和寻址方式的种类,使用固定的指令格式,采用LOAD/STORE结构,指令执行过程中设置多级流水线等。软件方面:十分强调优化编译技术的作用RISC设计思想也可以用于CISC中,例如:Intel公司的80x86处理机的CPI在不断缩小8088的CPI大于2080286的CPI大约是5.580386的CPI进一步减小到4左右80486的CPI已经接近2Pentium处理机的CPI已经与RISC十分接近 目前,超标量、超流水

16、线处理机的CPI已经达到0.5,实际上用IPC (Instruction Per Cycle)更确切。,RISC的定义,90年代初,IEEE的Michael Slater对RISC定义的描述:RISC为使流水线高效率执行,应具有:简单而统一格式的指令译码大部分指令可以单周期执行完成仅Load和Store指令可以访问存储器简单的寻址方式采用延迟转移技术采用LOAD延迟技术RISC为使优化编译器便于生成优化代码,应具有:三地址指令格式、较多的寄存器、对称的指令格式,RISC的设计原则,使用频度很高的指令(精简指令条数)大大减少寻址方式(指令字等长)所有指令在一个机器周期完成扩大通用寄存器个数采用硬

17、联控制实现,提高速度通过精简指令和优化设计编译程序,以简单有效的方式支持高级语言,CISC与RISC的主要特征对比,主要RISC产品,DEC公司DEC Alpha 21064,21066, 21164 ,21264MIPS公司(SGI公司)R3000,R4000,R8000,R10000,R12000, RT5IBM, Motorola ,ApplePowerPC 601,602,603,603E,604,615,620,630,640Power3、Power4、Power5HP公司PA-RISC8000SUN公司Sun SPARC MicroSPARC, SuperSPARC,UltraSP

18、ARC,RISC技术的发展,采用RISC后的好处简化指令系统设计提高机器的执行速度和效率降低设计成本,提高系统可靠性提供直接支持高级语言的能力,简化编译程序的设计 RISC的不足 指令少,加重汇编程序员的负担 浮点运算和虚拟存储器支持不足 编译程序难写,堆栈计算机,罗伯特巴登B5000两个操作数放在堆栈中执行结果自动送入堆栈指令中不需要地址部分。指令中需要相对指针的地址即可特点存储空间节省(省掉了指令的地址部分) 程序紧凑(去掉了所有中间结果的存取指令),2018/9/30,,51,逆波兰表达式,(a+b)*(c+d)转换为ab+cd+*d+入栈和出栈就可以搞定任何普通表达式的运算。运算方式如

19、下:当前字符为变量或者为数字,则压栈,如果是运算符,则将栈顶两个元素弹出作相应运算,结果再入栈,最后当表达式扫描完后,栈里的就是结果。,2018/9/30,,52,逆波兰表达式(2),转换过程包括用下面的算法读入中缀表达式的操作数、操作符和括号: 1. 初始化一个空堆栈,将结果字符串变量置空。 2. 从左到右读入中缀表达式,每次一个字符。 3. 如果字符是操作数,将它添加到结果字符串。 4. 如果字符是个操作符,弹出(pop)操作符,直至遇见开括号(opening parenthesis)、优先级较低的操作符或者同一优先级的右结合符号。把这个操作符压入(push)堆栈。 5. 如果字符是个开括

20、号,把它压入堆栈。 6. 如果字符是个闭括号(closing parenthesis),在遇见开括号前,弹出所有操作符,然后把它们添加到结果字符串。 7. 如果到达输入字符串的末尾,弹出所有操作符并添加到结果字符串。,2018/9/30,,53,信息论,1948年香农发表的通讯的数学理论信息是负熵信息是选择的自由度消息是信息的外壳,信息是消息的内核信息既不是物质,又不是能量,信息就是信息。信息存在于自然界,也存在于人类社会!,2018/9/30,,54,信息的概念,信息是标志事物存在及其关系的属性。信息可以界定为由信息源(如自然界、人类社会等)发出的被使用者接受和理解的各种信号。事件发生的概率

21、大,事先容易判断,有关此事件的消息排队事件发生的不确定程度小,则包含的信息量就小;反之则大,2018/9/30,,55,信息特征,可识别可转换可传递可加工处理可多次利用(无损耗性)在流通中扩充主客体二重性信息的能动性可共享性信息与物质和能量的主要区别。信息的产生、存在和流通,依赖于物质和能量,没有物质和能量就没有能动作用。信息可以控制和支配物质与能量的流动。,2018/9/30,,56,四次信息技术革命,第一次革命是人类创造了语言和文字,接着现出了文献。第二次革命是造纸和印刷技术的出现。第三次革命是电报、电话、电视及其它通讯技术的发明和应用。第四次革命是电子计算机和现代通讯技术在信息工作中的应用。信息爆炸,2018/9/30,,57,香农(1916-2001),大部分在贝尔实验室和MIT度过两大贡献信息理论、信息熵的概念符号逻辑和开关理论通信领域的大师级人物5台钢琴、30多种其他乐器骑独轮车,手里抛着三个球上班踩着高跷骑摩托,有两个座位的独轮车下棋机器、迷宫老鼠二战期间研究德军密码破译,2018/9/30,,58,

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 学术论文资料库 > 毕业论文

Copyright © 2018-2021 Wenke99.com All rights reserved

工信部备案号浙ICP备20026746号-2  

公安局备案号:浙公网安备33038302330469号

本站为C2C交文档易平台,即用户上传的文档直接卖给下载用户,本站只是网络服务中间平台,所有原创文档下载所得归上传人所有,若您发现上传作品侵犯了您的权利,请立刻联系网站客服并提供证据,平台将在3个工作日内予以改正。