C54x DSP的流水线操作以及优化指南

2019-07-28 19:03发布

流水线操作是指各个指令以机器周期为单位,相差一个时间周期、连续并行发生的一系列总线操作,对于多总线的Harvard结构有可能使用同一条指令,在不同的机器周期内占用不同的总线资源;也可以不同指令在同一机器周期内占用不同的总线资源。基于C54x DSP的处理器平台,其流水线的特点会在具体的开发过程中可以利用来做优化。
1.'C54xx的六级流水指令




友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
13条回答
biechedan
1楼-- · 2019-07-28 19:05
Prefetch 预取指:用PC中的内容加载PAB

Fetch 取指:用读到的指令 字加载PB

Decode译码: 用PB的内容加载IR,对IR的内容译码

Access寻址: 用数据1读地址,加载DAB;用数据2读地址,加载CAB;修正辅助寄存器和堆栈指针

Read读数:读数据1,加载DB;读数据2,加载CB;如果需要,将数据3写地址加载EAB

eXecute/write执行:执行指令;用写数据加载EB

'C54x流水线中所涉及的硬件
biechedan
2楼-- · 2019-07-28 20:03

biechedan
3楼-- · 2019-07-29 00:15
当结果回存到存储器时,"Write"被分成2个阶段:
# 产生写地址(占用R Phase)
#写结果(占用X Phase)
'C54xx流水线中存储器存取操作


biechedan
4楼-- · 2019-07-29 01:02
 精彩回答 2  元偷偷看……
biechedan
5楼-- · 2019-07-29 02:01
2、延时分支转移在流水线上的操作
延时分支转移 (B b1)流水线图


biechedan
6楼-- · 2019-07-29 06:17
3、流水线的冲突
1)流水线冲突的原因及解决:
2)流水线冲突情况分析:
3)可能引发冲突的相关的硬件资源 (Phase≌Affected Phase)


一周热门 更多>