《计算机组成与体系结构:性能设计》读后小记 12、CPU的结构和功能
一、CPU组成
1、组成:
ALU:算术逻辑单元,完成数据的实际计算或处理
控制器:控制数据的移入移出CPU
寄存器:由一组存储位置极小的内部存储器组成
CPU内部总线:在各寄存器和ALU之间传送数据
2、CPU要完成的任务:
取指令:从存储器(主存、cache、寄存器)读取指令
解释指令:对指令进行译码
处理指令:对数据完成算术或逻辑运算
写数据:运算结果数据写到存储器或I/0模块
二、寄存器组成
1、组成:
用户可见寄存器:允许机器语言或汇编语言的编程人员通过优化寄存器的使用而减少对主存的访问
控制和状态寄存器:由控制器来控制CPU的操作,并由拥有特权的操作系统来控制程序的执行
2、到目前为止,关于组织CPU寄存器的最好方式还没有一个普遍接受的原则,正如指令集设计的情况一样,也有众多的CPU设计观点,这些都还是有待品评的事情。
三、指令周期
1、间接周期:指令的执行涉及到从存储器中读取操作数,可能会使用到间接寻址,可以把间接寻址看成是一个额外的指令子周期,即间接周期。
2、数据流:该小节讲述了在取指令阶段、指令执行阶段和中断周期阶段,PC(程序计数器)、MAR(存储器地址寄存器)、MBR(存储器缓冲寄存器)和IR(指令寄存器)中数据的移动方向与时序,详情见此书P283页。
四、指令流水线技术
1、定义:流水是指将指令周期分解成几个连续出现的阶段,如取指令、译码指令、确定操作数地址、取操作数、执行指令和写结果操作数。
2、指令预取:在取指阶段取一条指令并缓存它,当执行阶段空闲时,将取指阶段缓存的指令输送给它。当执行阶段正在执行此指令时,取指阶段利用未使用的存储器周期读取下一条指令并缓存它。这称为指令预取或指令交叠。这种处理能加快指令的执行,理论上速率可以提升一倍,但是仅仅只是理论上,别想多了!至于原因,见P284页。
3、流水线冒险:发生在流水线或流水线的某个部分,因为某些条件不允许流水线继续运行,而必须停顿的时候,这种停顿也称流水线空泡。通俗的说,就是几条指令想要并行取指、执行的时候,因为资源、数据或控制不得不等待其他指令的一种情况。
4、三种流水线冒险:
资源冒险:也称为结构冒险,主要是等待内存可用,或者算数逻辑单元可用的情况;
数据冒险:需要访问同一内存中或寄存器中的数据时发生;
控制冒险:又称为分支冒险,发生在流水线对分支转移做出了错误的预测,因此读取了在后期必须取消的指令之时。
5、处理分支指令:
多个指令流:条件分支流水线的开始部分,允许流水线同时取这两条指令,使用两个指令流;
预取分支目标:识别出一个条件分支指令时,除了取此分支指令之后的指令外,分支目标的指令也被取来。说实话,我看的不太明白;
循环缓冲器:由流水线指令取指阶段维护一个小的但极高速的存储器,含有n条最近取来的指令,其原理类似于指令高速缓存;
指令预测:预测绝不发生、预测总是发生、依操作码预测、发生/不发生切换、转移历史表;
延迟分支:自动重排程序中的指令,这样可以把一条分支指令移到实际所期望的位置之后;
《计算机组成与体系结构:性能设计》读后小记 12、CPU的结构和功能的更多相关文章
- 【计组】《计算机组成与体系结构性能设计》William Stallings 第2部分 计算机系统 第3章 计算机功能和互连的顶层视图
关键词 address bus 地址总线 asynchronous timing 异步时序 bus 总线 bus arbitration 总线仲裁 bus width 总线宽度 centralized ...
- 《像计算机科学家一样思考Java》—— 读后总结
本书属于入门级的Java书籍,与其他的向编程思想.核心技术不同的是,这本书不是按部就班的讲解java变成知识,而是随着语言的深入慢慢增加知识点. 这本书以一个语言开发者的角度,深入浅出的讲解了Java ...
- "Entity Framework数据插入性能追踪"读后总结
园友莱布尼茨写了一篇<Entity Framework数据插入性能追踪>的文章,我感觉不错,至少他提出了问题,写了出来,引起了大家的讨论,这就是一个氛围.读完文章+评论,于是我自己也写了个 ...
- C语言指针使用小记 (深入理解C指针 读后小记)
最近正值过年在家,新年初一,闲暇时间无事可做便把以前看过的书籍整理了一下,顺手也把这本“深入理解C指针”的书重新读了一遍,这本书总体感觉比较简单,但是还是不免有些地方是平时没有想到过或者没有注意到的, ...
- 编写高质量代码 改善Python程序的91个建议 (读后 小记)
此书是自己好久之前买的,当时总觉得Python语言中有各种trick, 总是要自己猝不及防的掉入到陷阱之中, 看了一些资料后发现了这本书,感觉很是不错,不过可惜自己平时总是杂事太多,总是找不到整块的时 ...
- 浏览器渲染原理笔记 --《How Browser Work》读后总结
综述 之前使用ExtJS时遇到一个问题:为什么依次设置多个组件的可见性界面会卡顿?在了解HTML的dom操作相关内容的时候也好奇这个东西到底是怎么回事,然后尤其搞不懂CSS和Html分管样式和网页结构 ...
- WiscKey: Separating Keys from Values in SSD-Conscious Storage [读后整理]
WiscKey: Separating Keys from Values in SSD-Conscious Storage WiscKey是一个基于LSM的KV存储引擎,特点是:针对SSD的顺序和随机 ...
- Code Complete 读后总结和新的扩展阅读计划
Code Complete 读后总结和新的扩展阅读计划 用了一年时间终于将代码大全读完了,在这里做一个简单的总结,并安排下一阶段的扩展阅读计划. 1.选择代码大全作为我程序员职业入门的第一本书,我认为 ...
- 《Effective Objective-C 2.0》 读后总结
感觉自己最近提升很慢了.然后去找了一些面试题看看.发现自己自大了.在实际开发中,让我解决bug.编写功能,我有自信可以完成.但是对项目更深层的思考,我却没有.为了能进到自己的目标BAT.也为了让自己更 ...
随机推荐
- win10家庭版升级 到win10企业版
成功升级3小时 20200124 拿到电脑 win10家庭版 不会用 找admin都找不到只能用企业版 升级win10家庭版 到win10企业版 在msdn下载win10企业版iso iso 文件管 ...
- 启动kafaka失败了,提示zk保存kafka的ids已经在使用。
FATAL [Kafka Server 1], Fatal error during KafkaServer startup. Prepare to shutdown (kafka.server.Ka ...
- MIPS指令的CPU实现:ALU设计
设计CPU的第一步,设计一个简单的逻辑运算单元ALU.同时对Verilog语言也有一定要求. 一.实验内容 如图,ALU接受两个N位的输入,得到N位的输出,通过控制信号F决定运算功能. 将ALU的输出 ...
- 微信公众号H5-网页开发须知
网页授权 1. 公众号配置--授权回调域名(仅域名,不带https://)2. 配置的域名为全域名,该域名下的页面可以进行OAuth2.0鉴权3. scope 授权的[静默.非静默] a.(静默--无 ...
- Win10 安装 Python3 (上)
Python3 For Windows 10 installer 参考 The full installer 安装 随后可以看到,installer 在用户环境变量PATH中,添加了三项: 卸载 使用 ...
- Auto ML自动调参
Auto ML自动调参 本文介绍Auto ML自动调参的算法介绍及操作流程. 操作步骤 登录PAI控制台. 单击左侧导航栏的实验并选择某个实验. 本文以雾霾天气预测实验为例. 在实验画布区,单击左上角 ...
- 英特尔内存革新助平安云 Redis 云服务降本增效
英特尔内存革新助平安云 Redis 云服务降本增效 英特尔 傲腾 数据中心级持久内存的引入,为平安云的降本增效开启了一条新的道路.通过对平安云 Redis 数据库产品的支持,用户能享受到性能优异且价格 ...
- C#中使用swagger小技巧
C#中使用swagger小技巧 swaggerUI显示的接口内容主要用于开发阶段便于与前端联调,不适合发布到对外的站点. 有以下两种方式,让接口不显示在SwaggerUI中 1.使用属性 [ApiEx ...
- 采用MVC模式创建一个简单的javascript App
初次翻译,翻译的不好,还请见谅 JavaScript中最好的一部分之一,也可能是最糟糕的. 在HTML文档的头部添加一个开始和结束脚本标记,并在其中引入一些意大利面条式的代码,毫无疑问这是一种过分简单 ...
- 番外篇:搭建Windows环境下的RabbitMQ环境
搭建Windows环境下的Rabbitmq环境 下载erlang语言包OTP.官网地址: https://www.erlang.org/downloads 如果下载不了,可以选择百度网盘下载,里面的版 ...