白沐沐vccc 2023-04-29 10:11 采纳率: 96.2%
浏览 11
已结题

Verilog序列检测问题

请教一下为什么上板子时,我把计数那段雨具单独写一个always块,res就一直为0,根本没计数。如下:

module detect(
    input clk,
    input rst,
    input[15:1] SW,
    output reg[2:0] res
);

    reg[2:0] tmp;
    reg[15:1] sec;

    //初始化
     always @(posedge clk) begin
        if(!rst) begin
            tmp=3'b000;
            res=3'b0;
            sec=SW;
            end
        else if(sec>0) begin
            tmp={tmp[1:0],sec[15]};
            sec=sec<<1;
            end
        else  tmp=3'b0;
    end
    
    //计数
    always @(posedge clk) begin
        if(tmp==3'b101) begin
            res=res+1;
            tmp=3'b000;
        end
    end
endmodule

但是我把他放进第一个always块中,就能计数了,请问这是为什么呀?

module detect(
    input clk,
    input rst,
    input[15:1] SW,
    output reg[2:0] res
);

    reg[2:0] tmp;
    reg[15:1] sec;

    //初始化
     always @(posedge clk) begin
        if(!rst) begin
            tmp=3'b000;
            res=3'b0;
            sec=SW;
            end
        else if(sec>0) begin
            tmp={tmp[1:0],sec[15]};
            sec=sec<<1;
            if(tmp==3'b101) begin
              res=res+1;
              tmp=3'b000;
            end
            end
        else  tmp=3'b0;
    end
    
    
endmodule

  • 写回答

2条回答 默认 最新

  • 老皮芽子 2023-05-02 17:45
    关注

    res 和 tmp 这两个变量必须在同一个always 中赋值。
    verilog 是个描述硬件电路的语言。当这俩变量在多个always 中赋值,相当于多个芯片的输出连在一起短路了。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 5月15日
  • 已采纳回答 5月7日
  • 创建了问题 4月29日

悬赏问题

  • ¥15 系统 24h2 专业工作站版,浏览文件夹的图库,视频,图片之类的怎样删除?
  • ¥15 怎么把512还原为520格式
  • ¥15 MATLAB的动态模态分解出现错误,以CFX非定常模拟结果为快照
  • ¥15 求高通平台Softsim调试经验
  • ¥15 canal如何实现将mysql多张表(月表)采集入库到目标表中(一张表)?
  • ¥15 wpf ScrollViewer实现冻结左侧宽度w范围内的视图
  • ¥15 栅极驱动低侧烧毁MOSFET
  • ¥30 写segy数据时出错3
  • ¥100 linux下qt运行QCefView demo报错
  • ¥50 F1C100S下的红外解码IR_RX驱动问题