Dynamic threads in system verilog

Status
Not open for further replies.

giri_lp

Member level 3
Joined
Feb 11, 2006
Messages
61
Helped
0
Reputation
0
Reaction score
0
Trophy points
1,286
Visit site
Activity points
1,657
Hi All,
I am learning SV and I am coming across the concept called dynamic threads.

Can any one please explain me the concept of dynamic threads?


-Giri
 

Re: Dynamic threads in SystemVerilog

In Verilog, all static threads are started at time 0 from initial or always constructs. A thread may be split up by a fork/join constructs. If you count up the number of initial and always constructs , plus the number of statements inside all your fork/join constructs, you can determine exactly the total number of threads there will be in your simulation at compile time. That is what is meant by "static"

The fork/join_none or fork/join_any constructs spawns a number of dynamic threads from a static thread. Because the static thread does not block waiting for dynamic thread to complete, there's no way to determine at compile time the number of threads that will be created. Only be the execution of code, or dynamically will you know how many threads will be created.
 
Re: Dynamic threads in SystemVerilog

Thank you. I will do some exercise staring at a piece of example and will get back if I have any questions
 

Status
Not open for further replies.
Cookies are required to use this site. You must accept them to continue using the site. Learn more…