|
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
data:image/s3,"s3://crabby-images/70081/70081725daed7509ef608f65744137f7751316dd" alt="../images/main/bullet_green_ball.gif" |
expect
|
|
|
expect is same as assert in syntax, but expect is used inside a procedural block, and it waits till a property evalutes to true or false. |
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
|
Below example shows how a expect is used and its possible syntax. |
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
data:image/s3,"s3://crabby-images/180a6/180a67ce44f79a6885b1aa1e6502087811b76b36" alt="../images/main/bulllet_4dots_orange.gif" |
Example : expect
|
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
|
1 module expect_assertion;
2
3 logic clk = 0;
4 always #1 clk ++;
5
6 logic a, b,c;
7
8 default clocking myclk @ (posedge clk);
9
10 endclocking
11
12 initial begin
13 a <= 0;
14 b <= 0;
15 c <= 0;
16 ##1 ;
17 a <= 1;
18 ##1 ;
19 a <= 0;
20 b <= 1;
21 ##1 ;
22 b <= 0;
23 c <= 0;
24 ##1 ;
25 c <= 0;
26 ##20000 $finish;
27 end
28
29 initial begin
30 ##1 ;
31 // Wait for the sequence if pass, terminate sim
32 expect ( @ (posedge clk) a ##1 b ##1 c ##1 ! c)
33 $finish;
34 else
35 $error ("Something is wrong");
36 end
37
38 endmodule
You could download file expect_assertion.sv here
|
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
data:image/s3,"s3://crabby-images/180a6/180a67ce44f79a6885b1aa1e6502087811b76b36" alt="../images/main/bulllet_4dots_orange.gif" |
Simulation : expect
|
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
|
Something is wrong
Simulation complete via $finish(1) at time 40007 NS + 0
|
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/c07fa/c07faa78f89bc25daa6b296a3dfea8738f9196e2" alt="space.gif"
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/c2c27/c2c277fbe75b68ffa3f0eb99f3b30bb25fa28361" alt=""
|
|
Copyright © 1998-2025 |
Deepak Kumar Tala - All rights reserved |
Do you have any Comment? mail me at:deepak@asic-world.com
|
|