verilator/test_regress
Geza Lore dc25e9b949
Optimize fine grained trace activity flags (#2336)
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.
2020-05-17 13:53:02 +01:00
..
t Optimize fine grained trace activity flags (#2336) 2020-05-17 13:53:02 +01:00
.gdbinit
.gitignore
CMakeLists.txt
driver.pl Update internal code coverage framework. 2020-05-16 06:15:25 -04:00
input.vc Fix DPI import/export to be standard compliant, #2236. 2020-04-07 19:07:47 -04:00
input.xsim.vc
Makefile Clean additional objects. 2020-05-16 13:28:03 -04:00
Makefile_obj
vgen.pl Make vgen.pl deterministic 2020-04-24 04:53:33 +01:00