-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathtb.sv
48 lines (38 loc) · 1.12 KB
/
tb.sv
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
// Basic example code showcasing how to use sv_waveterm with assertions
// License for example code: CC0 "No Rights Reserved"
module tb;
`include "sv_waveterm.sv"
logic clk = 0;
always #5 clk <= !clk;
logic reset_b = '0;
initial begin
#17;
reset_b = '1;
#1000;
$finish;
end
logic [3:0] counter;
always @(posedge clk or negedge reset_b) begin
if (!reset_b) begin
counter <= '0;
end else begin
counter <= counter + 1'b1;
end
end
`sv_waveterm_begin(counter_waves, clk)
`sv_waveterm_int(reset_b)
`sv_waveterm_int(counter)
`sv_waveterm_end
a_not_9 : assert property(
@(posedge clk) disable iff (!reset_b)
counter != 9
) else $fatal(0, "Counter is 9\n%s", counter_waves.sprint());
a_not_5 : assert property(
@(posedge clk) disable iff (!reset_b)
counter != 5
) else $error("Counter is 5\n%s", counter_waves.sprint());
a_not_4 : assert property(
@(posedge clk) disable iff (!reset_b)
counter != 4
) else $error("Counter is 4\n%s", counter_waves.sprint());
endmodule // tb