题解 | #移位运算与乘法#

移位运算与乘法

https://www.nowcoder.com/practice/1dd22852bcac42ce8f781737f84a3272

`timescale 1ns/1ns
module multi_sel(
input [7:0]d ,
input clk,
input rst,
output reg input_grant,
output reg [10:0]out
);
//*************code***********//

reg     [1:0]   cnt;
reg     [7:0]   d_reg;

always@(posedge clk or negedge rst)
    if(!rst)
        d_reg <= 8'b0;
    else if(cnt == 2'd0)
        d_reg <= d;
    else
        d_reg <= d_reg;

always@(posedge clk or negedge rst)
    if(!rst)
        cnt <= 2'd0;
    else if(cnt == 2'd3)
        cnt <= 2'b0;
    else
        cnt <= cnt + 1'b1;

always@(posedge clk or negedge rst)
    if(!rst)
        input_grant <= 1'b0;
    else if(cnt == 2'd0)
        input_grant <= 1'b1;
    else
        input_grant <= 1'b0;

always@(posedge clk or negedge rst)
    if(!rst)
        out <= 11'b0;
    else
        case(cnt)
        2'd0    :   out <= d;	//d_reg打一拍,不能用d_reg
        2'd1    :   out <= (d_reg << 1) + d_reg;
        2'd2    :   out <= (d_reg << 3) - d_reg;
        2'd3    :   out <= (d_reg << 3);
        default :   out <= 11'b111_1111_1111;
        endcase


//*************code***********//
endmodule

全部评论

相关推荐

07-25 13:42
门头沟学院 Java
安锋:看看老板的腿
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-25 18:02
来组里2个月了,天天让打杂,写的代码不超过200行。现在已经开始摆烂冲秋招了。我感觉4个月,就算周六日全天睡觉,周一到周五一直看黑马也比我来节子实习学到的东西多。
小熊梦奇:😅节子那么多文档,你是一个都不看啊。 大厂的意义在于内部系统对你开放,看明白事情起因经过结果解决措施,实在看不明白,直接聊天系统搜到对应团队去问当时的负责人,大部分情况下都会给你解答。 这才是大厂实习的精髓
实习生的蛐蛐区
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务