mlir 编译器学习笔记之四 -- 调度

1、指令的活跃区间 LiveRange [startTime, endTime]

startTime: 节点开始执行的时间(指令被发射到功能单元)

endTime: 节点结果就绪的时间(指令执行完成,结果可用)

前驱指令P: R1 = R2 + R3 // LiveRange: [10, 12]

当前指令C: R4 = R1 * 2 // 什么时候可以开始?==> R1 就绪,即endTime

2、普通调度 (严格顺序)& 硬件循环(允许重叠)的原因

复制代码
T1 = max(preStart + hardware_switch_overhead,preEnd + loop_iteration_period - latency)

普通调度OOO:可以提前发射,但会在流水线中等待

硬件循环:可以更早开始执行,因为有数据转发 (专有硬件,不竞争通用资源)

3、资源占用:级联模式时需要多个功能单元

相关推荐
田里的水稻2 分钟前
AI_常见“XX学习”术语速查表
人工智能·学习
Nan_Shu_61438 分钟前
学习:Sass
javascript·学习·es6
天殇凉43 分钟前
AC自动机学习笔记
java·笔记·学习
AA陈超1 小时前
从0开始学习 **Lyra Starter Game** 项目
c++·笔记·学习·游戏·ue5·lyra
rchmin2 小时前
Prompt Engineering 从入门到精通的系统学习路径
人工智能·学习·prompt
江苏世纪龙科技3 小时前
开启汽车实训新视界:大众迈腾整车检测与诊断MR仿真实训系统
学习
2301_800256114 小时前
第七章 空间存储与索引 知识点梳理3(空间填充曲线)
数据库·笔记·sql·postgresql
好奇龙猫4 小时前
【AI学习-lora-定义-comfyUI相关-相关学习-了解概念(1)】
人工智能·学习
冯诺依曼的锦鲤4 小时前
算法练习:差分
c++·学习·算法
凉凉的知识库5 小时前
书海拾遗:《枪炮、病菌与钢铁》
笔记·电子书