芯路恒电子技术论坛

 找回密码
 立即注册
热搜: 合集
查看: 2074|回复: 0

Verilog常见语法总结

[复制链接]
  • TA的每日心情
    慵懒
    2021-2-24 10:16
  • 428

    主题

    811

    帖子

    1万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    16107
    QQ
    发表于 2023-7-17 16:18:53 | 显示全部楼层 |阅读模式
    adc_fifo_uart_inst0.state == 0

    功能说明
    取用tb中例化的模块中的某个信号值来进行判断。注意,“.”前面的名字,一定是模块例化后的名字,不是原始名字。该语法还可以多级调用,比如
    1. adc_fifo_uart_inst0.uart_byte_tx_inst.div_cnt == 1;
    复制代码


    案例展示:

    1. initial begin
    2.         Reset_n = 0;
    3.         adc_dout = 0;
    4.         #201;
    5.         Reset_n = 1;
    6.         uart_rx = 1;
    7.         #200;
    8.         send_cmd(499,1,32);
    9.         #200;
    10.         wait(adc_fifo_uart.state == 0);
    11.         #500000;
    12.         $stop;
    13. end
    复制代码

    上述代码中,等待adc_fifo_uart模块中的state信号为0后,再执行后续操作,否则一直等待。



    wait(sig == N);

    功能说明
    阻塞式等待,仅当sig == N这个条件满足的时候,该语句才会执行通过,然后执行该语句后面的内容,该语法常用来等待1位或多位信号满足某条件后,再产生新的激励信号。使用方法如:
    wait(!CS_N); 等待CS_N信号拉低后再执行后续操作
    wait(state == IDLE);等待状态机回到IDLE状态后再执行后续操作。

    案例展示:

    1. initial begin
    2.         Reset_n = 0;
    3.         adc_dout = 0;
    4.         #201;
    5.         Reset_n = 1;
    6.         uart_rx = 1;
    7.         #200;
    8.         send_cmd(499,1,32);
    9.         #200;
    10.         wait(adc_fifo_uart.state == 0);
    11.         #500000;
    12.         $stop;
    13. end
    复制代码

    上述代码中,等待adc_fifo_uart模块中的state信号为0后,再执行后续操作,否则一直等待。


    @(negedge adc_cs);@(posedge adc_cs);

    功能说明
    阻塞式等待某个信号的下降沿/上升沿到来后,再执行后续操作,该语法常用来等待1位信号的变化。

    案例展示

    1. Tx_En <= 1;
    2. #20
    3. Tx_En <= 0;
    4. @(posedge Tx_Done);
    5. #20;
    6. Tx_En <= 1;
    7. #20
    8. Tx_En <= 0;
    复制代码

    上述代码来源于串口发送模块的testbench文件,首先产生Tx_En脉冲来使能一次串口发送。然后就开始等待等串口发送模块发送完成,发送完成后,串口发送模块 Tx_Done信号会出现高脉冲,所以使用@(posedge Tx_Done);来等待这个高脉冲,直到脉冲到来后,再产生新的发送使能脉冲信号Tx_En;


    回复

    使用道具 举报

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

    本版积分规则

    QQ|小黑屋|Archiver|芯路恒电子技术论坛 |鄂ICP备2021003648号

    GMT+8, 2024-11-21 21:51 , Processed in 0.105536 second(s), 31 queries .

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc. Template By 【未来科技】【 www.wekei.cn 】

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