【计算机体系结构基础】流水线异常处理和提高流水线效率的技术(一)

news2024/11/18 17:28:20

流水线中的异常

异常的来源

  • 外部事件
  • 指令执行中的错误
  • 数据完整性的问题
  • 地址转换异常
  • 系统调用
  • 陷入
  • 需要软件修正的运算
    异常可以分为:可恢复异常和不可恢复异常
    不可恢复异常:系统硬件出现严重故障,异常处理后系统面临重启。
    解决办法:立即终止当前的执行,记录软件所需的信息然后跳转到异常的处理入口。
    可恢复异常:又称为精确异常,要求处理完异常后,回到产生异常的地方继续执行,还能执行正确,就像没发生过异常一样。
    解决办法:要求在处理异常时,发生异常指令的前面的所有指令都执行完,而发生异常的指令及其后面的指令都没有执行。
    书上给出的一种可行的实现精确异常的方案:
    在这里插入图片描述

提高流水线效率的技术

执行时间

执行时间是用来衡量一款处理器性能的手段。
执行时间=指令数每条指令执行周期数(CPI) *时钟周期
流水线处理器实际的CPI等于指令的理想执行周期数+由于指令相关引起的阻塞周期数
CPI=CPI+RAW+WAR+WAW

多发射数据通路

让处理器中每级流水线都可以同时处理更多的指令
双发射流水线:每一拍用PC从指令存储器中取两条指令,在译码级同时进行两条指令的译码、读源寄存器操作,并且同时执行两条指令的运算操作和访存操作,并同时写回两条指令的结果。双发射的理想CPI从单发射的1降为0.5。

双发射处理器流水线

双发射处理器流水线的时空图:
在这里插入图片描述注:当同一个时钟周期执行的两条指令存在指令相关时,也需要进行阻塞。

动态调度

基本思想:把相关的解决尽量往后拖延,同时前面的指令的等待不影响后面指令继续前进。
假设有一个双发射流水线,执行以下指令:

div.w $r3,$r2,$r1
add.w $r5,$r4,$r3
sub.w $r8,$r7,$r6

【分析】除法指令div是需要多个执行周期的,加法指令add和div是RAW相关的,所以最早要等到div执行完之后才能执行。但是减法指令sub和上两条指令是无关的。所以可以在执行除法指令的同时执行减法指令。动态调度的解决办法就是允许减法指令越过前面尚未执行完毕的除法指令和加法指令,提前开始执行
sub指令是在流水线由于指令间的相关引起阻塞而空闲的情况下,见缝插针地提前执行。

如何改进流水线

  • 将译码阶段拆成:译码+读操作数两个阶段
  • 等待的指令:译码阶段检查结构相关,读操作数阶段一直等待直至操作数可以读取。在等待状态的指令不能一直停留在原有的译码流水线上,这样它后面的指令没法前进或是进入流水线。
  • 保留站:一个存储等待指令的结构,也称为发射队列
    除了存储指令,保留站还要控制其中的指令何时去执行,因此保留站中还会记录下,描述指令间相关关系的信息,监测各条指令的执行状态。如果指令时在进入保留站前读取寄存器,那么保留站还需要监听每条结果总线,获取源操作数的最新值
    在这里插入图片描述保留站通常是一个无序队列,每一项对应一条指令,包含多个域,存放该指令的监听结果后续执行所需的各类信息(见上图)。
    译码并读寄存器的指令进入保留站,保留站会每个时钟周期选择一条没有被阻塞的指令,送往执行逻辑,并退出保留站,这个动作称为发射

关于保留站如何处理数据相关引起的阻塞以及结构相关和控制相关的起因以及如何解决下一篇再讲。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/163711.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Spring Boot Apollo监听namespace并更新配置Bean(附源码)

这里是weihubeats,觉得文章不错可以关注公众号小奏技术,文章首发。拒绝营销号,拒绝标题党 背景 如果我们使用的配置中心是apollo的话我们经常会遇到这样的问题,就是动态更新配置Bean 动态更新配置bean 动态更新配置bean其实是很简单的&…

Python学习笔记-PyQt6消息窗

对话框是界面编程中重要的窗体,一般用于提示或者一些其他特定操作。一、使用QDialog显示通用消息框直接使用QDialog类,可以及通过对话框进行通用对话框显示,亦可以通过自定义设置自己需要的对话框。# _*_ coding:utf-8 _*_import sysfrom PyQ…

MySQL主从复制的原理是什么?

主从复制是指将主数据库的 DDL 和 DML 操作通过二进制日志传到从库服务器中,然后在从库上对这些日志重新执行(也叫重做),从而使得从库和主库的数据保持同步。 MySQL支持一台主库同时向多台从库进行复制, 从库同时也可以作为其他从服务器的主…

Python批量下载某网站贵得要shi文档 并保存为PDF

人生苦短,我用Python 基本开发环境💨 Python 3.6Pycharm 相关模块的使用💨 import requests import parsel import re import os import pdfkit需要使用到一个软件 wkhtmltopdf 这个软件的作用就是把html文件转成PDF 想要把文档内容保存…

人工智能轨道交通行业周刊-第30期(2023.1.9-1.15)

本期关键词:贵阳智慧车站、城轨智能化汇总、隧道巡检、信创厂商、手语数字人 1 整理涉及公众号名单 1.1 行业类 RT轨道交通中关村轨道交通产业服务平台人民铁道世界轨道交通资讯网铁路信号技术交流北京铁路轨道交通网上榜铁路视点ITS World轨道交通联盟VSTR铁路与…

