forked from github/verilator
dc25e9b949
Firstly, we always use a byte array for fine grained activity flags instead of a bit vector (we used to use a byte array only if we had parallel mtasks). The byte vector can be set more cheaply in eval, closing about 1/3 of the gap in performance between compiling with or without --trace on SweRV EH1. The speed of tracing itself is not measurably different. Secondly, we prune the activity tracking such that if a set of activity flag combinations only guard a small number of signals, we will turn those signals into awayls traced signals. This avoids code which sometimes tests dozens of activity flags just to subsequently check one signal and dump it if it's value changed. We can just check the signal state straight instead, and not bother with the flags. This removes about 30% of activity flags in SweRV EH1, and makes both single threaded VCD and FST tracing 8-9% faster.
127 lines
2.0 KiB
Plaintext
127 lines
2.0 KiB
Plaintext
$version Generated by VerilatedVcd $end
|
|
$date Sat Feb 29 09:18:19 2020
|
|
$end
|
|
$timescale 1ps $end
|
|
|
|
$scope module topa $end
|
|
$scope module t $end
|
|
$var wire 32 3 c_trace_on [31:0] $end
|
|
$var wire 1 # clk $end
|
|
$var wire 32 + cyc [31:0] $end
|
|
$scope module sub $end
|
|
$var wire 32 ; inside_sub_a [31:0] $end
|
|
$upscope $end
|
|
$upscope $end
|
|
$upscope $end
|
|
$scope module topb $end
|
|
$scope module t $end
|
|
$var wire 32 ^ c_trace_on [31:0] $end
|
|
$var wire 1 > clk $end
|
|
$var wire 32 V cyc [31:0] $end
|
|
$var real 64 F r $end
|
|
$scope module sub $end
|
|
$var wire 32 f inside_sub_a [31:0] $end
|
|
$upscope $end
|
|
$upscope $end
|
|
$upscope $end
|
|
$enddefinitions $end
|
|
|
|
|
|
#0
|
|
0#
|
|
b00000000000000000000000000000001 +
|
|
b00000000000000000000000000000000 3
|
|
b00000000000000000000000000000001 ;
|
|
0>
|
|
r0 F
|
|
b00000000000000000000000000000001 V
|
|
b00000000000000000000000000000000 ^
|
|
b00000000000000000000000000000010 f
|
|
#10000
|
|
1#
|
|
b00000000000000000000000000000010 +
|
|
b00000000000000000000000000000011 3
|
|
1>
|
|
r0.1 F
|
|
#15000
|
|
0#
|
|
0>
|
|
#20000
|
|
1#
|
|
b00000000000000000000000000000011 +
|
|
b00000000000000000000000000000100 3
|
|
1>
|
|
r0.2 F
|
|
#25000
|
|
0#
|
|
0>
|
|
#30000
|
|
1#
|
|
b00000000000000000000000000000100 +
|
|
b00000000000000000000000000000101 3
|
|
1>
|
|
r0.3 F
|
|
#35000
|
|
0#
|
|
0>
|
|
#40000
|
|
1#
|
|
b00000000000000000000000000000101 +
|
|
b00000000000000000000000000000110 3
|
|
1>
|
|
r0.4 F
|
|
#45000
|
|
0#
|
|
0>
|
|
#50000
|
|
1#
|
|
b00000000000000000000000000000110 +
|
|
b00000000000000000000000000000111 3
|
|
1>
|
|
r0.5 F
|
|
#55000
|
|
0#
|
|
0>
|
|
#60000
|
|
1#
|
|
b00000000000000000000000000000111 +
|
|
b00000000000000000000000000001000 3
|
|
1>
|
|
r0.6 F
|
|
#65000
|
|
0#
|
|
0>
|
|
#70000
|
|
1#
|
|
b00000000000000000000000000001000 +
|
|
b00000000000000000000000000001001 3
|
|
1>
|
|
r0.7 F
|
|
#75000
|
|
0#
|
|
0>
|
|
#80000
|
|
1#
|
|
b00000000000000000000000000001001 +
|
|
b00000000000000000000000000001010 3
|
|
1>
|
|
r0.7999999999999999 F
|
|
#85000
|
|
0#
|
|
0>
|
|
#90000
|
|
1#
|
|
b00000000000000000000000000001010 +
|
|
b00000000000000000000000000001011 3
|
|
1>
|
|
r0.8999999999999999 F
|
|
#95000
|
|
0#
|
|
0>
|
|
#100000
|
|
1#
|
|
1>
|
|
b00000000000000000000000000001011 +
|
|
b00000000000000000000000000001100 3
|
|
r0.9999999999999999 F
|