Interface、Clocking Block、BA、NBA

1、interface中可以使用:initial、always、tunction、task;

2、interface中定义的接口类型为logic(4态),不用bit是因为其只有2态,不足以表示dut signal;

3、module、inter不同点:

        module中:可以例化module、interface;

        interface中:可以例化interface,但不能例化module;

4、flip flop:D触发器;

5、系统函数:

        $finish():结束仿真;

        $stop():特点是stop后,还是继续执行(continue on)

        $exit():用于退出program,program中不能实例化program;

6、interface中特殊用法(覆盖默认的采样方式):

Interface、Clocking Block、BA、NBA_第1张图片



CB中input、output的延时模拟了dut的建立时间、保持时间(如上图):

input:采集在上升沿之前的10ns的信号值;

output:在上升沿之后的2ns对dut信号进行驱动;



Driver:一般需要使用cb块对信号进行驱动,并且使用NBA,是为了避免让dut产生竞争-冒险;

Monitor:一般需要使用cb块对信号进行采样,并且使用BA,是因为只是采样,并不是驱动dut,不会让dut产生竞争-冒险;



Dut中:时序逻辑使用NBA、组合逻辑使用BA;

BA、NBA的不同如下:

Interface、Clocking Block、BA、NBA_第2张图片Interface、Clocking Block、BA、NBA_第3张图片 

你可能感兴趣的:(SystemVerilog,UVM,经验分享)