煤矿人员工服着装智能识别监测系统 yolov5架构

煤矿人员工服着装智能识别监测系统通过pythonyolov5深度学习网络架构,对画面中人员是否正确着装实时分析,发现违规着装立即抓拍存档告警。我们选择当下YOLO最新的卷积神经网络YOLOv5来进行识别检测。按照官方给出的数目,现版本的YOLOv5每个图…

数据库概述杂谈之章节回顾

数据与数据之间联系的模型表示 网状模型用“图”结构来表示数据及数据之间的联系层次模型用“树”结构来表示数据及数据之间的联系关系模型用“关系(二维表)”结构来表示数据及数据之间的联系对象模型用“对象”数据结构来表示数据及数据之间的联系 数…

SPI协议与GPIO模拟SPI的实现

SPI定义 SPI(Serial Peripheral Interface, 串口外设接口),它用于MCU与各种外围设备以串行方式进行通信,速度最高可达25MHz以上。 SPI接口主要应用在EEPROM、 FLASH、实时时钟、网络控制器、 OLED显示驱动器、 AD转换器&#xf…

ArcGIS10.6保姆式安装教程,超详细;附安装包

安装前请关闭杀毒软件,系统防火墙,断开网络连接 参考链接:请点击 下载链接: 通过百度网盘分享的文件:ArcGIS10.6zip 链接:https://pan.baidu.com/s/1tCsOQ_-WP-usEHmJo9SfcA 提取码:hn15 复制这段内容打开「百度网盘A…

Java环境安装、python环境安装、Burpsuite安装

数据来源 Java环境安装 Windows安装JDK8(安装过程:一路下一步) 下载JDK8:https://www.oracle.com/java/technologies/javase-jdk8-downloads.html 百度网盘:windows64、84位 配置PATH环境变量: 变量名…

RT-Thread系列--双链表分析

一、目的学习过C语言的同学应该都知道几种常用的数据结构,例如数组、单链表、双链表等。每种数据结构都有其特点和应用场景,本篇就结合RT-Thread源码分析一下其双链表实现细节和特点。那什么是双链表呢,这边简单解释一下帮助大家理解。通过双…

KubeSphere 开源社区 2022 年度回顾与致谢

2022 年,国内的云原生技术生态日趋完善,细分技术项目也不断涌现,形成了完整的支撑应用云原生化的全生命周期技术体系。基础设施即代码、微服务、Serverless 等技术,促使基础设施资源向更加灵活弹性、自动化方向发展。而开源生态也…

重装系统如何设置u盘启动为第一启动项

如何设置u盘启动为第一启动项呢?将U盘设为第一启动项,是使用U盘装机工具重装系统的重要步骤之一,很多网友不清楚怎么操作,下面小编就分享下设置u盘启动为第一启动项的方法。 工具/原料: 系统版本:win7家庭版 品牌型…

【openGauss实战4】数据类型解读

📢📢📢📣📣📣 哈喽!大家好,我是【IT邦德】,江湖人称jeames007,10余年DBA工作经验 一位上进心十足的【大数据领域博主】!😜&#x1f61…

一文教会你巧用设计模式重构项目

文章目录一、设计模式总览二、模板方法模式案例三、策略模式案例四、支付改造4.1 思路分析4.2 实现图解:4.3 代码实现:4.4 效果演示4.5 如何扩展本文参考自12.29日尚硅谷雷神的 巧妙使用设计模式重构项目 一、设计模式总览 总体分类 不同时期选择不同的…

Python批量检索论文被引用数量源码,利用百度学术网页版来批量检索论文的被引用数量源码

论文被引用数搜索 利用百度学术网页版来检索一个文件夹中的所有论文的被引用数量。 完整代码下载地址:Python批量检索论文被引用数量源码 依赖有beautifulsoup库、regex正则表达式库。 使用方法 主程序为fileWalk.py。 修改程序中workPath值为文件夹绝对路径&am…

基于碰撞传感器的自动导航车系统设计

1、内容简介略635-可以交流、咨询、答疑2、内容说明略随着世界各国对科学技术的重视,各类高科技技术突飞猛进,人类逐步进入人工智能时代。而在这些高科技技术的背后,自动导航小车作为无人驾驶小车的一种类型备受关注。它的主要优点是不需要人…

冰冰学习笔记:智能指针

欢迎各位大佬光临本文章!!! 还请各位大佬提出宝贵的意见,如发现文章错误请联系冰冰,冰冰一定会虚心接受,及时改正。 本系列文章为冰冰学习编程的学习笔记,如果对您也有帮助,还请各位…

vite 在proxy代理中更改headers

vite 在proxy代理中更改headers 平时我们在对接接口时,我们都是配置代理解决跨域问题 proxy: {^/api: {target: envConfig.VITE_APP_BASE_URL,changeOrigin: true,rewrite: (path) > path.replace(/^/api/, ),}} 某天你明明配置好了代理,浏览器还是会…

嵌入式Linux-守护进程

1.守护进程 1.1 何为守护进程 守护进程(Daemon)也称为精灵进程,是运行在后台的一种特殊进程,它独立于控制终端并且周期性地执行某种任务或等待处理某些事情的发生,主要表现为以下两个特点: 长期运行。 守…