mirror of
https://github.com/verilator/verilator.git
synced 2025-01-03 21:27:35 +00:00
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:
parent
b55ee79d86
commit
f8b7981be4
@ -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();
|
||||||
|
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user