mirror of
https://github.com/verilator/verilator.git
synced 2025-01-01 04:07:34 +00:00
Fix false $dumpfile warning on model save (#2834).
This commit is contained in:
parent
4261f72bd2
commit
e6b19d557e
2
Changes
2
Changes
@ -10,6 +10,8 @@ The contributors that suggested a given feature are shown in []. Thanks!
|
|||||||
|
|
||||||
**** Fix exceeding command-line ar limit (#2834). [Yinan Xu]
|
**** Fix exceeding command-line ar limit (#2834). [Yinan Xu]
|
||||||
|
|
||||||
|
**** Fix false $dumpfile warning on model save (#2834). [Yinan Xu]
|
||||||
|
|
||||||
|
|
||||||
* Verilator 4.200 2021-03-12
|
* Verilator 4.200 2021-03-12
|
||||||
|
|
||||||
|
@ -2202,11 +2202,15 @@ void VerilatedContext::dumpfile(const std::string& flag) VL_MT_SAFE_EXCLUDES(m_t
|
|||||||
}
|
}
|
||||||
std::string VerilatedContext::dumpfile() const VL_MT_SAFE_EXCLUDES(m_timeDumpMutex) {
|
std::string VerilatedContext::dumpfile() const VL_MT_SAFE_EXCLUDES(m_timeDumpMutex) {
|
||||||
const VerilatedLockGuard lock(m_timeDumpMutex);
|
const VerilatedLockGuard lock(m_timeDumpMutex);
|
||||||
if (VL_UNLIKELY(m_dumpfile.empty())) {
|
return m_dumpfile;
|
||||||
|
}
|
||||||
|
std::string VerilatedContext::dumpfileCheck() const VL_MT_SAFE_EXCLUDES(m_timeDumpMutex) {
|
||||||
|
const std::string out = dumpfile();
|
||||||
|
if (VL_UNLIKELY(out.empty())) {
|
||||||
VL_PRINTF_MT("%%Warning: $dumpvar ignored as not proceeded by $dumpfile\n");
|
VL_PRINTF_MT("%%Warning: $dumpvar ignored as not proceeded by $dumpfile\n");
|
||||||
return "";
|
return "";
|
||||||
}
|
}
|
||||||
return m_dumpfile;
|
return out;
|
||||||
}
|
}
|
||||||
void VerilatedContext::errorCount(int val) VL_MT_SAFE {
|
void VerilatedContext::errorCount(int val) VL_MT_SAFE {
|
||||||
const VerilatedLockGuard lock(m_mutex);
|
const VerilatedLockGuard lock(m_mutex);
|
||||||
|
@ -529,6 +529,7 @@ public: // But for internal use only
|
|||||||
// Internal: $dumpfile
|
// Internal: $dumpfile
|
||||||
void dumpfile(const std::string& flag) VL_MT_SAFE_EXCLUDES(m_timeDumpMutex);
|
void dumpfile(const std::string& flag) VL_MT_SAFE_EXCLUDES(m_timeDumpMutex);
|
||||||
std::string dumpfile() const VL_MT_SAFE_EXCLUDES(m_timeDumpMutex);
|
std::string dumpfile() const VL_MT_SAFE_EXCLUDES(m_timeDumpMutex);
|
||||||
|
std::string dumpfileCheck() const VL_MT_SAFE_EXCLUDES(m_timeDumpMutex);
|
||||||
|
|
||||||
// Internal: --prof-threads related settings
|
// Internal: --prof-threads related settings
|
||||||
void profThreadsStart(vluint64_t flag) VL_MT_SAFE;
|
void profThreadsStart(vluint64_t flag) VL_MT_SAFE;
|
||||||
|
@ -3523,7 +3523,7 @@ class EmitCTrace final : EmitCStmts {
|
|||||||
puts("if (VL_UNLIKELY(!__VlSymsp->__Vm_dumperp)) {\n");
|
puts("if (VL_UNLIKELY(!__VlSymsp->__Vm_dumperp)) {\n");
|
||||||
puts("__VlSymsp->__Vm_dumperp = new " + v3Global.opt.traceClassLang() + "();\n");
|
puts("__VlSymsp->__Vm_dumperp = new " + v3Global.opt.traceClassLang() + "();\n");
|
||||||
puts("trace(__VlSymsp->__Vm_dumperp, 0, 0);\n");
|
puts("trace(__VlSymsp->__Vm_dumperp, 0, 0);\n");
|
||||||
puts("std::string dumpfile = __VlSymsp->_vm_contextp__->dumpfile();\n");
|
puts("std::string dumpfile = __VlSymsp->_vm_contextp__->dumpfileCheck();\n");
|
||||||
puts("__VlSymsp->__Vm_dumperp->open(dumpfile.c_str());\n");
|
puts("__VlSymsp->__Vm_dumperp->open(dumpfile.c_str());\n");
|
||||||
puts("__VlSymsp->__Vm_dumping = true;\n");
|
puts("__VlSymsp->__Vm_dumping = true;\n");
|
||||||
puts("}\n");
|
puts("}\n");
|
||||||
|
Loading…
Reference in New Issue
Block a user