diff --git a/docs/CONTRIBUTORS b/docs/CONTRIBUTORS index f68ce43d5..3ca519cd0 100644 --- a/docs/CONTRIBUTORS +++ b/docs/CONTRIBUTORS @@ -4,6 +4,7 @@ under the Developer Certificate of Origin (https://developercertificate.org/). Please see the Verilator manual for 200+ additional contributors. Thanks to all. Adam Bagley +Adrian Sampson Adrien Le Masle Ahmed El-Mahmoudy Aleksander Kiryk diff --git a/src/V3TraceDecl.cpp b/src/V3TraceDecl.cpp index cceee8a5c..0735e6dce 100644 --- a/src/V3TraceDecl.cpp +++ b/src/V3TraceDecl.cpp @@ -259,10 +259,12 @@ class TraceDeclVisitor final : public VNVisitor { const std::string name = path.substr(pos == string::npos ? 0 : pos + 1); // Compute the type of the scope being fixed up - AstNodeModule* const modp = scopep->aboveCellp()->modp(); - const VTracePrefixType scopeType = VN_IS(modp, Iface) - ? VTracePrefixType::SCOPE_INTERFACE - : VTracePrefixType::SCOPE_MODULE; + const AstCell* const cellp = scopep->aboveCellp(); + const VTracePrefixType scopeType = cellp ? ( + VN_IS((cellp->modp()), Iface) + ? VTracePrefixType::SCOPE_INTERFACE + : VTracePrefixType::SCOPE_MODULE + ) : VTracePrefixType::SCOPE_MODULE; // Push the scope prefix AstNodeStmt* const pushp = new AstTracePushPrefix{flp, name, scopeType};