forked from github/verilator
Fix cppcheck warnings. No functional change intended.
This commit is contained in:
parent
5d26bca55c
commit
0eb1d0a84e
@ -569,7 +569,7 @@ void VerilatedVcd::declare (vluint32_t code, const char* name, const char* wirep
|
|||||||
sprintf(buf, " %2d ", bits);
|
sprintf(buf, " %2d ", bits);
|
||||||
decl += buf;
|
decl += buf;
|
||||||
if (m_evcd) {
|
if (m_evcd) {
|
||||||
sprintf(buf, "<%d", code);
|
sprintf(buf, "<%u", code);
|
||||||
decl += buf;
|
decl += buf;
|
||||||
} else {
|
} else {
|
||||||
decl += stringCode(code);
|
decl += stringCode(code);
|
||||||
|
@ -166,7 +166,7 @@ private:
|
|||||||
}
|
}
|
||||||
UINFO(8,"Simple case statement: "<<nodep<<endl);
|
UINFO(8,"Simple case statement: "<<nodep<<endl);
|
||||||
// Zero list of items for each value
|
// Zero list of items for each value
|
||||||
for (uint32_t i=0; i<(1UL<<m_caseWidth); i++) m_valueItem[i] = NULL;
|
for (uint32_t i=0; i<(1UL<<m_caseWidth); ++i) m_valueItem[i] = NULL;
|
||||||
// Now pick up the values for each assignment
|
// Now pick up the values for each assignment
|
||||||
// We can cheat and use uint32_t's because we only support narrow case's
|
// We can cheat and use uint32_t's because we only support narrow case's
|
||||||
bool bitched = false;
|
bool bitched = false;
|
||||||
@ -184,7 +184,7 @@ private:
|
|||||||
V3Number numval (itemp->fileline(), iconstp->width());
|
V3Number numval (itemp->fileline(), iconstp->width());
|
||||||
numval.opBitsOne(iconstp->num());
|
numval.opBitsOne(iconstp->num());
|
||||||
uint32_t val = numval.toUInt();
|
uint32_t val = numval.toUInt();
|
||||||
for (uint32_t i=0; i<(1UL<<m_caseWidth); i++) {
|
for (uint32_t i=0; i<(1UL<<m_caseWidth); ++i) {
|
||||||
if ((i & mask) == val) {
|
if ((i & mask) == val) {
|
||||||
if (!m_valueItem[i]) {
|
if (!m_valueItem[i]) {
|
||||||
m_valueItem[i] = itemp;
|
m_valueItem[i] = itemp;
|
||||||
@ -199,12 +199,12 @@ private:
|
|||||||
}
|
}
|
||||||
// Defaults were moved to last in the caseitem list by V3LinkDot
|
// Defaults were moved to last in the caseitem list by V3LinkDot
|
||||||
if (itemp->isDefault()) { // Case statement's default... Fill the table
|
if (itemp->isDefault()) { // Case statement's default... Fill the table
|
||||||
for (uint32_t i=0; i<(1UL<<m_caseWidth); i++) {
|
for (uint32_t i=0; i<(1UL<<m_caseWidth); ++i) {
|
||||||
if (!m_valueItem[i]) m_valueItem[i] = itemp;
|
if (!m_valueItem[i]) m_valueItem[i] = itemp;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for (uint32_t i=0; i<(1UL<<m_caseWidth); i++) {
|
for (uint32_t i=0; i<(1UL<<m_caseWidth); ++i) {
|
||||||
if (!m_valueItem[i]) {
|
if (!m_valueItem[i]) {
|
||||||
nodep->v3warn(CASEINCOMPLETE,"Case values incompletely covered (example pattern 0x"<<hex<<i<<")");
|
nodep->v3warn(CASEINCOMPLETE,"Case values incompletely covered (example pattern 0x"<<hex<<i<<")");
|
||||||
m_caseNoOverlapsAllCovered = false;
|
m_caseNoOverlapsAllCovered = false;
|
||||||
@ -278,7 +278,7 @@ private:
|
|||||||
AstNode* cexprp = nodep->exprp()->unlinkFrBack();
|
AstNode* cexprp = nodep->exprp()->unlinkFrBack();
|
||||||
|
|
||||||
if (debug()>=9) {
|
if (debug()>=9) {
|
||||||
for (uint32_t i=0; i<(1UL<<m_caseWidth); i++) {
|
for (uint32_t i=0; i<(1UL<<m_caseWidth); ++i) {
|
||||||
if (AstNode* itemp = m_valueItem[i]) {
|
if (AstNode* itemp = m_valueItem[i]) {
|
||||||
UINFO(9,"Value "<<hex<<i<<" "<<itemp<<endl);
|
UINFO(9,"Value "<<hex<<i<<" "<<itemp<<endl);
|
||||||
}
|
}
|
||||||
|
@ -386,10 +386,13 @@ private:
|
|||||||
public:
|
public:
|
||||||
// CONSTUCTORS
|
// CONSTUCTORS
|
||||||
explicit ClockVisitor(AstNetlist* nodep) {
|
explicit ClockVisitor(AstNetlist* nodep) {
|
||||||
m_modp=NULL;
|
m_modp = NULL;
|
||||||
m_evalFuncp = NULL;
|
m_evalFuncp = NULL;
|
||||||
m_topScopep=NULL;
|
m_initFuncp = NULL;
|
||||||
m_lastSenp=NULL;
|
m_finalFuncp = NULL;
|
||||||
|
m_settleFuncp = NULL;
|
||||||
|
m_topScopep = NULL;
|
||||||
|
m_lastSenp = NULL;
|
||||||
m_lastIfp = NULL;
|
m_lastIfp = NULL;
|
||||||
m_scopep = NULL;
|
m_scopep = NULL;
|
||||||
//
|
//
|
||||||
|
@ -402,6 +402,7 @@ private:
|
|||||||
UINFO(4," MOD "<<nodep<<endl);
|
UINFO(4," MOD "<<nodep<<endl);
|
||||||
m_modp = nodep;
|
m_modp = nodep;
|
||||||
m_modNFuncs = 0;
|
m_modNFuncs = 0;
|
||||||
|
m_walkLast2p = NULL;
|
||||||
m_hashed.clear();
|
m_hashed.clear();
|
||||||
// Compute hash of all statement trees in the function
|
// Compute hash of all statement trees in the function
|
||||||
m_state = STATE_HASH;
|
m_state = STATE_HASH;
|
||||||
|
@ -382,6 +382,7 @@ public:
|
|||||||
explicit CoverageVisitor(AstNetlist* rootp) {
|
explicit CoverageVisitor(AstNetlist* rootp) {
|
||||||
// Operate on all modules
|
// Operate on all modules
|
||||||
m_checkBlock = true;
|
m_checkBlock = true;
|
||||||
|
m_modp = NULL;
|
||||||
m_beginHier = "";
|
m_beginHier = "";
|
||||||
m_inToggleOff = false;
|
m_inToggleOff = false;
|
||||||
m_inModOff = true;
|
m_inModOff = true;
|
||||||
|
@ -119,7 +119,8 @@ private:
|
|||||||
<<nodep->varp()->prettyName());
|
<<nodep->varp()->prettyName());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
AstVarScope* createVarSc(AstVarScope* oldvarscp, string name, int width/*0==fromoldvar*/, AstNodeDType* newdtypep) {
|
AstVarScope* createVarSc(AstVarScope* oldvarscp, const string& name,
|
||||||
|
int width/*0==fromoldvar*/, AstNodeDType* newdtypep) {
|
||||||
// Because we've already scoped it, we may need to add both the AstVar and the AstVarScope
|
// Because we've already scoped it, we may need to add both the AstVar and the AstVarScope
|
||||||
if (!oldvarscp->scopep()) oldvarscp->v3fatalSrc("Var unscoped");
|
if (!oldvarscp->scopep()) oldvarscp->v3fatalSrc("Var unscoped");
|
||||||
AstVar* varp;
|
AstVar* varp;
|
||||||
|
@ -126,8 +126,10 @@ private:
|
|||||||
public:
|
public:
|
||||||
// CONSTUCTORS
|
// CONSTUCTORS
|
||||||
explicit DepthBlockVisitor(AstNetlist* nodep) {
|
explicit DepthBlockVisitor(AstNetlist* nodep) {
|
||||||
m_modp=NULL;
|
m_modp = NULL;
|
||||||
m_depth=0;
|
m_funcp = NULL;
|
||||||
|
m_depth = 0;
|
||||||
|
m_deepNum = 0;
|
||||||
//
|
//
|
||||||
nodep->accept(*this);
|
nodep->accept(*this);
|
||||||
}
|
}
|
||||||
|
@ -993,7 +993,7 @@ class EmitCImp : EmitCStmts {
|
|||||||
// High level
|
// High level
|
||||||
void emitImp(AstNodeModule* modp);
|
void emitImp(AstNodeModule* modp);
|
||||||
void emitStaticDecl(AstNodeModule* modp);
|
void emitStaticDecl(AstNodeModule* modp);
|
||||||
void emitSettleLoop(std::string eval_call, bool initial);
|
void emitSettleLoop(const std::string& eval_call, bool initial);
|
||||||
void emitWrapEval(AstNodeModule* modp);
|
void emitWrapEval(AstNodeModule* modp);
|
||||||
void emitInt(AstNodeModule* modp);
|
void emitInt(AstNodeModule* modp);
|
||||||
void maybeSplit(AstNodeModule* modp);
|
void maybeSplit(AstNodeModule* modp);
|
||||||
@ -1752,7 +1752,7 @@ void EmitCImp::emitSensitives() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void EmitCImp::emitSettleLoop(std::string eval_call, bool initial) {
|
void EmitCImp::emitSettleLoop(const std::string& eval_call, bool initial) {
|
||||||
putsDecoration("// Evaluate till stable\n");
|
putsDecoration("// Evaluate till stable\n");
|
||||||
puts("int __VclockLoop = 0;\n");
|
puts("int __VclockLoop = 0;\n");
|
||||||
puts("QData __Vchange = 1;\n");
|
puts("QData __Vchange = 1;\n");
|
||||||
|
@ -829,6 +829,8 @@ private:
|
|||||||
// Rather than doing a (slowish) ==##, we OR in the bits that aren't part of the mask
|
// Rather than doing a (slowish) ==##, we OR in the bits that aren't part of the mask
|
||||||
eqp = new AstOr (nodep->fileline(),
|
eqp = new AstOr (nodep->fileline(),
|
||||||
new AstConst (nodep->fileline(), notWideMask(nodep->lhsp())),
|
new AstConst (nodep->fileline(), notWideMask(nodep->lhsp())),
|
||||||
|
// Bug in cppcheck
|
||||||
|
// cppcheck-suppress memleak
|
||||||
eqp);
|
eqp);
|
||||||
}
|
}
|
||||||
newp = (newp==NULL) ? eqp : (new AstAnd (nodep->fileline(), newp, eqp));
|
newp = (newp==NULL) ? eqp : (new AstAnd (nodep->fileline(), newp, eqp));
|
||||||
|
@ -1612,7 +1612,7 @@ void OrderVisitor::process() {
|
|||||||
UINFO(2," Process Circulars...\n");
|
UINFO(2," Process Circulars...\n");
|
||||||
processCircular(); // must be before processDomains
|
processCircular(); // must be before processDomains
|
||||||
|
|
||||||
// Assign logic verticesto new domains
|
// Assign logic vertices to new domains
|
||||||
UINFO(2," Domains...\n");
|
UINFO(2," Domains...\n");
|
||||||
processDomains();
|
processDomains();
|
||||||
m_graph.dumpDotFilePrefixed("orderg_domain");
|
m_graph.dumpDotFilePrefixed("orderg_domain");
|
||||||
|
@ -211,9 +211,9 @@ uint64_t V3Os::memUsageBytes() {
|
|||||||
if (!fp) {
|
if (!fp) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
uint64_t size, resident, share, text, lib, data, dt; // All in pages
|
vluint64_t size, resident, share, text, lib, data, dt; // All in pages
|
||||||
if (7 != fscanf(fp, "%" VL_PRI64 "d %" VL_PRI64 "d %" VL_PRI64 "d %"
|
if (7 != fscanf(fp, "%" VL_PRI64 "u %" VL_PRI64 "u %" VL_PRI64 "u %"
|
||||||
VL_PRI64 "d %" VL_PRI64 "d %" VL_PRI64 "d %" VL_PRI64 "d",
|
VL_PRI64 "u %" VL_PRI64 "u %" VL_PRI64 "u %" VL_PRI64 "u",
|
||||||
&size, &resident, &share, &text, &lib, &data, &dt)) {
|
&size, &resident, &share, &text, &lib, &data, &dt)) {
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -1258,7 +1258,9 @@ public:
|
|||||||
m_modp = NULL;
|
m_modp = NULL;
|
||||||
m_topScopep = NULL;
|
m_topScopep = NULL;
|
||||||
m_scopep = NULL;
|
m_scopep = NULL;
|
||||||
|
m_insMode = IM_BEFORE;
|
||||||
m_insStmtp = NULL;
|
m_insStmtp = NULL;
|
||||||
|
m_modNCalls = 0;
|
||||||
AstNode::user1ClearTree();
|
AstNode::user1ClearTree();
|
||||||
nodep->accept(*this);
|
nodep->accept(*this);
|
||||||
}
|
}
|
||||||
|
@ -700,6 +700,8 @@ public:
|
|||||||
m_chgSubFuncp = NULL;
|
m_chgSubFuncp = NULL;
|
||||||
m_chgSubParentp = NULL;
|
m_chgSubParentp = NULL;
|
||||||
m_chgSubStmts = 0;
|
m_chgSubStmts = 0;
|
||||||
|
m_code = 0;
|
||||||
|
m_finding = false;
|
||||||
m_funcNum = 0;
|
m_funcNum = 0;
|
||||||
nodep->accept(*this);
|
nodep->accept(*this);
|
||||||
}
|
}
|
||||||
|
@ -461,9 +461,11 @@ public:
|
|||||||
UnrollVisitor(AstNode* nodep, bool generate, const string& beginName) {
|
UnrollVisitor(AstNode* nodep, bool generate, const string& beginName) {
|
||||||
m_forVarp = NULL;
|
m_forVarp = NULL;
|
||||||
m_forVscp = NULL;
|
m_forVscp = NULL;
|
||||||
|
m_varValuep = NULL;
|
||||||
m_ignoreIncp = NULL;
|
m_ignoreIncp = NULL;
|
||||||
m_varModeCheck = false;
|
m_varModeCheck = false;
|
||||||
m_varModeReplace = false;
|
m_varModeReplace = false;
|
||||||
|
m_varAssignHit = false;
|
||||||
m_generate = generate;
|
m_generate = generate;
|
||||||
m_beginName = beginName;
|
m_beginName = beginName;
|
||||||
//
|
//
|
||||||
|
Loading…
Reference in New Issue
Block a user