mirror of
https://github.com/verilator/verilator.git
synced 2025-01-01 04:07:34 +00:00
Spelling fixes
This commit is contained in:
parent
3ccb2e0f2d
commit
c0499da28b
@ -445,7 +445,7 @@ detailed descriptions of these arguments.
|
|||||||
--unused-regexp <regexp> Tune UNUSED lint signals
|
--unused-regexp <regexp> Tune UNUSED lint signals
|
||||||
-V Verbose version and config
|
-V Verbose version and config
|
||||||
-v <filename> Verilog library
|
-v <filename> Verilog library
|
||||||
--no-verilate Skip verilation and just compile previously Verilated code
|
--no-verilate Skip Verilation and just compile previously Verilated code
|
||||||
+verilog1995ext+<ext> Synonym for +1364-1995ext+<ext>
|
+verilog1995ext+<ext> Synonym for +1364-1995ext+<ext>
|
||||||
+verilog2001ext+<ext> Synonym for +1364-2001ext+<ext>
|
+verilog2001ext+<ext> Synonym for +1364-2001ext+<ext>
|
||||||
--version Displays program version and exits
|
--version Displays program version and exits
|
||||||
|
@ -364,7 +364,7 @@ protected:
|
|||||||
// assumption is that the restore is allowed to pass different arguments
|
// assumption is that the restore is allowed to pass different arguments
|
||||||
struct NonSerializedCommandArgs {
|
struct NonSerializedCommandArgs {
|
||||||
// Medium speed
|
// Medium speed
|
||||||
std::vector<std::string> m_argVec; // Aargument list
|
std::vector<std::string> m_argVec; // Argument list
|
||||||
bool m_argVecLoaded = false; // Ever loaded argument list
|
bool m_argVecLoaded = false; // Ever loaded argument list
|
||||||
} m_args VL_GUARDED_BY(m_argMutex);
|
} m_args VL_GUARDED_BY(m_argMutex);
|
||||||
|
|
||||||
|
@ -506,7 +506,7 @@ static inline void VL_ASSIGNBIT_WO(int bit, WDataOutP owp) VL_MT_SAFE {
|
|||||||
int32_t lsb = 0; \
|
int32_t lsb = 0; \
|
||||||
uint32_t* chunkp = _butemp.get_raw(); \
|
uint32_t* chunkp = _butemp.get_raw(); \
|
||||||
while (lsb + VL_SC_BITS_PER_DIGIT < (obits)) { \
|
while (lsb + VL_SC_BITS_PER_DIGIT < (obits)) { \
|
||||||
static_assert(std::is_same<IData, EData>::value, "IData and EData missmatch"); \
|
static_assert(std::is_same<IData, EData>::value, "IData and EData mismatch"); \
|
||||||
const uint32_t data = VL_SEL_IWII(lsb + VL_SC_BITS_PER_DIGIT + 1, (rwp).data(), lsb, \
|
const uint32_t data = VL_SEL_IWII(lsb + VL_SC_BITS_PER_DIGIT + 1, (rwp).data(), lsb, \
|
||||||
VL_SC_BITS_PER_DIGIT); \
|
VL_SC_BITS_PER_DIGIT); \
|
||||||
*chunkp = data & VL_MASK_E(VL_SC_BITS_PER_DIGIT); \
|
*chunkp = data & VL_MASK_E(VL_SC_BITS_PER_DIGIT); \
|
||||||
|
@ -60,7 +60,7 @@ static const char* const VLTSAVE_TRAILER_STR = "vltsaved";
|
|||||||
//=============================================================================
|
//=============================================================================
|
||||||
//=============================================================================
|
//=============================================================================
|
||||||
//=============================================================================
|
//=============================================================================
|
||||||
// Searalization
|
// Serialization
|
||||||
|
|
||||||
bool VerilatedDeserialize::readDiffers(const void* __restrict datap,
|
bool VerilatedDeserialize::readDiffers(const void* __restrict datap,
|
||||||
size_t size) VL_MT_UNSAFE_ONE {
|
size_t size) VL_MT_UNSAFE_ONE {
|
||||||
|
@ -497,7 +497,7 @@ void VerilatedTrace<VL_SUB_T, VL_BUF_T>::runCallbacks(const std::vector<Callback
|
|||||||
const unsigned threads = threadPoolp->numThreads() + 1;
|
const unsigned threads = threadPoolp->numThreads() + 1;
|
||||||
// Main thread executes all jobs with index % threads == 0
|
// Main thread executes all jobs with index % threads == 0
|
||||||
std::vector<ParallelWorkerData*> mainThreadWorkerData;
|
std::vector<ParallelWorkerData*> mainThreadWorkerData;
|
||||||
// Enuque all the jobs
|
// Enqueue all the jobs
|
||||||
for (unsigned i = 0; i < cbVec.size(); ++i) {
|
for (unsigned i = 0; i < cbVec.size(); ++i) {
|
||||||
const CallbackRecord& cbr = cbVec[i];
|
const CallbackRecord& cbr = cbVec[i];
|
||||||
// Always get the trace buffer on the main thread
|
// Always get the trace buffer on the main thread
|
||||||
@ -793,7 +793,7 @@ static inline void cvtSDataToStr(char* dstp, SData value) {
|
|||||||
static inline void cvtIDataToStr(char* dstp, IData value) {
|
static inline void cvtIDataToStr(char* dstp, IData value) {
|
||||||
#ifdef VL_HAVE_AVX2
|
#ifdef VL_HAVE_AVX2
|
||||||
// Similar to cvtSDataToStr but the bottom 16-bits are processed in the
|
// Similar to cvtSDataToStr but the bottom 16-bits are processed in the
|
||||||
// top half of the YMM registerss
|
// top half of the YMM registers
|
||||||
const __m256i a = _mm256_insert_epi32(_mm256_undefined_si256(), value, 0);
|
const __m256i a = _mm256_insert_epi32(_mm256_undefined_si256(), value, 0);
|
||||||
const __m256i b = _mm256_permute4x64_epi64(a, 0);
|
const __m256i b = _mm256_permute4x64_epi64(a, 0);
|
||||||
const __m256i s = _mm256_set_epi8(0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 2, 2, 2, 2,
|
const __m256i s = _mm256_set_epi8(0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 2, 2, 2, 2,
|
||||||
|
@ -86,7 +86,7 @@ protected:
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Recursively traverse the graph to determine whether every control 'BLOCK' has an assignment
|
// Recursively traverse the graph to determine whether every control 'BLOCK' has an assignment
|
||||||
// to the output we are currently analysing (the output whose 'user() is set), if so return
|
// to the output we are currently analyzing (the output whose 'user() is set), if so return
|
||||||
// true. Where a BLOCK contains a BRANCH, both the if and else sides of the branch must return
|
// true. Where a BLOCK contains a BRANCH, both the if and else sides of the branch must return
|
||||||
// true for the BRANCH to evaluate to true. A BLOCK however needs only a single one of its
|
// true for the BRANCH to evaluate to true. A BLOCK however needs only a single one of its
|
||||||
// siblings to evaluate true in order to evaluate true itself. On output vertex only evaluates
|
// siblings to evaluate true in order to evaluate true itself. On output vertex only evaluates
|
||||||
|
@ -2207,7 +2207,7 @@ AstNode* AstNode::addNext<AstNode, AstNode>(AstNode* nodep, AstNode* newp);
|
|||||||
// Inline method implementations
|
// Inline method implementations
|
||||||
AstNode* AstNode::addNext(AstNode* newp) { return addNext(this, newp); }
|
AstNode* AstNode::addNext(AstNode* newp) { return addNext(this, newp); }
|
||||||
|
|
||||||
// Specialisations of privateTypeTest
|
// Specializations of privateTypeTest
|
||||||
#include "V3Ast__gen_type_tests.h" // From ./astgen
|
#include "V3Ast__gen_type_tests.h" // From ./astgen
|
||||||
|
|
||||||
// Specializations of AstNode::mayBeUnder
|
// Specializations of AstNode::mayBeUnder
|
||||||
|
@ -1158,7 +1158,7 @@ static bool sameInit(const AstInitArray* ap, const AstInitArray* bp) {
|
|||||||
// Compare initializer arrays by value. Note this is only called when they hash the same,
|
// Compare initializer arrays by value. Note this is only called when they hash the same,
|
||||||
// so they likely run at most once per call to 'AstConstPool::findTable'.
|
// so they likely run at most once per call to 'AstConstPool::findTable'.
|
||||||
// This assumes that the defaults are used in the same way.
|
// This assumes that the defaults are used in the same way.
|
||||||
// TODO when buinding the AstInitArray, remove any values matching the default
|
// TODO when building the AstInitArray, remove any values matching the default
|
||||||
const auto& amapr = ap->map();
|
const auto& amapr = ap->map();
|
||||||
const auto& bmapr = bp->map();
|
const auto& bmapr = bp->map();
|
||||||
const auto ait = amapr.cbegin();
|
const auto ait = amapr.cbegin();
|
||||||
|
@ -2719,7 +2719,7 @@ private:
|
|||||||
if (nodep->isClocked()) { // A constant can never get a pos/negedge
|
if (nodep->isClocked()) { // A constant can never get a pos/negedge
|
||||||
if (onlySenItemInSenTree(nodep)) {
|
if (onlySenItemInSenTree(nodep)) {
|
||||||
if (nodep->edgeType() == VEdgeType::ET_CHANGED) {
|
if (nodep->edgeType() == VEdgeType::ET_CHANGED) {
|
||||||
// TODO: This really is dodgy, as strictgly compliant simulators will not
|
// TODO: This really is dodgy, as strictly compliant simulators will not
|
||||||
// execute this block, but but t_func_check relies on it
|
// execute this block, but but t_func_check relies on it
|
||||||
nodep->replaceWith(
|
nodep->replaceWith(
|
||||||
new AstSenItem{nodep->fileline(), AstSenItem::Initial{}});
|
new AstSenItem{nodep->fileline(), AstSenItem::Initial{}});
|
||||||
|
@ -125,7 +125,7 @@ class DfgGraph final {
|
|||||||
|
|
||||||
// Variables and constants make up a significant proportion of vertices (40-50% was observed
|
// Variables and constants make up a significant proportion of vertices (40-50% was observed
|
||||||
// in large designs), and they can often be treated specially in algorithms, which in turn
|
// in large designs), and they can often be treated specially in algorithms, which in turn
|
||||||
// enables significant verilation performance gains, so we keep these in separate lists for
|
// enables significant Verilation performance gains, so we keep these in separate lists for
|
||||||
// direct access.
|
// direct access.
|
||||||
V3List<DfgVertex*> m_varVertices; // The variable vertices in the graph
|
V3List<DfgVertex*> m_varVertices; // The variable vertices in the graph
|
||||||
V3List<DfgVertex*> m_constVertices; // The constant vertices in the graph
|
V3List<DfgVertex*> m_constVertices; // The constant vertices in the graph
|
||||||
@ -559,7 +559,7 @@ public:
|
|||||||
virtual const string srcName(size_t idx) const = 0;
|
virtual const string srcName(size_t idx) const = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
// Specialisations of privateTypeTest
|
// Specializations of privateTypeTest
|
||||||
#include "V3Dfg__gen_type_tests.h" // From ./astgen
|
#include "V3Dfg__gen_type_tests.h" // From ./astgen
|
||||||
|
|
||||||
//------------------------------------------------------------------------------
|
//------------------------------------------------------------------------------
|
||||||
|
@ -291,7 +291,7 @@ class ExtractCyclicComponents final {
|
|||||||
// Assign vertex to the target component
|
// Assign vertex to the target component
|
||||||
vtxState.component = targetComponent;
|
vtxState.component = targetComponent;
|
||||||
|
|
||||||
// Visit all neighbours. We stop at variable boundaries,
|
// Visit all neighbors. We stop at variable boundaries,
|
||||||
// which is where we will split the graphs
|
// which is where we will split the graphs
|
||||||
vtx.forEachSource([=](DfgVertex& other) {
|
vtx.forEachSource([=](DfgVertex& other) {
|
||||||
if (other.is<DfgVertexVar>()) return;
|
if (other.is<DfgVertexVar>()) return;
|
||||||
|
@ -317,7 +317,7 @@ class EmitMkHierVerilation final {
|
|||||||
void emit(V3OutMkFile& of) const {
|
void emit(V3OutMkFile& of) const {
|
||||||
of.puts("# Hierarchical Verilation -*- Makefile -*-\n");
|
of.puts("# Hierarchical Verilation -*- Makefile -*-\n");
|
||||||
of.puts("# DESCR"
|
of.puts("# DESCR"
|
||||||
"IPTION: Verilator output: Makefile for hierarchical verilatrion\n");
|
"IPTION: Verilator output: Makefile for hierarchical Verilation\n");
|
||||||
of.puts("#\n");
|
of.puts("#\n");
|
||||||
of.puts("# The main makefile " + v3Global.opt.prefix() + ".mk calls this makefile\n");
|
of.puts("# The main makefile " + v3Global.opt.prefix() + ".mk calls this makefile\n");
|
||||||
of.puts("\n");
|
of.puts("\n");
|
||||||
|
@ -126,7 +126,7 @@ private:
|
|||||||
bool m_inStringLiteral = false;
|
bool m_inStringLiteral = false;
|
||||||
int m_indentLevel = 0; // Current {} indentation
|
int m_indentLevel = 0; // Current {} indentation
|
||||||
std::stack<int> m_parenVec; // Stack of columns where last ( was
|
std::stack<int> m_parenVec; // Stack of columns where last ( was
|
||||||
int m_bracketLevel = 0; // Intenting = { block, indicates number of {'s seen.
|
int m_bracketLevel = 0; // Indenting = { block, indicates number of {'s seen.
|
||||||
|
|
||||||
int endLevels(const char* strg);
|
int endLevels(const char* strg);
|
||||||
void putcNoTracking(char chr);
|
void putcNoTracking(char chr);
|
||||||
|
@ -593,7 +593,7 @@ void GateVisitor::optimizeSignals(bool allowMultiIn) {
|
|||||||
if (!logicVertexp->reducible()) continue;
|
if (!logicVertexp->reducible()) continue;
|
||||||
AstNode* const logicp = logicVertexp->nodep();
|
AstNode* const logicp = logicVertexp->nodep();
|
||||||
|
|
||||||
// Commit pendingg optimizations to driving logic, as we will re-analyse
|
// Commit pending optimizations to driving logic, as we will re-analyze
|
||||||
commitElimVar(logicp);
|
commitElimVar(logicp);
|
||||||
|
|
||||||
// Can we eliminate?
|
// Can we eliminate?
|
||||||
|
@ -93,7 +93,7 @@ class V3Global final {
|
|||||||
// Globals
|
// Globals
|
||||||
AstNetlist* m_rootp = nullptr; // Root of entire netlist,
|
AstNetlist* m_rootp = nullptr; // Root of entire netlist,
|
||||||
// created by makeInitNetlist(} so static constructors run first
|
// created by makeInitNetlist(} so static constructors run first
|
||||||
V3HierBlockPlan* m_hierPlanp = nullptr; // Hierarchical verilation plan,
|
V3HierBlockPlan* m_hierPlanp = nullptr; // Hierarchical Verilation plan,
|
||||||
// nullptr unless hier_block, set via hierPlanp(V3HierBlockPlan*}
|
// nullptr unless hier_block, set via hierPlanp(V3HierBlockPlan*}
|
||||||
VWidthMinUsage m_widthMinUsage
|
VWidthMinUsage m_widthMinUsage
|
||||||
= VWidthMinUsage::LINT_WIDTH; // What AstNode::widthMin() is used for
|
= VWidthMinUsage::LINT_WIDTH; // What AstNode::widthMin() is used for
|
||||||
|
@ -300,7 +300,7 @@ private:
|
|||||||
}
|
}
|
||||||
|
|
||||||
//------------------------------------------------------------
|
//------------------------------------------------------------
|
||||||
// AstNode direct descendents
|
// AstNode direct descendants
|
||||||
void visit(AstNodeRange* nodep) override {
|
void visit(AstNodeRange* nodep) override {
|
||||||
m_hash += hashNodeAndIterate(nodep, HASH_DTYPE, HASH_CHILDREN, [=]() {});
|
m_hash += hashNodeAndIterate(nodep, HASH_DTYPE, HASH_CHILDREN, [=]() {});
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
// -*- mode: C++; c-file-style: "cc-mode" -*-
|
// -*- mode: C++; c-file-style: "cc-mode" -*-
|
||||||
//*************************************************************************
|
//*************************************************************************
|
||||||
// DESCRIPTION: Verilator: Hierarchical verilation for large designs
|
// DESCRIPTION: Verilator: Hierarchical Verilation for large designs
|
||||||
//
|
//
|
||||||
// Code available from: https://verilator.org
|
// Code available from: https://verilator.org
|
||||||
//
|
//
|
||||||
|
@ -59,7 +59,7 @@ private:
|
|||||||
|
|
||||||
// VISITs
|
// VISITs
|
||||||
// TODO: Most of these visitors are here for historical reasons.
|
// TODO: Most of these visitors are here for historical reasons.
|
||||||
// TODO: ExpectDecriptor can move to data type resolution, and the rest
|
// TODO: ExpectDescriptor can move to data type resolution, and the rest
|
||||||
// TODO: could move to V3LinkParse to get them out of the way of elaboration
|
// TODO: could move to V3LinkParse to get them out of the way of elaboration
|
||||||
void visit(AstNodeModule* nodep) override {
|
void visit(AstNodeModule* nodep) override {
|
||||||
// Module: Create sim table for entire module and iterate
|
// Module: Create sim table for entire module and iterate
|
||||||
|
@ -138,7 +138,7 @@ bool areDisjoint(const std::set<const AstVar*>& a, const std::set<const AstVar*>
|
|||||||
struct StmtProperties {
|
struct StmtProperties {
|
||||||
AstNodeExpr* m_condp = nullptr; // The condition expression, if a conditional node
|
AstNodeExpr* m_condp = nullptr; // The condition expression, if a conditional node
|
||||||
std::set<const AstVar*> m_rdVars; // Variables read by this statement
|
std::set<const AstVar*> m_rdVars; // Variables read by this statement
|
||||||
std::set<const AstVar*> m_wrVars; // Variables writen by this statement
|
std::set<const AstVar*> m_wrVars; // Variables written by this statement
|
||||||
bool m_isFence = false; // Nothing should move across this statement, nor should it be merged
|
bool m_isFence = false; // Nothing should move across this statement, nor should it be merged
|
||||||
AstNodeStmt* m_prevWithSameCondp = nullptr; // Previous node in same list, with same condition
|
AstNodeStmt* m_prevWithSameCondp = nullptr; // Previous node in same list, with same condition
|
||||||
bool writesConditionVar() const {
|
bool writesConditionVar() const {
|
||||||
|
@ -638,7 +638,7 @@ public:
|
|||||||
bool hierTop() const VL_MT_SAFE { return !m_hierChild && !m_hierBlocks.empty(); }
|
bool hierTop() const VL_MT_SAFE { return !m_hierChild && !m_hierBlocks.empty(); }
|
||||||
const V3HierBlockOptSet& hierBlocks() const { return m_hierBlocks; }
|
const V3HierBlockOptSet& hierBlocks() const { return m_hierBlocks; }
|
||||||
// Directory to save .tree, .dot, .dat, .vpp for hierarchical block top
|
// Directory to save .tree, .dot, .dat, .vpp for hierarchical block top
|
||||||
// Returns makeDir() unless top module of hierarchical verilation.
|
// Returns makeDir() unless top module of hierarchical Verilation.
|
||||||
string hierTopDataDir() const VL_MT_SAFE {
|
string hierTopDataDir() const VL_MT_SAFE {
|
||||||
return hierTop() ? (makeDir() + '/' + prefix() + "__hier.dir") : makeDir();
|
return hierTop() ? (makeDir() + '/' + prefix() + "__hier.dir") : makeDir();
|
||||||
}
|
}
|
||||||
|
@ -217,7 +217,7 @@ class OrderBuildVisitor final : public VNVisitor {
|
|||||||
|
|
||||||
m_inClocked = senTreep->hasClocked();
|
m_inClocked = senTreep->hasClocked();
|
||||||
|
|
||||||
// Note: We don't need to analyse the sensitivity list, as currently all sensitivity
|
// Note: We don't need to analyze the sensitivity list, as currently all sensitivity
|
||||||
// lists simply reference an entry in a trigger vector, which are all set external to
|
// lists simply reference an entry in a trigger vector, which are all set external to
|
||||||
// the code being ordered.
|
// the code being ordered.
|
||||||
|
|
||||||
|
@ -27,7 +27,7 @@
|
|||||||
//
|
//
|
||||||
// While this is written as a generic data structure, it's interface and
|
// While this is written as a generic data structure, it's interface and
|
||||||
// implementation is finely tuned for it's use by V3Parm_tition, and is critical
|
// implementation is finely tuned for it's use by V3Parm_tition, and is critical
|
||||||
// to verilaton performance, so be very careful changing anything or adding any
|
// to Verilation performance, so be very careful changing anything or adding any
|
||||||
// new operations that would impact either memory usage, or performance of the
|
// new operations that would impact either memory usage, or performance of the
|
||||||
// existing operations. This data structure is fully deterministic, meaning
|
// existing operations. This data structure is fully deterministic, meaning
|
||||||
// the order in which elements with equal keys are retrieved only depends on
|
// the order in which elements with equal keys are retrieved only depends on
|
||||||
|
@ -79,7 +79,7 @@ class ParameterizedHierBlocks final {
|
|||||||
|
|
||||||
// MEMBERS
|
// MEMBERS
|
||||||
// key:Original module name, value:HiearchyBlockOption*
|
// key:Original module name, value:HiearchyBlockOption*
|
||||||
// If a module is parameterized, the module is uniquiefied to overridden parameters.
|
// If a module is parameterized, the module is uniquified to overridden parameters.
|
||||||
// This is why HierBlockOptsByOrigName is multimap.
|
// This is why HierBlockOptsByOrigName is multimap.
|
||||||
HierBlockOptsByOrigName m_hierBlockOptsByOrigName;
|
HierBlockOptsByOrigName m_hierBlockOptsByOrigName;
|
||||||
// key:mangled module name, value:AstNodeModule*
|
// key:mangled module name, value:AstNodeModule*
|
||||||
@ -442,7 +442,7 @@ class ParamProcessor final {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Check if parameter setting during instantiation is simple enough for hierarchical verilation
|
// Check if parameter setting during instantiation is simple enough for hierarchical Verilation
|
||||||
void checkSupportedParam(AstNodeModule* modp, AstPin* pinp) const {
|
void checkSupportedParam(AstNodeModule* modp, AstPin* pinp) const {
|
||||||
// InitArray and AstParamTypeDType are not supported because that can not be set via -G
|
// InitArray and AstParamTypeDType are not supported because that can not be set via -G
|
||||||
// option.
|
// option.
|
||||||
@ -453,7 +453,7 @@ class ParamProcessor final {
|
|||||||
}
|
}
|
||||||
if (!supported) {
|
if (!supported) {
|
||||||
pinp->v3error(AstNode::prettyNameQ(modp->origName())
|
pinp->v3error(AstNode::prettyNameQ(modp->origName())
|
||||||
<< " has hier_block metacomment, hierarchical verilation"
|
<< " has hier_block metacomment, hierarchical Verilation"
|
||||||
<< " supports only integer/floating point/string parameters");
|
<< " supports only integer/floating point/string parameters");
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -1119,7 +1119,7 @@ public:
|
|||||||
// of a rescore, in case its score has fallen and we need to move it up
|
// of a rescore, in case its score has fallen and we need to move it up
|
||||||
// toward the front of the scoreboard.
|
// toward the front of the scoreboard.
|
||||||
//
|
//
|
||||||
// Wait, whaaat? Shouldn't the scores only increase as we merge nodes? Well
|
// Wait, what? Shouldn't the scores only increase as we merge nodes? Well
|
||||||
// that's almost true. But there is one exception.
|
// that's almost true. But there is one exception.
|
||||||
//
|
//
|
||||||
// Suppose we have A->B, B->C, and A->C.
|
// Suppose we have A->B, B->C, and A->C.
|
||||||
@ -1652,12 +1652,12 @@ private:
|
|||||||
// Need at least 2 edges
|
// Need at least 2 edges
|
||||||
if (!mtaskp->beginp(way) || !mtaskp->beginp(way)->nextp(way)) return;
|
if (!mtaskp->beginp(way) || !mtaskp->beginp(way)->nextp(way)) return;
|
||||||
|
|
||||||
std::array<LogicMTask*, PART_SIBLING_EDGE_LIMIT> neighbours;
|
std::array<LogicMTask*, PART_SIBLING_EDGE_LIMIT> neighbors;
|
||||||
|
|
||||||
// This is a hot method, so we want so sort as efficiently as possible. We pre-load
|
// This is a hot method, so we want so sort as efficiently as possible. We pre-load
|
||||||
// all data (critical path cost and id) required for determining ordering into an aligned
|
// all data (critical path cost and id) required for determining ordering into an aligned
|
||||||
// structure. There is not enough space next to these to keep a whole pointer within 16
|
// structure. There is not enough space next to these to keep a whole pointer within 16
|
||||||
// bytes, so we store an index into the neighbours buffer instead. We can then compare
|
// bytes, so we store an index into the neighbors buffer instead. We can then compare
|
||||||
// and swap these sorting records very efficiently. With this the standard library sorting
|
// and swap these sorting records very efficiently. With this the standard library sorting
|
||||||
// functions are efficient enough and using more optimized methods (e.g.: sorting networks)
|
// functions are efficient enough and using more optimized methods (e.g.: sorting networks)
|
||||||
// has no measurable benefit.
|
// has no measurable benefit.
|
||||||
@ -1666,7 +1666,7 @@ private:
|
|||||||
uint32_t m_cp;
|
uint32_t m_cp;
|
||||||
uint8_t m_idx;
|
uint8_t m_idx;
|
||||||
static_assert(PART_SIBLING_EDGE_LIMIT <= std::numeric_limits<uint8_t>::max(),
|
static_assert(PART_SIBLING_EDGE_LIMIT <= std::numeric_limits<uint8_t>::max(),
|
||||||
"m_idx must fit all indices into 'neighbours'");
|
"m_idx must fit all indices into 'neighbors'");
|
||||||
bool operator<(const SortingRecord& that) const {
|
bool operator<(const SortingRecord& that) const {
|
||||||
return m_cp < that.m_cp || (m_cp == that.m_cp && m_id < that.m_id);
|
return m_cp < that.m_cp || (m_cp == that.m_cp && m_id < that.m_id);
|
||||||
}
|
}
|
||||||
@ -1680,7 +1680,7 @@ private:
|
|||||||
for (V3GraphEdge *edgep = mtaskp->beginp(way), *nextp; edgep; edgep = nextp) {
|
for (V3GraphEdge *edgep = mtaskp->beginp(way), *nextp; edgep; edgep = nextp) {
|
||||||
nextp = edgep->nextp(way); // Fetch next first as likely cache miss
|
nextp = edgep->nextp(way); // Fetch next first as likely cache miss
|
||||||
LogicMTask* const otherp = static_cast<LogicMTask*>(edgep->furtherp(way));
|
LogicMTask* const otherp = static_cast<LogicMTask*>(edgep->furtherp(way));
|
||||||
neighbours[n] = otherp;
|
neighbors[n] = otherp;
|
||||||
sortRecs[n].m_id = otherp->id();
|
sortRecs[n].m_id = otherp->id();
|
||||||
sortRecs[n].m_cp = otherp->critPathCost(way) + otherp->cost();
|
sortRecs[n].m_cp = otherp->critPathCost(way) + otherp->cost();
|
||||||
sortRecs[n].m_idx = n;
|
sortRecs[n].m_idx = n;
|
||||||
@ -1697,13 +1697,13 @@ private:
|
|||||||
const size_t end = n & ~static_cast<size_t>(1); // Round down to even, (we want pairs)
|
const size_t end = n & ~static_cast<size_t>(1); // Round down to even, (we want pairs)
|
||||||
std::sort(sortRecs.begin(), sortRecs.begin() + n);
|
std::sort(sortRecs.begin(), sortRecs.begin() + n);
|
||||||
for (size_t i = 0; i < end; i += 2) {
|
for (size_t i = 0; i < end; i += 2) {
|
||||||
makeSiblingMC(neighbours[sortRecs[i].m_idx], neighbours[sortRecs[i + 1].m_idx]);
|
makeSiblingMC(neighbors[sortRecs[i].m_idx], neighbors[sortRecs[i + 1].m_idx]);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
constexpr size_t end = 2 * MAX_NONEXHAUSTIVE_PAIRS;
|
constexpr size_t end = 2 * MAX_NONEXHAUSTIVE_PAIRS;
|
||||||
std::partial_sort(sortRecs.begin(), sortRecs.begin() + end, sortRecs.begin() + n);
|
std::partial_sort(sortRecs.begin(), sortRecs.begin() + end, sortRecs.begin() + n);
|
||||||
for (size_t i = 0; i < end; i += 2) {
|
for (size_t i = 0; i < end; i += 2) {
|
||||||
makeSiblingMC(neighbours[sortRecs[i].m_idx], neighbours[sortRecs[i + 1].m_idx]);
|
makeSiblingMC(neighbors[sortRecs[i].m_idx], neighbors[sortRecs[i + 1].m_idx]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1907,7 +1907,7 @@ private:
|
|||||||
//
|
//
|
||||||
// ABOUT UNORDERED WRITE-READ PAIRS
|
// ABOUT UNORDERED WRITE-READ PAIRS
|
||||||
//
|
//
|
||||||
// If we don't put unordered write-read pairs into some order at verilation
|
// If we don't put unordered write-read pairs into some order at Verilation
|
||||||
// time, we risk a runtime race.
|
// time, we risk a runtime race.
|
||||||
//
|
//
|
||||||
// How do such unordered writer/reader pairs happen? Here's a partial list
|
// How do such unordered writer/reader pairs happen? Here's a partial list
|
||||||
|
@ -151,7 +151,7 @@ private:
|
|||||||
|
|
||||||
// Timescale
|
// Timescale
|
||||||
if (v3Global.opt.hierChild() && v3Global.rootp()->timescaleSpecified()) {
|
if (v3Global.opt.hierChild() && v3Global.rootp()->timescaleSpecified()) {
|
||||||
// Emit timescale for hierarchical verilation if input HDL specifies timespec
|
// Emit timescale for hierarchical Verilation if input HDL specifies timespec
|
||||||
txtp->addText(fl, std::string{"timeunit "} + modp->timeunit().ascii() + ";\n");
|
txtp->addText(fl, std::string{"timeunit "} + modp->timeunit().ascii() + ";\n");
|
||||||
txtp->addText(fl, std::string{"timeprecision "}
|
txtp->addText(fl, std::string{"timeprecision "}
|
||||||
+ +v3Global.rootp()->timeprecision().ascii() + ";\n");
|
+ +v3Global.rootp()->timeprecision().ascii() + ";\n");
|
||||||
|
@ -258,7 +258,7 @@ class SchedGraphBuilder final : public VNVisitor {
|
|||||||
|
|
||||||
// Default - Any other AstActive content not handled above will hit this
|
// Default - Any other AstActive content not handled above will hit this
|
||||||
void visit(AstNode* nodep) override { //
|
void visit(AstNode* nodep) override { //
|
||||||
nodep->v3fatalSrc("Should behandled above");
|
nodep->v3fatalSrc("Should be handled above");
|
||||||
}
|
}
|
||||||
// LCOV_EXCL_STOP
|
// LCOV_EXCL_STOP
|
||||||
|
|
||||||
@ -361,7 +361,7 @@ LogicRegions partition(LogicByScope& clockedLogic, LogicByScope& combinationalLo
|
|||||||
// Partition the Pre logic
|
// Partition the Pre logic
|
||||||
{
|
{
|
||||||
const VNUser1InUse user1InUse; // AstVarScope::user1() -> bool: read in Active region
|
const VNUser1InUse user1InUse; // AstVarScope::user1() -> bool: read in Active region
|
||||||
const VNUser2InUse user2InUse; // AstVarScope::user2() -> bool: writen in Active region
|
const VNUser2InUse user2InUse; // AstVarScope::user2() -> bool: written in Active region
|
||||||
|
|
||||||
const auto markVars = [](AstNode* nodep) {
|
const auto markVars = [](AstNode* nodep) {
|
||||||
nodep->foreach([](const AstNodeVarRef* vrefp) {
|
nodep->foreach([](const AstNodeVarRef* vrefp) {
|
||||||
|
@ -27,7 +27,7 @@
|
|||||||
// What this pass does looks as below.
|
// What this pass does looks as below.
|
||||||
//
|
//
|
||||||
// // Original
|
// // Original
|
||||||
// logic [1:0] unpcked_array_var[0:1] /*verilator split_var*/;
|
// logic [1:0] unpacked_array_var[0:1] /*verilator split_var*/;
|
||||||
// always_comb begin
|
// always_comb begin
|
||||||
// unpacked_array_var[1][0] = unpacked_array_var[0][0]; // UNOPTFLAT warning
|
// unpacked_array_var[1][0] = unpacked_array_var[0][0]; // UNOPTFLAT warning
|
||||||
// unpacked_array_var[1][1] = ~unpacked_array_var[0][1]; // UNOPTFLAT warning
|
// unpacked_array_var[1][1] = ~unpacked_array_var[0][1]; // UNOPTFLAT warning
|
||||||
@ -45,8 +45,8 @@
|
|||||||
// is initially converted to
|
// is initially converted to
|
||||||
//
|
//
|
||||||
// // Intermediate
|
// // Intermediate
|
||||||
// logic [1:0] unpcked_array_var0 /*verilator split_var*/;
|
// logic [1:0] unpacked_array_var0 /*verilator split_var*/;
|
||||||
// logic [1:0] unpcked_array_var1 /*verilator split_var*/;
|
// logic [1:0] unpacked_array_var1 /*verilator split_var*/;
|
||||||
// always_comb begin
|
// always_comb begin
|
||||||
// unpacked_array_var1[0] = unpacked_array_var0[0];
|
// unpacked_array_var1[0] = unpacked_array_var0[0];
|
||||||
// unpacked_array_var1[1] = ~unpacked_array_var0[1];
|
// unpacked_array_var1[1] = ~unpacked_array_var0[1];
|
||||||
|
@ -65,7 +65,7 @@
|
|||||||
//
|
//
|
||||||
// It is possible to statically resolve all drivers when the strongest assignment has RHS marked as
|
// It is possible to statically resolve all drivers when the strongest assignment has RHS marked as
|
||||||
// non-tristate. If the RHS is equal to z, that assignment has to be skipped. Since the value may
|
// non-tristate. If the RHS is equal to z, that assignment has to be skipped. Since the value may
|
||||||
// be not known at verilation time, cases with tristates on RHS can't be handled statically.
|
// be not known at Verilation time, cases with tristates on RHS can't be handled statically.
|
||||||
//
|
//
|
||||||
// Static resolution is split into 2 parts.
|
// Static resolution is split into 2 parts.
|
||||||
// First part can be done before tristate propagation. It is about removing assignments that are
|
// First part can be done before tristate propagation. It is about removing assignments that are
|
||||||
|
@ -7207,7 +7207,7 @@ AstNode* V3Width::widthParamsEdit(AstNode* nodep) {
|
|||||||
//! later to do the width check.
|
//! later to do the width check.
|
||||||
//! @return Pointer to the edited node.
|
//! @return Pointer to the edited node.
|
||||||
AstNode* V3Width::widthGenerateParamsEdit(
|
AstNode* V3Width::widthGenerateParamsEdit(
|
||||||
AstNode* nodep) { //!< [in] AST whose parameters widths are to be analysed.
|
AstNode* nodep) { //!< [in] AST whose parameters widths are to be analyzed.
|
||||||
UINFO(4, __FUNCTION__ << ": " << nodep << endl);
|
UINFO(4, __FUNCTION__ << ": " << nodep << endl);
|
||||||
// We should do it in bottom-up module order, but it works in any order.
|
// We should do it in bottom-up module order, but it works in any order.
|
||||||
WidthVisitor visitor{true, true};
|
WidthVisitor visitor{true, true};
|
||||||
|
@ -159,7 +159,7 @@ static void process() {
|
|||||||
V3Dead::deadifyModules(v3Global.rootp());
|
V3Dead::deadifyModules(v3Global.rootp());
|
||||||
v3Global.checkTree();
|
v3Global.checkTree();
|
||||||
|
|
||||||
// Create a hierarchical verilation plan
|
// Create a hierarchical Verilation plan
|
||||||
if (!v3Global.opt.lintOnly() && !v3Global.opt.xmlOnly() && v3Global.opt.hierarchical()) {
|
if (!v3Global.opt.lintOnly() && !v3Global.opt.xmlOnly() && v3Global.opt.hierarchical()) {
|
||||||
V3HierBlockPlan::createPlan(v3Global.rootp());
|
V3HierBlockPlan::createPlan(v3Global.rootp());
|
||||||
// If a plan is created, further analysis is not necessary.
|
// If a plan is created, further analysis is not necessary.
|
||||||
|
@ -1560,7 +1560,7 @@ portSig<nodep>:
|
|||||||
// Interface headers
|
// Interface headers
|
||||||
|
|
||||||
interface_declaration: // IEEE: interface_declaration + interface_nonansi_header + interface_ansi_header:
|
interface_declaration: // IEEE: interface_declaration + interface_nonansi_header + interface_ansi_header:
|
||||||
// // timeunits_delcarationE is instead in interface_item
|
// // timeunits_declarationE is instead in interface_item
|
||||||
intFront importsAndParametersE portsStarE ';'
|
intFront importsAndParametersE portsStarE ';'
|
||||||
interface_itemListE yENDINTERFACE endLabelE
|
interface_itemListE yENDINTERFACE endLabelE
|
||||||
{ if ($2) $1->addStmtsp($2);
|
{ if ($2) $1->addStmtsp($2);
|
||||||
@ -1648,7 +1648,7 @@ anonymous_program_item<nodep>: // ==IEEE: anonymous_program_item
|
|||||||
;
|
;
|
||||||
|
|
||||||
program_declaration: // IEEE: program_declaration + program_nonansi_header + program_ansi_header:
|
program_declaration: // IEEE: program_declaration + program_nonansi_header + program_ansi_header:
|
||||||
// // timeunits_delcarationE is instead in program_item
|
// // timeunits_declarationE is instead in program_item
|
||||||
pgmFront parameter_port_listE portsStarE ';'
|
pgmFront parameter_port_listE portsStarE ';'
|
||||||
/*cont*/ program_itemListE yENDPROGRAM endLabelE
|
/*cont*/ program_itemListE yENDPROGRAM endLabelE
|
||||||
{ $1->modTrace(GRAMMARP->allTracingOn($1->fileline())); // Stash for implicit wires, etc
|
{ $1->modTrace(GRAMMARP->allTracingOn($1->fileline())); // Stash for implicit wires, etc
|
||||||
@ -4029,7 +4029,7 @@ system_f_call<nodeExprp>: // IEEE: system_tf_call (as func)
|
|||||||
| system_f_call_or_t { $$ = $1; }
|
| system_f_call_or_t { $$ = $1; }
|
||||||
;
|
;
|
||||||
|
|
||||||
systemDpiArgsE<argp>: // IEEE: part of system_if_call for aruments of $dpi call
|
systemDpiArgsE<argp>: // IEEE: part of system_if_call for arguments of $dpi call
|
||||||
parenE { $$ = nullptr; }
|
parenE { $$ = nullptr; }
|
||||||
| '(' exprList ')' { $$ = GRAMMARP->argWrapList($2); }
|
| '(' exprList ')' { $$ = GRAMMARP->argWrapList($2); }
|
||||||
;
|
;
|
||||||
|
@ -17,7 +17,7 @@ if ($ENV{VERILATOR_TEST_NO_ATTRIBUTES}) {
|
|||||||
}
|
}
|
||||||
sub check {
|
sub check {
|
||||||
my $root = "..";
|
my $root = "..";
|
||||||
# some of the files are only used in verilation
|
# some of the files are only used in Verilation
|
||||||
# and are only in "include" folder
|
# and are only in "include" folder
|
||||||
my @srcfiles = glob("$root/include/*.cpp");
|
my @srcfiles = glob("$root/include/*.cpp");
|
||||||
my $srcfiles_str = join(" ", @srcfiles);
|
my $srcfiles_str = join(" ", @srcfiles);
|
||||||
|
@ -17,7 +17,7 @@ if ($ENV{VERILATOR_TEST_NO_ATTRIBUTES}) {
|
|||||||
}
|
}
|
||||||
sub check {
|
sub check {
|
||||||
my $root = "..";
|
my $root = "..";
|
||||||
# some of the files are only used in verilation
|
# some of the files are only used in Verilation
|
||||||
# and are only in "include" folder
|
# and are only in "include" folder
|
||||||
my @srcfiles = grep { !/\/(V3Const|Vlc\w*|\w*_test|\w*_sc|\w*.yy).cpp$/ }
|
my @srcfiles = grep { !/\/(V3Const|Vlc\w*|\w*_test|\w*_sc|\w*.yy).cpp$/ }
|
||||||
glob("$root/src/*.cpp $root/src/obj_opt/V3Const__gen.cpp");
|
glob("$root/src/*.cpp $root/src/obj_opt/V3Const__gen.cpp");
|
||||||
|
@ -10,7 +10,7 @@ if (!$::Driver) { use FindBin; exec("$FindBin::Bin/bootstrap.pl", @ARGV, $0); di
|
|||||||
|
|
||||||
scenarios(vlt => 1);
|
scenarios(vlt => 1);
|
||||||
|
|
||||||
# test case was causing use-after-free and segfaulting during verilation
|
# test case was causing use-after-free and segfaulting during Verilation
|
||||||
compile();
|
compile();
|
||||||
|
|
||||||
ok(1);
|
ok(1);
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
// DESCRIPTION: Verilator: Verilog Test module for issue #3817
|
// DESCRIPTION: Verilator: Verilog Test module for issue #3817
|
||||||
// addDriver() was causing use-after-free and segfaulting during verilation
|
// addDriver() was causing use-after-free and segfaulting during Verilation
|
||||||
//
|
//
|
||||||
// This file ONLY is placed under the Creative Commons Public Domain, for
|
// This file ONLY is placed under the Creative Commons Public Domain, for
|
||||||
// any use, without warranty, 2022 by Jevin Sweval.
|
// any use, without warranty, 2022 by Jevin Sweval.
|
||||||
|
@ -23,7 +23,7 @@ foreach my $dotname ("linkcells", "task_call", "gate_simp", "gate_opt",
|
|||||||
"ordermv_initial", "ordermv_hazards", "ordermv_contraction",
|
"ordermv_initial", "ordermv_hazards", "ordermv_contraction",
|
||||||
"ordermv_transitive1", "orderg_done", "ordermv_transitive2", "schedule") {
|
"ordermv_transitive1", "orderg_done", "ordermv_transitive2", "schedule") {
|
||||||
# Some files with identical prefix are generated multiple times during
|
# Some files with identical prefix are generated multiple times during
|
||||||
# verilation. Ensure that at least one of each $dotname-prefixed file is generated.
|
# Verilation. Ensure that at least one of each $dotname-prefixed file is generated.
|
||||||
@dotFiles = glob("$Self->{obj_dir}/*$dotname.dot");
|
@dotFiles = glob("$Self->{obj_dir}/*$dotname.dot");
|
||||||
if (scalar @dotFiles == 0) {
|
if (scalar @dotFiles == 0) {
|
||||||
error("Found no dotfiles with pattern *$dotname.dot");
|
error("Found no dotfiles with pattern *$dotname.dot");
|
||||||
|
@ -23,7 +23,7 @@ compile( # Don't call cmake nor gmake from driver.pl. Nothing should be done he
|
|||||||
'../' . $Self->{main_filename}]
|
'../' . $Self->{main_filename}]
|
||||||
);
|
);
|
||||||
|
|
||||||
# --no-verilate should skip verilation
|
# --no-verilate should skip Verilation
|
||||||
if ( -e $Self->{obj_dir} . '/Vt_flag_verilate.mk' ) {
|
if ( -e $Self->{obj_dir} . '/Vt_flag_verilate.mk' ) {
|
||||||
$Self->error('Vt_flag_verilate.mk is unexpectedly created');
|
$Self->error('Vt_flag_verilate.mk is unexpectedly created');
|
||||||
}
|
}
|
||||||
@ -41,7 +41,7 @@ if ( ! -e $Self->{obj_dir} . '/Vt_flag_verilate.mk' ) {
|
|||||||
$Self->error('Vt_flag_verilate.mk does not exist');
|
$Self->error('Vt_flag_verilate.mk does not exist');
|
||||||
}
|
}
|
||||||
|
|
||||||
# Just build, no verilation. .tree must not be saved even with --dump-tree option.
|
# Just build, no Verilation. .tree must not be saved even with --dump-tree option.
|
||||||
compile( # Don't call cmake nor gmake from driver.pl. Just build here
|
compile( # Don't call cmake nor gmake from driver.pl. Just build here
|
||||||
verilator_make_cmake => 0,
|
verilator_make_cmake => 0,
|
||||||
verilator_make_gmake => 0,
|
verilator_make_gmake => 0,
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
%Error: t/t_hier_block0_bad.v:20:11: 'sub0' has hier_block metacomment, hierarchical verilation supports only integer/floating point/string parameters
|
%Error: t/t_hier_block0_bad.v:20:11: 'sub0' has hier_block metacomment, hierarchical Verilation supports only integer/floating point/string parameters
|
||||||
: ... In instance t
|
: ... In instance t
|
||||||
20 | sub0 #(UNPACKED) i_sub0(.clk(clk), .in(8'(count)), .out(out0));
|
20 | sub0 #(UNPACKED) i_sub0(.clk(clk), .in(8'(count)), .out(out0));
|
||||||
| ^~~~~~~~
|
| ^~~~~~~~
|
||||||
|
@ -14,7 +14,7 @@ double sc_time_stamp() { return 0; }
|
|||||||
void compare_signals(const sc_signal<sc_bv<256>>& ls, const sc_signal<sc_bv<256>>& rs) {
|
void compare_signals(const sc_signal<sc_bv<256>>& ls, const sc_signal<sc_bv<256>>& rs) {
|
||||||
if (ls.read() != rs.read()) {
|
if (ls.read() != rs.read()) {
|
||||||
pass &= false;
|
pass &= false;
|
||||||
VL_PRINTF("%%Error: Data missmatch in signals %s and %s\n", ls.name(), rs.name());
|
VL_PRINTF("%%Error: Data mismatch in signals %s and %s\n", ls.name(), rs.name());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user