一、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的结构和功能的更多相关文章

  1. 【计组】《计算机组成与体系结构性能设计》William Stallings 第2部分 计算机系统 第3章 计算机功能和互连的顶层视图

    关键词 address bus 地址总线 asynchronous timing 异步时序 bus 总线 bus arbitration 总线仲裁 bus width 总线宽度 centralized ...

  2. 《像计算机科学家一样思考Java》—— 读后总结

    本书属于入门级的Java书籍,与其他的向编程思想.核心技术不同的是,这本书不是按部就班的讲解java变成知识,而是随着语言的深入慢慢增加知识点. 这本书以一个语言开发者的角度,深入浅出的讲解了Java ...

  3. "Entity Framework数据插入性能追踪"读后总结

    园友莱布尼茨写了一篇<Entity Framework数据插入性能追踪>的文章,我感觉不错,至少他提出了问题,写了出来,引起了大家的讨论,这就是一个氛围.读完文章+评论,于是我自己也写了个 ...

  4. C语言指针使用小记 (深入理解C指针 读后小记)

    最近正值过年在家,新年初一,闲暇时间无事可做便把以前看过的书籍整理了一下,顺手也把这本“深入理解C指针”的书重新读了一遍,这本书总体感觉比较简单,但是还是不免有些地方是平时没有想到过或者没有注意到的, ...

  5. 编写高质量代码 改善Python程序的91个建议 (读后 小记)

    此书是自己好久之前买的,当时总觉得Python语言中有各种trick, 总是要自己猝不及防的掉入到陷阱之中, 看了一些资料后发现了这本书,感觉很是不错,不过可惜自己平时总是杂事太多,总是找不到整块的时 ...

  6. 浏览器渲染原理笔记 --《How Browser Work》读后总结

    综述 之前使用ExtJS时遇到一个问题:为什么依次设置多个组件的可见性界面会卡顿?在了解HTML的dom操作相关内容的时候也好奇这个东西到底是怎么回事,然后尤其搞不懂CSS和Html分管样式和网页结构 ...

  7. WiscKey: Separating Keys from Values in SSD-Conscious Storage [读后整理]

    WiscKey: Separating Keys from Values in SSD-Conscious Storage WiscKey是一个基于LSM的KV存储引擎,特点是:针对SSD的顺序和随机 ...

  8. Code Complete 读后总结和新的扩展阅读计划

    Code Complete 读后总结和新的扩展阅读计划 用了一年时间终于将代码大全读完了,在这里做一个简单的总结,并安排下一阶段的扩展阅读计划. 1.选择代码大全作为我程序员职业入门的第一本书,我认为 ...

  9. 《Effective Objective-C 2.0》 读后总结

    感觉自己最近提升很慢了.然后去找了一些面试题看看.发现自己自大了.在实际开发中,让我解决bug.编写功能,我有自信可以完成.但是对项目更深层的思考,我却没有.为了能进到自己的目标BAT.也为了让自己更 ...

随机推荐

  1. jsp表单传值后在页面中文显示乱码

    主要通过添加以下代码来实现(前提是其他处的编码都设置成了utf-8): response.setContentType("text/html;charset=utf-8"); re ...

  2. GPIO端口上拉下拉 与 硬件图的上拉下拉

    硬件图上的上拉下拉: 没有触发时默认接到IO的是高电平就是上拉: 没有触发时默认接到IO的是低电平就是 下拉: (2)对应GPIO的配置 配置与你的外围电路息息相关: 比如下图: 你只能配置为上拉: ...

  3. Spring AOP 用法浅谈(Day_18)

    当你这一天没有在进步,那你就是在退步! [简述] Aspect Oriented Programming :面向切面编程 所谓面向切面编程,是一种通过预编译和运行期动态代理的方式实现在不修改源代码的情 ...

  4. 『动善时』JMeter基础 — 26、使用txt文件实现JMeter参数化

    目录 1.测试计划中的元件 2.数据文件内容 3.线程组元件内容 4.HTTP信息头管理器组件内容 5.CSV数据文件设置组件内容 6.HTTP请求组件内容 7.脚本运行结果 之前我们都是使用.csv ...

  5. 死磕nginx系列

    死磕nginx系列 死磕nginx系列--nginx入门 死磕nginx系列--nginx配置文件 死磕nginx系统--nginx日志配置 死磕nginx系列--nginx服务器做web服务器 死磕 ...

  6. node.js学习(2)函数

    1 简答函数 2 匿名函数 3 回调函数

  7. i.MX6UL: i.MX 6UltraLite处理器 - 低功耗,安全,Arm® Cortex®-A7内核

    i.MX6UL: i.MX 6UltraLite处理器 - 低功耗,安全,Arm Cortex-A7内核 概述 MX6UltraLite作为i.MX6系列的扩展,一系列高性能.超高效的处理器,采用先进 ...

  8. PaddlePaddle推理部署

    PaddlePaddle推理部署 飞桨推理产品简介 作为飞桨生态重要的一部分,飞桨提供了多个推理产品,完整承接深度学习模型应用的最后一公里. 整体上分,推理产品主要包括如下子产品 各产品在推理生态中的 ...

  9. NVIDIA CUDA-X AI

    NVIDIA CUDA-X AI 面向数据科学和 AI 的 NVIDIA GPU 加速库 数据科学是推动 AI 发展的关键力量之一,而 AI 能够改变各行各业. 但是,驾驭 AI 的力量是一个复杂挑战 ...

  10. Wide & Deep的OneFlow网络训练

    Wide & Deep的OneFlow网络训练 HugeCTR是英伟达提供的一种高效的GPU框架,专为点击率(CTR)估计训练而设计. OneFlow对标HugeCTR搭建了Wide & ...