forked from github/verilator
Minor optimization of PartContraction
Remove rarely used debug code from initialization loop.
This commit is contained in:
parent
546aeab9f2
commit
881c3f6e40
@ -1270,6 +1270,18 @@ public:
|
|||||||
|
|
||||||
// METHODS
|
// METHODS
|
||||||
void go() {
|
void go() {
|
||||||
|
if (m_slowAsserts) {
|
||||||
|
// Check there are no redundant edges
|
||||||
|
for (V3GraphVertex* itp = m_mtasksp->verticesBeginp(); itp;
|
||||||
|
itp = itp->verticesNextp()) {
|
||||||
|
std::unordered_set<const V3GraphVertex*> neighbors;
|
||||||
|
for (V3GraphEdge* edgep = itp->outBeginp(); edgep; edgep = edgep->outNextp()) {
|
||||||
|
const bool first = neighbors.insert(edgep->top()).second;
|
||||||
|
UASSERT_OBJ(first, itp, "Redundant edge found in input to PartContraction()");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
unsigned maxMTasks = v3Global.opt.threadsMaxMTasks();
|
unsigned maxMTasks = v3Global.opt.threadsMaxMTasks();
|
||||||
if (maxMTasks == 0) { // Unspecified so estimate
|
if (maxMTasks == 0) { // Unspecified so estimate
|
||||||
if (v3Global.opt.threads() > 1) {
|
if (v3Global.opt.threads() > 1) {
|
||||||
@ -1290,15 +1302,9 @@ public:
|
|||||||
// - Incrementally recompute critical paths near the merged mtask.
|
// - Incrementally recompute critical paths near the merged mtask.
|
||||||
|
|
||||||
for (V3GraphVertex* itp = m_mtasksp->verticesBeginp(); itp; itp = itp->verticesNextp()) {
|
for (V3GraphVertex* itp = m_mtasksp->verticesBeginp(); itp; itp = itp->verticesNextp()) {
|
||||||
itp->userp(nullptr); // Reset user value. Used by PartPropagateCp.
|
itp->userp(nullptr); // Reset user value while we are here. Used by PartPropagateCp.
|
||||||
std::unordered_set<const V3GraphVertex*> neighbors;
|
|
||||||
for (V3GraphEdge* edgep = itp->outBeginp(); edgep; edgep = edgep->outNextp()) {
|
for (V3GraphEdge* edgep = itp->outBeginp(); edgep; edgep = edgep->outNextp()) {
|
||||||
m_sb.add(static_cast<MTaskEdge*>(edgep));
|
m_sb.add(static_cast<MTaskEdge*>(edgep));
|
||||||
if (m_slowAsserts) {
|
|
||||||
UASSERT_OBJ(neighbors.find(edgep->top()) == neighbors.end(), itp,
|
|
||||||
"Redundant edge found in input to PartContraction()");
|
|
||||||
}
|
|
||||||
neighbors.insert(edgep->top());
|
|
||||||
}
|
}
|
||||||
siblingPairFromRelatives<GraphWay::REVERSE, true>(itp);
|
siblingPairFromRelatives<GraphWay::REVERSE, true>(itp);
|
||||||
siblingPairFromRelatives<GraphWay::FORWARD, true>(itp);
|
siblingPairFromRelatives<GraphWay::FORWARD, true>(itp);
|
||||||
|
Loading…
Reference in New Issue
Block a user