OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 5206|回复: 1

Verilog 中的initial语句赋值问题

[复制链接]

5

主题

6

帖子

0

精华

新手上路

积分
28
金钱
28
注册时间
2018-8-30
在线时间
9 小时
发表于 2019-4-2 10:53:57 | 显示全部楼层 |阅读模式
利用modelsim 进行仿真时,发现initia语句在使用阻塞和非阻塞赋值时,会出现不同的结果,请问在initial语句中什么时候该用阻塞什么时候该用非阻塞赋值呢?代码如下:
module key_decount(
    input    sys_clk,
    input    sys_rst_n,
    input    key,
);

reg    touch_key_d0;
reg    touch_key_d1;

always @(posedge sys_clk or negedge sys_rst_n) begin
    if(!sys_rst_n) begin
        touch_key_d0 <= 1'b0;
        touch_key_d1 <= 1'b0;
    end  
    else begin
        touch_key_d0 <= key;
        touch_key_d1 <= touch_key_d0;
   end         
end

endmodule

使用阻塞赋值时的testbench:
initial                                                
begin                                             
    sys_clk               =  1'b0;
    sys_rst_n            =  1'b0;
    key                    =  1'b1;
    #100 sys_rst_n    =  1'b1;
    #210 key            =  1'b0;
    #210 key            =  1'b1;
    #205 key            =  1'b0;
    #205 key            =  1'b1;
    #200 key            =  1'b0;
    #200 key            =  1'b1;
end                                                   
always #10 sys_clk=~sys_clk;

仿真波形如图:
20190402103639.png
当key的值恰好在上升沿变化时,touch_key_d0会立刻跟随key发生变化;

使用非阻塞赋值时的testbench:
initial                                                
begin                                                
    sys_clk              <=  1'b0;
    sys_rst_n           <=  1'b0;
    key                   <=  1'b1;
    #100 sys_rst_n   <=  1'b1;
    #210 key           <=  1'b0;
    #210 key           <=  1'b1;
    #205 key           <=  1'b0;
    #205 key           <=  1'b1;
    #200 key           <=  1'b0;
    #200 key           <=  1'b1;
end                                                   
always #10 sys_clk=~sys_clk;  

仿真波形:
20190402104613.png
当key恰好在上升沿变化时,touch_key_d0会在下一时钟周期上升沿发生变化;


20190402104613.png
20190402103639.png
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

0

主题

4

帖子

0

精华

新手上路

积分
35
金钱
35
注册时间
2019-4-1
在线时间
5 小时
发表于 2019-4-2 11:05:35 | 显示全部楼层
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2024-10-3 05:33

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表