在线咨询
eetop公众号 创芯大讲堂 创芯人才网
切换到宽版

EETOP 创芯网论坛 (原名:电子顶级开发网)

手机号码,快捷登录

手机号码,快捷登录

找回密码

  登录   注册  

快捷导航
搜帖子
查看: 2648|回复: 6

[求助] 测试的时候遇到关于task 的问题

[复制链接]
发表于 2013-8-4 14:26:13 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?注册

x
本帖最后由 tjzcl 于 2013-8-4 14:29 编辑

在testbench中这样定义:
         ......
reg vdd_en,pad_en;
          ......

initial begin
forever begin
aa_inst(vdd_en,pad_en);
bb_inst(vdd_en,pad_en);
end
end
    ................
task aa_inst;
begin
vdd_en = 1'b0;
pad_en = 1'b0;
#1000;

vdd_en = 1'b1;
pad_en = 1'b1;
#2000;

vdd_en = 1'b0;
pad_en = 1'b0;
#1000;
end
endtask

task bb_inst;
begin
vdd_en = 1'b0;
pad_en = 1'b0;
#1000;

vdd_en = 1'b1;
pad_en = 1'b1;
#2000;

vdd_en = 1'b0;
pad_en = 1'b0;
#1000;
end
endtask


在被测试代码中有这样的2个计数模块:

     ..........
always@(posedge pad_en) begin
num <= num + 1'b1;
end

always@(posedge vdd_en) begin
num1 <= num1 + 1'b1;
end
       ...................

测试的软件是用vcs2009版本(用modelsim仿真完全没有问题),结果却出现意外的情况:

首先声明函数间的传递完全没有问题,在波形上看vdd_en和pad_en的波形也完全没有问题;

但是在执行完aa_inst到执行bb_inst这段时间里面(bb_inst执行完转到执行aa_inst的时候也会有这样的问题),num和num1的值都发生了变化,但是在aa_inst结束时候vdd_en和pad_en都为0,而到了bb_inst中的开始也是全为0,并没有沿的变化,但是num和num1确实发生了变化!!

什么原因呢?百思不得其解啊!!求教高手!
 楼主| 发表于 2013-8-4 17:46:37 | 显示全部楼层
自己顶一下,高手都度假去了么
发表于 2013-8-5 09:22:19 | 显示全部楼层
个人建议,pad_en非时钟类信号时,不要使用
always@(posedge pad_en)
来建模

还有其他方式建模,比如
always@(posedge clk)
if(pad_en)
...

lz试一试
 楼主| 发表于 2013-8-8 20:54:05 | 显示全部楼层
回复 3# yadog


    thank you !!
 楼主| 发表于 2013-8-8 20:56:25 | 显示全部楼层
自己顶一下,高手请教!!
发表于 2013-8-11 00:02:10 | 显示全部楼层
三楼的方法学习了。。看来还是在任何时候都避免异步
发表于 2018-12-17 18:18:34 | 显示全部楼层
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋| 手机版| 关于我们| 联系我们| 在线咨询| 隐私声明| EETOP 创芯网
( 京ICP备:10050787号 京公网安备:11010502037710 )

GMT+8, 2024-11-5 12:37 , Processed in 0.023298 second(s), 9 queries , Gzip On, Redis On.

eetop公众号 创芯大讲堂 创芯人才网
快速回复 返回顶部 返回列表