cpu 设计实战 lab 4

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

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_to_pipe2_valid 会为0,如果有更前级的流水线,则全部阻塞,从第一拍开始全部不接受新值,直到 pipe2_

### LoongArch 架构下的 CPU 设计 Lab6 实验 Lab6 的主要内容围绕构建一个支持 20 条指令的单周期 CPU 展开。该实验的目标是通过实现这些基本指令来加深对 CPU 工作原理的理解,并熟悉 LoongArch 指令集架构的设计理念[^1]。 #### 实验目标 实验的主要目的是设计并验证一个能够执行特定指令集合的单周期处理器。这包括但不限于算术逻辑单元 (ALU) 的实现、寄存器文件的操作以及控制信号的生成。具体来说,学生需要完成以下任务: - **指令解码模块**:解析输入指令并生成相应的控制信号。 - **数据通路搭建**:连接 ALU、寄存器文件和其他功能部件以形成完整的数据路径。 - **测试平台开发**:编写测试程序以验证所设计 CPU 的正确性和性能表现。 为了顺利完成此项目,建议仔细阅读《CPU设计实战》第四章中的相关内容[^3],同时参照官方发布的 `exp` 压缩包文档说明获取更多细节指导信息[^5]。 #### 关键知识点回顾 以下是几个需要注意的关键概念和技术要点: - **指令格式分析**: 不同类型的指令具有各自独特的编码方式, 正确理解每种类型对于后续硬件电路模拟至关重要. - **组合逻辑应用**: 利用布尔代数简化表达式可以有效减少资源消耗提高效率. - **同步机制引入**: 确保所有操作都在时钟边沿触发有助于保持系统的稳定性. 下面给出一段简单的 Verilog HDL 示例代码用于展示如何定义一个多路选择器: ```verilog module mux2to1( input wire sel, input wire a, input wire b, output reg out ); always @(*) begin case(sel) 1'b0 : out = a; default : out = b; endcase end endmodule ``` 上述片段展示了基于选择信号切换两个输入源之一作为输出的基本方法[^4]. ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值