《systemverilog验证》阅读笔记 -- 过程语句和子程序

过程语句

条件

if

case

循环

for

while

continue
break

子程序

function和task的使用,与verilog语法不太一样。主要区别:
- function可以不带返回值
- function里可以调用task;线程章节会介绍。
- function/task不需要begin…end包含了。
- task的参数,更灵活;比module的参数设置还灵活。

基于此特点,
可以定义用于debug的function了。

function void print_state(...);
    $display("@%0t,state=%s",$time,current_state.name());
endfunction

参数

function void print_checksum(const ref bit[31:0] a[]);
    bit[31:0] checksum=0;
    for(int i=0;i<a.size();i++)
        checksum ^= a[i];
    $display("The array checksum is %0d",checksum);
endfunction

其中const,是指参数变量不能改变,否则编译报错;
ref代表数组参数的传递,注意整个子程序需要是automatic属性,即自动存储。后文再讨论。
ref还有个好处,是用于线程的。后文再讨论。

return

出现错误的时候,跳出子程序。

带返回值的子程序

function void init(ref int f[5],
                    input int start);
    foreach(f[i])
        f[i]=i+start;
endfunction

int fa[5];
initial begin
    int(fa,5);
    foreach(fa[i])
        $display("fa[%0d]=%0d",i,fa[i]);
end

自动存储automatic

多线程的时候用到。
比如某个task,被多次调用,为了不让变量互相干扰。从verilog的默认静态共享,变为自动存储类型。后文再说吧。

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值