mirror of
https://github.com/verilator/verilator.git
synced 2025-01-01 04:07:34 +00:00
Add method to check if there are VPI callbacks of the given type (#5399)
This commit is contained in:
parent
155dcc5658
commit
e04ef5d83a
@ -896,6 +896,9 @@ public:
|
|||||||
if (VL_LIKELY(it != s().m_futureCbs.cend())) return it->first.first;
|
if (VL_LIKELY(it != s().m_futureCbs.cend())) return it->first.first;
|
||||||
return ~0ULL; // maxquad
|
return ~0ULL; // maxquad
|
||||||
}
|
}
|
||||||
|
static bool hasCbs(const uint32_t reason) VL_MT_UNSAFE_ONE {
|
||||||
|
return !s().m_cbCurrentLists[reason].empty();
|
||||||
|
}
|
||||||
static bool callCbs(const uint32_t reason) VL_MT_UNSAFE_ONE {
|
static bool callCbs(const uint32_t reason) VL_MT_UNSAFE_ONE {
|
||||||
VL_DEBUG_IF_PLI(VL_DBG_MSGF("- vpi: callCbs reason=%u\n", reason););
|
VL_DEBUG_IF_PLI(VL_DBG_MSGF("- vpi: callCbs reason=%u\n", reason););
|
||||||
assertOneCheck();
|
assertOneCheck();
|
||||||
@ -1056,6 +1059,10 @@ bool VerilatedVpi::callCbs(uint32_t reason) VL_MT_UNSAFE_ONE {
|
|||||||
return VerilatedVpiImp::callCbs(reason);
|
return VerilatedVpiImp::callCbs(reason);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool VerilatedVpi::hasCbs(uint32_t reason) VL_MT_UNSAFE_ONE {
|
||||||
|
return VerilatedVpiImp::hasCbs(reason);
|
||||||
|
}
|
||||||
|
|
||||||
// Historical, before we had multiple kinds of timed callbacks
|
// Historical, before we had multiple kinds of timed callbacks
|
||||||
void VerilatedVpi::callTimedCbs() VL_MT_UNSAFE_ONE { VerilatedVpiImp::callCbs(cbAfterDelay); }
|
void VerilatedVpi::callTimedCbs() VL_MT_UNSAFE_ONE { VerilatedVpiImp::callCbs(cbAfterDelay); }
|
||||||
|
|
||||||
|
@ -49,6 +49,9 @@ public:
|
|||||||
/// Call callbacks of arbitrary types.
|
/// Call callbacks of arbitrary types.
|
||||||
/// User wrapper code should call this from their main loops.
|
/// User wrapper code should call this from their main loops.
|
||||||
static bool callCbs(uint32_t reason) VL_MT_UNSAFE_ONE;
|
static bool callCbs(uint32_t reason) VL_MT_UNSAFE_ONE;
|
||||||
|
/// Returns true if there are callbacks of the given reason registered.
|
||||||
|
/// User wrapper code should call this from their main loops.
|
||||||
|
static bool hasCbs(uint32_t reason) VL_MT_UNSAFE_ONE;
|
||||||
/// Returns time of the next registered VPI callback, or
|
/// Returns time of the next registered VPI callback, or
|
||||||
/// ~(0ULL) if none are registered
|
/// ~(0ULL) if none are registered
|
||||||
static QData cbNextDeadline() VL_MT_UNSAFE_ONE;
|
static QData cbNextDeadline() VL_MT_UNSAFE_ONE;
|
||||||
|
@ -107,32 +107,22 @@ int main(int argc, char** argv) {
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
while (!contextp->gotFinish()) {
|
while (!contextp->gotFinish()) {
|
||||||
// Call registered timed callbacks (e.g. clock timer)
|
do {
|
||||||
// These are called at the beginning of the time step
|
// We must evaluate whole design until we process all 'events' for
|
||||||
// before the iterative regions (IEEE 1800-2012 4.4.1)
|
// this time step
|
||||||
VerilatedVpi::callTimedCbs();
|
do {
|
||||||
|
top->eval_step();
|
||||||
|
VerilatedVpi::clearEvalNeeded();
|
||||||
|
VerilatedVpi::doInertialPuts();
|
||||||
|
settle_value_callbacks();
|
||||||
|
} while (VerilatedVpi::evalNeeded());
|
||||||
|
|
||||||
// Call Value Change callbacks triggered by Timer callbacks
|
// Run ReadWrite callback as we are done processing this eval step
|
||||||
// These can modify signal values
|
VerilatedVpi::callCbs(cbReadWriteSynch);
|
||||||
settle_value_callbacks();
|
VerilatedVpi::doInertialPuts();
|
||||||
|
settle_value_callbacks();
|
||||||
|
} while (VerilatedVpi::evalNeeded() || VerilatedVpi::hasCbs(cbReadWriteSynch));
|
||||||
|
|
||||||
// We must evaluate whole design until we process all 'events'
|
|
||||||
bool again = true;
|
|
||||||
while (again) {
|
|
||||||
// Evaluate design
|
|
||||||
top->eval_step();
|
|
||||||
|
|
||||||
// Call Value Change callbacks triggered by eval()
|
|
||||||
// These can modify signal values
|
|
||||||
again = settle_value_callbacks();
|
|
||||||
|
|
||||||
// Call registered ReadWrite callbacks
|
|
||||||
again |= VerilatedVpi::callCbs(cbReadWriteSynch);
|
|
||||||
|
|
||||||
// Call Value Change callbacks triggered by ReadWrite callbacks
|
|
||||||
// These can modify signal values
|
|
||||||
again |= settle_value_callbacks();
|
|
||||||
}
|
|
||||||
top->eval_end_step();
|
top->eval_end_step();
|
||||||
|
|
||||||
// Call ReadOnly callbacks
|
// Call ReadOnly callbacks
|
||||||
@ -161,9 +151,12 @@ int main(int argc, char** argv) {
|
|||||||
// It should be called in simulation cycle before everything else
|
// It should be called in simulation cycle before everything else
|
||||||
// but not on first cycle
|
// but not on first cycle
|
||||||
VerilatedVpi::callCbs(cbNextSimTime);
|
VerilatedVpi::callCbs(cbNextSimTime);
|
||||||
|
settle_value_callbacks();
|
||||||
|
|
||||||
// Call Value Change callbacks triggered by NextTimeStep callbacks
|
// Call registered timed callbacks (e.g. clock timer)
|
||||||
// These can modify signal values
|
// These are called at the beginning of the time step
|
||||||
|
// before the iterative regions (IEEE 1800-2012 4.4.1)
|
||||||
|
VerilatedVpi::callTimedCbs();
|
||||||
settle_value_callbacks();
|
settle_value_callbacks();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user