forked from github/verilator
Add -DVM_TRACE_VCD in model builds with Make with --trace
This commit is contained in:
parent
551bd284dd
commit
b130a8cfeb
1
Changes
1
Changes
@ -15,6 +15,7 @@ Verilator 4.223 devel
|
|||||||
|
|
||||||
* Support compile time trace signal selection with tracing_on/off (#3323). [Shunyao CAD]
|
* Support compile time trace signal selection with tracing_on/off (#3323). [Shunyao CAD]
|
||||||
* Add assert when VerilatedContext is mis-deleted (#3121). [Rupert Swarbrick]
|
* Add assert when VerilatedContext is mis-deleted (#3121). [Rupert Swarbrick]
|
||||||
|
* Define VM_TRACE_VCD when tracing in VCD format. [Geza Lore, Shunyao CAD]
|
||||||
* Fix hang with large case statement optimization (#3405). [Mike Urbach]
|
* Fix hang with large case statement optimization (#3405). [Mike Urbach]
|
||||||
* Fix 'with' operator with type casting (#3387). [xiak95]
|
* Fix 'with' operator with type casting (#3387). [xiak95]
|
||||||
|
|
||||||
|
@ -56,6 +56,7 @@ VK_CPPFLAGS_ALWAYS += \
|
|||||||
-DVM_SC=$(VM_SC) \
|
-DVM_SC=$(VM_SC) \
|
||||||
-DVM_TRACE=$(VM_TRACE) \
|
-DVM_TRACE=$(VM_TRACE) \
|
||||||
-DVM_TRACE_FST=$(VM_TRACE_FST) \
|
-DVM_TRACE_FST=$(VM_TRACE_FST) \
|
||||||
|
-DVM_TRACE_VCD=$(VM_TRACE_VCD) \
|
||||||
$(CFG_CXXFLAGS_NO_UNUSED) \
|
$(CFG_CXXFLAGS_NO_UNUSED) \
|
||||||
|
|
||||||
ifeq ($(CFG_WITH_CCWARN),yes) # Local... Else don't burden users
|
ifeq ($(CFG_WITH_CCWARN),yes) # Local... Else don't burden users
|
||||||
|
@ -119,14 +119,10 @@ class CMakeEmitter final {
|
|||||||
cmake_set_raw(*of, name + "_TRACE_STRUCTS", cvtToStr(v3Global.opt.traceStructs()));
|
cmake_set_raw(*of, name + "_TRACE_STRUCTS", cvtToStr(v3Global.opt.traceStructs()));
|
||||||
*of << "# VCD Tracing output mode? 0/1 (from --trace)\n";
|
*of << "# VCD Tracing output mode? 0/1 (from --trace)\n";
|
||||||
cmake_set_raw(*of, name + "_TRACE_VCD",
|
cmake_set_raw(*of, name + "_TRACE_VCD",
|
||||||
(v3Global.opt.trace() && (v3Global.opt.traceFormat() == TraceFormat::VCD))
|
(v3Global.opt.trace() && v3Global.opt.traceFormat().vcd()) ? "1" : "0");
|
||||||
? "1"
|
*of << "# FST Tracing output mode? 0/1 (from --trace-fst)\n";
|
||||||
: "0");
|
|
||||||
*of << "# FST Tracing output mode? 0/1 (from --fst-trace)\n";
|
|
||||||
cmake_set_raw(*of, name + "_TRACE_FST",
|
cmake_set_raw(*of, name + "_TRACE_FST",
|
||||||
(v3Global.opt.trace() && (v3Global.opt.traceFormat() != TraceFormat::VCD))
|
(v3Global.opt.trace() && v3Global.opt.traceFormat().fst()) ? "1" : "0");
|
||||||
? "1"
|
|
||||||
: "0");
|
|
||||||
|
|
||||||
*of << "\n### Sources...\n";
|
*of << "\n### Sources...\n";
|
||||||
std::vector<string> classes_fast;
|
std::vector<string> classes_fast;
|
||||||
|
@ -65,6 +65,10 @@ public:
|
|||||||
of.puts("VM_TRACE = ");
|
of.puts("VM_TRACE = ");
|
||||||
of.puts(v3Global.opt.trace() ? "1" : "0");
|
of.puts(v3Global.opt.trace() ? "1" : "0");
|
||||||
of.puts("\n");
|
of.puts("\n");
|
||||||
|
of.puts("# Tracing output mode in VCD format? 0/1 (from --trace)\n");
|
||||||
|
of.puts("VM_TRACE_VCD = ");
|
||||||
|
of.puts(v3Global.opt.trace() && v3Global.opt.traceFormat().vcd() ? "1" : "0");
|
||||||
|
of.puts("\n");
|
||||||
of.puts("# Tracing output mode in FST format? 0/1 (from --trace-fst)\n");
|
of.puts("# Tracing output mode in FST format? 0/1 (from --trace-fst)\n");
|
||||||
of.puts("VM_TRACE_FST = ");
|
of.puts("VM_TRACE_FST = ");
|
||||||
of.puts(v3Global.opt.trace() && v3Global.opt.traceFormat().fst() ? "1" : "0");
|
of.puts(v3Global.opt.trace() && v3Global.opt.traceFormat().fst() ? "1" : "0");
|
||||||
|
@ -137,6 +137,7 @@ public:
|
|||||||
: m_e(static_cast<en>(_e)) {} // Need () or GCC 4.8 false warning
|
: m_e(static_cast<en>(_e)) {} // Need () or GCC 4.8 false warning
|
||||||
operator en() const { return m_e; }
|
operator en() const { return m_e; }
|
||||||
bool fst() const { return m_e == FST; }
|
bool fst() const { return m_e == FST; }
|
||||||
|
bool vcd() const { return m_e == VCD; }
|
||||||
string classBase() const {
|
string classBase() const {
|
||||||
static const char* const names[] = {"VerilatedVcd", "VerilatedFst"};
|
static const char* const names[] = {"VerilatedVcd", "VerilatedFst"};
|
||||||
return names[m_e];
|
return names[m_e];
|
||||||
|
Loading…
Reference in New Issue
Block a user