题解 | #流水线乘法器#

流水线乘法器

http://www.nowcoder.com/practice/be97f63817c543fe9260d46d971a7283

本质上是加法树流水线,移位部分可以用组合逻辑实现,这里用了generate简化了代码。

`timescale 1ns/1ns

module multi_pipe#(
	parameter size = 4
)(
	input 						clk 		,   
	input 						rst_n		,
	input	[size-1:0]			mul_a		,
	input	[size-1:0]			mul_b		,
 
 	output	reg	[size*2-1:0]	mul_out		
);
    //parameter 
    parameter N = size * 2;
    //defination
    wire [N - 1 : 0] temp [0 : 3];
    
    reg [N - 1 : 0] adder_0;
    reg [N - 1 : 0] adder_1;
    
    //output 
    genvar i;
    generate
        for(i = 0; i < 4; i = i + 1)begin : loop
            assign temp[i] = mul_b[i] ? mul_a << i : 'd0;
        end
    endgenerate
    
    always@(posedge clk or negedge rst_n)begin
        if(!rst_n) adder_0 <= 'd0;
        else adder_0 <= temp[0] + temp[1];
    end
    
    always@(posedge clk or negedge rst_n)begin
        if(!rst_n) adder_1 <= 'd0;
        else adder_1 <= temp[2] + temp[3];
    end
    
    always@(posedge clk or negedge rst_n)begin
        if(!rst_n) mul_out <= 'd0;
        else mul_out <= adder_0 + adder_1;
    end
endmodule
全部评论
请问一下,如果不用adder_0和adder_1直接用mul_out<=temp[0] + temp[1]+temp[2] + temp[3],会快一个周期出结果,但是为什么会报错?
1 回复 分享
发布于 2023-02-28 14:54 四川

相关推荐

我就是0offer糕手:北大不乱杀
点赞 评论 收藏
分享
评论
22
3
分享

创作者周榜

更多
牛客网
牛客企业服务