Make use of FST writer thread switchable at run-time.

Always build the FST libray with -DFST_WRITER_PARALLEL, iff VL_THREADED.
This supports run-time enablement of the FST writer thread, and has no
measurable performance impact on single threaded tracing but simplifies
the library build.

Note: the actual choice of using the fst writer thread is still compile
time, but can now be made run-time easily.
This commit is contained in:
Geza Lore 2022-07-19 13:48:03 +01:00
parent b55ee79d86
commit f8b7981be4
2 changed files with 10 additions and 4 deletions

View File

@ -28,7 +28,7 @@
#include "verilated_fst_c.h" #include "verilated_fst_c.h"
// GTKWave configuration // GTKWave configuration
#ifdef VL_TRACE_FST_WRITER_THREAD #ifdef VL_THREADED
# define HAVE_LIBPTHREAD # define HAVE_LIBPTHREAD
# define FST_WRITER_PARALLEL # define FST_WRITER_PARALLEL
#endif #endif
@ -116,9 +116,7 @@ void VerilatedFst::open(const char* filename) VL_MT_SAFE_EXCLUDES(m_mutex) {
m_fst = fstWriterCreate(filename, 1); m_fst = fstWriterCreate(filename, 1);
fstWriterSetPackType(m_fst, FST_WR_PT_LZ4); fstWriterSetPackType(m_fst, FST_WR_PT_LZ4);
fstWriterSetTimescaleFromString(m_fst, timeResStr().c_str()); // lintok-begin-on-ref fstWriterSetTimescaleFromString(m_fst, timeResStr().c_str()); // lintok-begin-on-ref
#ifdef VL_TRACE_FST_WRITER_THREAD if (useFstWriterThread()) fstWriterSetParallelMode(m_fst, 1);
fstWriterSetParallelMode(m_fst, 1);
#endif
fullDump(true); // First dump must be full for fst fullDump(true); // First dump must be full for fst
m_curScope.clear(); m_curScope.clear();

View File

@ -60,6 +60,14 @@ private:
void declare(uint32_t code, const char* name, int dtypenum, fstVarDir vardir, void declare(uint32_t code, const char* name, int dtypenum, fstVarDir vardir,
fstVarType vartype, bool array, int arraynum, bool bussed, int msb, int lsb); fstVarType vartype, bool array, int arraynum, bool bussed, int msb, int lsb);
static constexpr bool useFstWriterThread() {
#ifdef VL_TRACE_FST_WRITER_THREAD
return true;
#else
return false;
#endif
}
protected: protected:
//========================================================================= //=========================================================================
// Implementation of VerilatedTrace interface // Implementation of VerilatedTrace interface