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、资源占用:级联模式时需要多个功能单元

相关推荐
我叫唧唧波7 小时前
Python+AI 全栈学习笔记
人工智能·python·学习
城北徐宫7 小时前
Linux信号深度解剖:5种产生、3张表、4次切换
linux·c++·学习
三品吉他手会点灯8 小时前
C语言学习笔记 - 43.运算符与表达式 - 运算符1 - 运算符的分类和简单介绍
c语言·笔记·学习·算法
疯狂打码的少年8 小时前
中断处理过程与中断优先级
笔记
likerhood9 小时前
WSL 下安装 Miniconda 笔记
笔记·wsl
吃好睡好便好10 小时前
芒种时节如何保健
学习·生活
lizhihai_9910 小时前
股市学习心得-A股服务器/算力服务器龙头
大数据·运维·服务器·人工智能·科技·学习
喜欢打篮球的普通人11 小时前
LLVM 后端流程与关键数据结构:从 IR 到机器码的入门笔记
java·数据结构·笔记
烛之武11 小时前
Pytorch学习笔记(1)
pytorch·笔记·学习
chushiyunen12 小时前
业务模型笔记
笔记