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

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

手机号码,快捷登录

手机号码,快捷登录

找回密码

  登录   注册  

快捷导航
搜帖子
查看: 10781|回复: 12

[求助] uvm环境中怎样停止一个systemverilog线程

[复制链接]
发表于 2012-7-13 16:12:38 | 显示全部楼层 |阅读模式

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

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

x
本帖最后由 heritor 于 2012-7-13 18:05 编辑

各位大侠:
      我现在想在uvm中停止一个线程不知怎样做,我的情况是

首先我在task a 中启动了一个线程


task a;

......
   fork : error_check
          .......
   join_none


endtask

现在我想在task b中去停止这个线程,可是在task b中用disable  error_check 。显示 不识别error_check 标签,
项目中task a运行结束后肯定会运行task b,只是在task b和task a 之间有很多任务.我怎样才能把这个标签导出来呢?或者有没有其它的办法?
发表于 2012-7-13 22:56:43 | 显示全部楼层
有一个办法是传process:
task a(ref process p);
   fork begin: error_check
//spawn error_check thread
         p = process::self();
         error_check();
   end
   join_none
endtask
task b(ref process p);
   ....
   p.kill();
endtask

process myproc;
a(myproc);
task1();
task2();
...
taskN();
b(p);//kill error_check thread
发表于 2012-7-13 23:40:02 | 显示全部楼层
这就是进程间通信的问题了吧
用event啊 mailbox啊  semaphore啊  一个全局变量啥的   只要让两个进程共享目前的状况就可以做到
 楼主| 发表于 2012-7-16 17:44:10 | 显示全部楼层
whxqq 的方法可行,我check_error启动的是一个forever 循环,直接kill了比较好。
发表于 2012-7-19 05:35:25 | 显示全部楼层
学习了
发表于 2012-7-26 09:45:34 | 显示全部楼层
我只能说,有点高深了。。。
发表于 2012-7-26 09:47:07 | 显示全部楼层
回复 2# whxqq


    请教一下:vmm中有没有线程哦?好像没有见过。。UVM不了。。
 楼主| 发表于 2012-7-26 17:47:29 | 显示全部楼层
回复 7# mikiahmikiah


    这是systemverilog中的,和uvm与VMM无关系。
发表于 2012-7-26 20:08:54 | 显示全部楼层
一般都是會在這個endfork 后面直接做事情,到需要等這個fork全部純種結束或是要kill他時,直接在那等待或kill的地方wait fork 或disable fork就OK了,但我還沒在碰到過在要kill的fork與kill的地方中間還插了fork的情況。看二樓的方法貌似是想把那個handle直接拿出來,但沒見過這個語句誒,不知道在哪里可以查看這個語句的用法
发表于 2012-7-27 08:27:45 | 显示全部楼层
回复 8# heritor


    哦。。谢谢解答。。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

站长推荐 上一条 /2 下一条

×

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

GMT+8, 2024-12-21 00:27 , Processed in 0.020432 second(s), 7 queries , Gzip On, Redis On.

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