cpu 设计实战 lab 4

本文详细探讨了CPU三级流水线中如何处理阻塞问题,特别是当pipe2被堵塞时的流水线行为。分析了两种阻塞情况,一种是当前级未准备好,另一种是前级阻塞导致的。还讨论了如何通过valid信号控制无效数据对后续指令的影响,并指出在流水线中,只需控制译码阶段的ready_go信号即可避免寄存器写后读冲突。最后提到了实现策略,包括监测执行、访存和写回级的目的寄存器,以及修改DS的ready_go逻辑。
摘要由CSDN通过智能技术生成

LAB 4

流水线的阻塞技术

我们先分析下这个三级流水线是如何阻塞的

qq_pic_merged_1622302049536

assign pipe2_ready_go = ...
assign pipe2_allowin = !pipe2_valid || pipe2_ready_go && pipe3_allowin;
assign pipe2_to_pipe3_valid = pipe2_valid && pipe2_ready_go
    always @(posedge clk) begin
        if (rst) begin
         	pipe2_valid <= 1'b0;
        end
        else if (pipe2_allowa_in) begin
        	pipe2_valid <= pipe1_to_pipe2_valid;
        end
        if (pipe1_to_pipe2_valid && pipe2_allowain) begin
           	pipe2_data <= pipe1_data; 
        end
    end

分析一下如果 pipe2_ready_go == 1'b0 时,即 pipe2 处被堵塞时的流水线会发生什么。

第一拍 pipe2_allowin , pipe2_to_pipe3_valid会为 0,于是 pipe1_allowin 和pipe1

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值