mirror of
https://github.com/verilator/verilator.git
synced 2025-01-01 04:07:34 +00:00
Internals: Rename isInoutish
This commit is contained in:
parent
1277a40b31
commit
a934d965be
@ -786,8 +786,8 @@ public:
|
|||||||
}
|
}
|
||||||
string prettyName() const { return verilogKwd(); }
|
string prettyName() const { return verilogKwd(); }
|
||||||
bool isAny() const { return m_e != NONE; }
|
bool isAny() const { return m_e != NONE; }
|
||||||
// Looks like inout - "ish" because not identical to being an INOUT
|
bool isInout() const { return m_e == INOUT; }
|
||||||
bool isInoutish() const { return m_e == INOUT; }
|
bool isInoutOrRef() const { return m_e == INOUT || m_e == REF || m_e == CONSTREF; }
|
||||||
bool isInput() const { return m_e == INPUT; }
|
bool isInput() const { return m_e == INPUT; }
|
||||||
bool isNonOutput() const {
|
bool isNonOutput() const {
|
||||||
return m_e == INPUT || m_e == INOUT || m_e == REF || m_e == CONSTREF;
|
return m_e == INPUT || m_e == INOUT || m_e == REF || m_e == CONSTREF;
|
||||||
|
@ -2060,7 +2060,8 @@ public:
|
|||||||
bool isAnsi() const { return m_ansi; }
|
bool isAnsi() const { return m_ansi; }
|
||||||
bool isContinuously() const { return m_isContinuously; }
|
bool isContinuously() const { return m_isContinuously; }
|
||||||
bool isDeclTyped() const { return m_declTyped; }
|
bool isDeclTyped() const { return m_declTyped; }
|
||||||
bool isInoutish() const { return m_direction.isInoutish(); }
|
bool isInout() const { return m_direction.isInout(); }
|
||||||
|
bool isInoutOrRef() const { return m_direction.isInoutOrRef(); }
|
||||||
bool isInput() const { return m_direction.isInput(); }
|
bool isInput() const { return m_direction.isInput(); }
|
||||||
bool isNonOutput() const { return m_direction.isNonOutput(); }
|
bool isNonOutput() const { return m_direction.isNonOutput(); }
|
||||||
bool isReadOnly() const VL_MT_SAFE { return m_direction.isReadOnly(); }
|
bool isReadOnly() const VL_MT_SAFE { return m_direction.isReadOnly(); }
|
||||||
|
@ -535,7 +535,7 @@ string AstVar::vlEnumType() const {
|
|||||||
|
|
||||||
string AstVar::vlEnumDir() const {
|
string AstVar::vlEnumDir() const {
|
||||||
string out;
|
string out;
|
||||||
if (isInoutish()) {
|
if (isInout()) {
|
||||||
out = "VLVD_INOUT";
|
out = "VLVD_INOUT";
|
||||||
} else if (isWritable()) {
|
} else if (isWritable()) {
|
||||||
out = "VLVD_OUT";
|
out = "VLVD_OUT";
|
||||||
@ -2448,7 +2448,7 @@ int AstVarRef::instrCount() const {
|
|||||||
void AstVar::dump(std::ostream& str) const {
|
void AstVar::dump(std::ostream& str) const {
|
||||||
this->AstNode::dump(str);
|
this->AstNode::dump(str);
|
||||||
if (isSc()) str << " [SC]";
|
if (isSc()) str << " [SC]";
|
||||||
if (isPrimaryIO()) str << (isInoutish() ? " [PIO]" : (isWritable() ? " [PO]" : " [PI]"));
|
if (isPrimaryIO()) str << (isInout() ? " [PIO]" : (isWritable() ? " [PO]" : " [PI]"));
|
||||||
if (isIO()) str << " " << direction().ascii();
|
if (isIO()) str << " " << direction().ascii();
|
||||||
if (isConst()) str << " [CONST]";
|
if (isConst()) str << " [CONST]";
|
||||||
if (isPullup()) str << " [PULLUP]";
|
if (isPullup()) str << " [PULLUP]";
|
||||||
@ -2649,7 +2649,7 @@ bool AstNodeFTask::getPurityRecurse() const {
|
|||||||
// or any write reference to a variable that isn't an automatic function local.
|
// or any write reference to a variable that isn't an automatic function local.
|
||||||
for (AstNode* stmtp = this->stmtsp(); stmtp; stmtp = stmtp->nextp()) {
|
for (AstNode* stmtp = this->stmtsp(); stmtp; stmtp = stmtp->nextp()) {
|
||||||
if (const AstVar* const varp = VN_CAST(stmtp, Var)) {
|
if (const AstVar* const varp = VN_CAST(stmtp, Var)) {
|
||||||
if (varp->isInoutish() || varp->isRef()) return false;
|
if (varp->isInoutOrRef()) return false;
|
||||||
}
|
}
|
||||||
if (!stmtp->isPure()) return false;
|
if (!stmtp->isPure()) return false;
|
||||||
if (stmtp->exists([](const AstNodeVarRef* const varrefp) {
|
if (stmtp->exists([](const AstNodeVarRef* const varrefp) {
|
||||||
|
@ -192,7 +192,7 @@ void EmitCBaseVisitorConst::emitVarDecl(const AstVar* nodep, bool asRef) {
|
|||||||
if (nodep->attrScClocked() && nodep->isReadOnly()) {
|
if (nodep->attrScClocked() && nodep->isReadOnly()) {
|
||||||
putns(nodep, "sc_core::sc_in_clk ");
|
putns(nodep, "sc_core::sc_in_clk ");
|
||||||
} else {
|
} else {
|
||||||
if (nodep->isInoutish()) {
|
if (nodep->isInout()) {
|
||||||
putns(nodep, "sc_core::sc_inout<");
|
putns(nodep, "sc_core::sc_inout<");
|
||||||
} else if (nodep->isWritable()) {
|
} else if (nodep->isWritable()) {
|
||||||
putns(nodep, "sc_core::sc_out<");
|
putns(nodep, "sc_core::sc_out<");
|
||||||
@ -213,7 +213,7 @@ void EmitCBaseVisitorConst::emitVarDecl(const AstVar* nodep, bool asRef) {
|
|||||||
emitDeclArrayBrackets(nodep);
|
emitDeclArrayBrackets(nodep);
|
||||||
puts(";\n");
|
puts(";\n");
|
||||||
} else if (nodep->isIO() && basicp && !basicp->isOpaque()) {
|
} else if (nodep->isIO() && basicp && !basicp->isOpaque()) {
|
||||||
if (nodep->isInoutish()) {
|
if (nodep->isInout()) {
|
||||||
putns(nodep, "VL_INOUT");
|
putns(nodep, "VL_INOUT");
|
||||||
} else if (nodep->isWritable()) {
|
} else if (nodep->isWritable()) {
|
||||||
putns(nodep, "VL_OUT");
|
putns(nodep, "VL_OUT");
|
||||||
|
@ -733,7 +733,7 @@ class EmitCTrace final : EmitCFunc {
|
|||||||
puts("," + cvtToStr(enumNum));
|
puts("," + cvtToStr(enumNum));
|
||||||
|
|
||||||
// Direction
|
// Direction
|
||||||
if (nodep->declDirection().isInoutish()) {
|
if (nodep->declDirection().isInout()) {
|
||||||
puts(", VerilatedTraceSigDirection::INOUT");
|
puts(", VerilatedTraceSigDirection::INOUT");
|
||||||
} else if (nodep->declDirection().isWritable()) {
|
} else if (nodep->declDirection().isWritable()) {
|
||||||
puts(", VerilatedTraceSigDirection::OUTPUT");
|
puts(", VerilatedTraceSigDirection::OUTPUT");
|
||||||
|
@ -433,7 +433,7 @@ class DynScopeVisitor final : public VNVisitor {
|
|||||||
nodep->v3warn(
|
nodep->v3warn(
|
||||||
E_UNSUPPORTED,
|
E_UNSUPPORTED,
|
||||||
"Unsupported: Writing to a captured "
|
"Unsupported: Writing to a captured "
|
||||||
<< (nodep->varp()->isInoutish() ? "inout" : "output") << " variable in a "
|
<< (nodep->varp()->isInout() ? "inout" : "output") << " variable in a "
|
||||||
<< (VN_IS(nodep->backp(), AssignDly) ? "non-blocking assignment" : "fork")
|
<< (VN_IS(nodep->backp(), AssignDly) ? "non-blocking assignment" : "fork")
|
||||||
<< " after a timing control");
|
<< " after a timing control");
|
||||||
}
|
}
|
||||||
|
@ -67,7 +67,7 @@ class InstVisitor final : public VNVisitor {
|
|||||||
AstNodeExpr* const exprp = VN_AS(nodep->exprp(), NodeExpr)->cloneTree(false);
|
AstNodeExpr* const exprp = VN_AS(nodep->exprp(), NodeExpr)->cloneTree(false);
|
||||||
UASSERT_OBJ(exprp->width() == nodep->modVarp()->width(), nodep,
|
UASSERT_OBJ(exprp->width() == nodep->modVarp()->width(), nodep,
|
||||||
"Width mismatch, should have been handled in pinReconnectSimple");
|
"Width mismatch, should have been handled in pinReconnectSimple");
|
||||||
if (nodep->modVarp()->isInoutish()) {
|
if (nodep->modVarp()->isInout()) {
|
||||||
nodep->v3fatalSrc("Unsupported: Verilator is a 2-state simulator");
|
nodep->v3fatalSrc("Unsupported: Verilator is a 2-state simulator");
|
||||||
} else if (nodep->modVarp()->isWritable()) {
|
} else if (nodep->modVarp()->isWritable()) {
|
||||||
AstNodeExpr* const rhsp = new AstVarXRef{exprp->fileline(), nodep->modVarp(),
|
AstNodeExpr* const rhsp = new AstVarXRef{exprp->fileline(), nodep->modVarp(),
|
||||||
@ -558,7 +558,7 @@ public:
|
|||||||
// Important to add statement next to cell, in case there is a
|
// Important to add statement next to cell, in case there is a
|
||||||
// generate with same named cell
|
// generate with same named cell
|
||||||
cellp->addNextHere(newvarp);
|
cellp->addNextHere(newvarp);
|
||||||
if (pinVarp->isInoutish()) {
|
if (pinVarp->isInout()) {
|
||||||
pinVarp->v3fatalSrc("Unsupported: Inout connections to pins must be"
|
pinVarp->v3fatalSrc("Unsupported: Inout connections to pins must be"
|
||||||
" direct one-to-one connection (without any expression)");
|
" direct one-to-one connection (without any expression)");
|
||||||
} else if (pinVarp->isWritable()) {
|
} else if (pinVarp->isWritable()) {
|
||||||
|
@ -775,7 +775,7 @@ public:
|
|||||||
const std::pair<uint32_t, uint32_t> dim = nodep->dtypep()->dimensions(false);
|
const std::pair<uint32_t, uint32_t> dim = nodep->dtypep()->dimensions(false);
|
||||||
UINFO(7, nodep->prettyNameQ()
|
UINFO(7, nodep->prettyNameQ()
|
||||||
<< " pub:" << nodep->isSigPublic() << " pri:" << nodep->isPrimaryIO()
|
<< " pub:" << nodep->isSigPublic() << " pri:" << nodep->isPrimaryIO()
|
||||||
<< " io:" << nodep->isInoutish() << " typ:" << nodep->varType() << "\n");
|
<< " io:" << nodep->isInout() << " typ:" << nodep->varType() << "\n");
|
||||||
const char* reason = nullptr;
|
const char* reason = nullptr;
|
||||||
// Public variable cannot be split.
|
// Public variable cannot be split.
|
||||||
// at least one unpacked dimension must exist
|
// at least one unpacked dimension must exist
|
||||||
|
@ -515,7 +515,7 @@ class TaskVisitor final : public VNVisitor {
|
|||||||
pinp->v3fatalSrc("ref argument should have caused non-inline of function");
|
pinp->v3fatalSrc("ref argument should have caused non-inline of function");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (portp->isInoutish()) {
|
} else if (portp->isInout()) {
|
||||||
// if (debug() >= 9) pinp->dumpTree("-pinrsize- ");
|
// if (debug() >= 9) pinp->dumpTree("-pinrsize- ");
|
||||||
|
|
||||||
AstVarScope* const newvscp
|
AstVarScope* const newvscp
|
||||||
@ -900,7 +900,7 @@ class TaskVisitor final : public VNVisitor {
|
|||||||
|
|
||||||
if (portp->isNonOutput()) {
|
if (portp->isNonOutput()) {
|
||||||
std::string frName
|
std::string frName
|
||||||
= portp->isInoutish() && portp->basicp()->isDpiPrimitive()
|
= portp->isInout() && portp->basicp()->isDpiPrimitive()
|
||||||
&& portp->dtypep()->skipRefp()->arrayUnpackedElements() == 1
|
&& portp->dtypep()->skipRefp()->arrayUnpackedElements() == 1
|
||||||
? "*"
|
? "*"
|
||||||
: "";
|
: "";
|
||||||
|
@ -23,7 +23,7 @@
|
|||||||
// Over each module, from child to parent:
|
// Over each module, from child to parent:
|
||||||
// Build a graph, connecting signals together so we can propagate tristates
|
// Build a graph, connecting signals together so we can propagate tristates
|
||||||
// Variable becomes tristate with
|
// Variable becomes tristate with
|
||||||
// VAR->isInoutish
|
// VAR->isInout
|
||||||
// VAR->isPullup/isPulldown (converted to AstPullup/AstPulldown
|
// VAR->isPullup/isPulldown (converted to AstPullup/AstPulldown
|
||||||
// BufIf0/1
|
// BufIf0/1
|
||||||
// All variables on the LHS need to become tristate when there is:
|
// All variables on the LHS need to become tristate when there is:
|
||||||
@ -1779,7 +1779,7 @@ class TristateVisitor final : public TristateBaseVisitor {
|
|||||||
nodep->addNextHere(newp);
|
nodep->addNextHere(newp);
|
||||||
// We'll iterate on the new AstPull later
|
// We'll iterate on the new AstPull later
|
||||||
}
|
}
|
||||||
if (nodep->isInoutish()
|
if (nodep->isInout()
|
||||||
//|| varp->isOutput()
|
//|| varp->isOutput()
|
||||||
// Note unconnected output only changes behavior vs. previous
|
// Note unconnected output only changes behavior vs. previous
|
||||||
// versions and causes outputs that don't come from anywhere to
|
// versions and causes outputs that don't come from anywhere to
|
||||||
|
@ -504,7 +504,7 @@ class UndrivenVisitor final : public VNVisitorConst {
|
|||||||
}
|
}
|
||||||
void visit(AstPin* nodep) override {
|
void visit(AstPin* nodep) override {
|
||||||
VL_RESTORER(m_inInoutPin);
|
VL_RESTORER(m_inInoutPin);
|
||||||
m_inInoutPin = nodep->modVarp()->isInoutish();
|
m_inInoutPin = nodep->modVarp()->isInout();
|
||||||
iterateChildrenConst(nodep);
|
iterateChildrenConst(nodep);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user