149 lines
5.2 KiB
C++
149 lines
5.2 KiB
C++
// Verilated -*- C++ -*-
|
|
// DESCRIPTION: Verilator output: Model implementation (design independent parts)
|
|
|
|
#include "Vtop__pch.h"
|
|
#include "verilated_vcd_c.h"
|
|
|
|
//============================================================
|
|
// Constructors
|
|
|
|
Vtop::Vtop(VerilatedContext* _vcontextp__, const char* _vcname__)
|
|
: VerilatedModel{*_vcontextp__}
|
|
, vlSymsp{new Vtop__Syms(contextp(), _vcname__, this)}
|
|
, led{vlSymsp->TOP.led}
|
|
, tmosi{vlSymsp->TOP.tmosi}
|
|
, tcs{vlSymsp->TOP.tcs}
|
|
, tsclk{vlSymsp->TOP.tsclk}
|
|
, sys_rst_n{vlSymsp->TOP.sys_rst_n}
|
|
, miso{vlSymsp->TOP.miso}
|
|
, cs{vlSymsp->TOP.cs}
|
|
, mosi{vlSymsp->TOP.mosi}
|
|
, sclk{vlSymsp->TOP.sclk}
|
|
, sysclk{vlSymsp->TOP.sysclk}
|
|
, tmiso{vlSymsp->TOP.tmiso}
|
|
, rootp{&(vlSymsp->TOP)}
|
|
{
|
|
// Register model with the context
|
|
contextp()->addModel(this);
|
|
contextp()->traceBaseModelCbAdd(
|
|
[this](VerilatedTraceBaseC* tfp, int levels, int options) { traceBaseModel(tfp, levels, options); });
|
|
}
|
|
|
|
Vtop::Vtop(const char* _vcname__)
|
|
: Vtop(Verilated::threadContextp(), _vcname__)
|
|
{
|
|
}
|
|
|
|
//============================================================
|
|
// Destructor
|
|
|
|
Vtop::~Vtop() {
|
|
delete vlSymsp;
|
|
}
|
|
|
|
//============================================================
|
|
// Evaluation function
|
|
|
|
#ifdef VL_DEBUG
|
|
void Vtop___024root___eval_debug_assertions(Vtop___024root* vlSelf);
|
|
#endif // VL_DEBUG
|
|
void Vtop___024root___eval_static(Vtop___024root* vlSelf);
|
|
void Vtop___024root___eval_initial(Vtop___024root* vlSelf);
|
|
void Vtop___024root___eval_settle(Vtop___024root* vlSelf);
|
|
void Vtop___024root___eval(Vtop___024root* vlSelf);
|
|
|
|
void Vtop::eval_step() {
|
|
VL_DEBUG_IF(VL_DBG_MSGF("+++++TOP Evaluate Vtop::eval_step\n"); );
|
|
#ifdef VL_DEBUG
|
|
// Debug assertions
|
|
Vtop___024root___eval_debug_assertions(&(vlSymsp->TOP));
|
|
#endif // VL_DEBUG
|
|
vlSymsp->__Vm_activity = true;
|
|
vlSymsp->__Vm_deleter.deleteAll();
|
|
if (VL_UNLIKELY(!vlSymsp->__Vm_didInit)) {
|
|
vlSymsp->__Vm_didInit = true;
|
|
VL_DEBUG_IF(VL_DBG_MSGF("+ Initial\n"););
|
|
Vtop___024root___eval_static(&(vlSymsp->TOP));
|
|
Vtop___024root___eval_initial(&(vlSymsp->TOP));
|
|
Vtop___024root___eval_settle(&(vlSymsp->TOP));
|
|
}
|
|
VL_DEBUG_IF(VL_DBG_MSGF("+ Eval\n"););
|
|
Vtop___024root___eval(&(vlSymsp->TOP));
|
|
// Evaluate cleanup
|
|
Verilated::endOfEval(vlSymsp->__Vm_evalMsgQp);
|
|
}
|
|
|
|
//============================================================
|
|
// Events and timing
|
|
bool Vtop::eventsPending() { return false; }
|
|
|
|
uint64_t Vtop::nextTimeSlot() {
|
|
VL_FATAL_MT(__FILE__, __LINE__, "", "No delays in the design");
|
|
return 0;
|
|
}
|
|
|
|
//============================================================
|
|
// Utilities
|
|
|
|
const char* Vtop::name() const {
|
|
return vlSymsp->name();
|
|
}
|
|
|
|
//============================================================
|
|
// Invoke final blocks
|
|
|
|
void Vtop___024root___eval_final(Vtop___024root* vlSelf);
|
|
|
|
VL_ATTR_COLD void Vtop::final() {
|
|
Vtop___024root___eval_final(&(vlSymsp->TOP));
|
|
}
|
|
|
|
//============================================================
|
|
// Implementations of abstract methods from VerilatedModel
|
|
|
|
const char* Vtop::hierName() const { return vlSymsp->name(); }
|
|
const char* Vtop::modelName() const { return "Vtop"; }
|
|
unsigned Vtop::threads() const { return 10; }
|
|
void Vtop::prepareClone() const { contextp()->prepareClone(); }
|
|
void Vtop::atClone() const {
|
|
vlSymsp->__Vm_threadPoolp = static_cast<VlThreadPool*>(contextp()->threadPoolpOnClone());
|
|
}
|
|
std::unique_ptr<VerilatedTraceConfig> Vtop::traceConfig() const {
|
|
return std::unique_ptr<VerilatedTraceConfig>{new VerilatedTraceConfig{true, false, false}};
|
|
};
|
|
|
|
//============================================================
|
|
// Trace configuration
|
|
|
|
void Vtop___024root__trace_decl_types(VerilatedVcd* tracep);
|
|
|
|
void Vtop___024root__trace_init_top(Vtop___024root* vlSelf, VerilatedVcd* tracep);
|
|
|
|
VL_ATTR_COLD static void trace_init(void* voidSelf, VerilatedVcd* tracep, uint32_t code) {
|
|
// Callback from tracep->open()
|
|
Vtop___024root* const __restrict vlSelf VL_ATTR_UNUSED = static_cast<Vtop___024root*>(voidSelf);
|
|
Vtop__Syms* const __restrict vlSymsp VL_ATTR_UNUSED = vlSelf->vlSymsp;
|
|
if (!vlSymsp->_vm_contextp__->calcUnusedSigs()) {
|
|
VL_FATAL_MT(__FILE__, __LINE__, __FILE__,
|
|
"Turning on wave traces requires Verilated::traceEverOn(true) call before time 0.");
|
|
}
|
|
vlSymsp->__Vm_baseCode = code;
|
|
tracep->pushPrefix(std::string{vlSymsp->name()}, VerilatedTracePrefixType::SCOPE_MODULE);
|
|
Vtop___024root__trace_decl_types(tracep);
|
|
Vtop___024root__trace_init_top(vlSelf, tracep);
|
|
tracep->popPrefix();
|
|
}
|
|
|
|
VL_ATTR_COLD void Vtop___024root__trace_register(Vtop___024root* vlSelf, VerilatedVcd* tracep);
|
|
|
|
VL_ATTR_COLD void Vtop::traceBaseModel(VerilatedTraceBaseC* tfp, int levels, int options) {
|
|
(void)levels; (void)options;
|
|
VerilatedVcdC* const stfp = dynamic_cast<VerilatedVcdC*>(tfp);
|
|
if (VL_UNLIKELY(!stfp)) {
|
|
vl_fatal(__FILE__, __LINE__, __FILE__,"'Vtop::trace()' called on non-VerilatedVcdC object;"
|
|
" use --trace-fst with VerilatedFst object, and --trace-vcd with VerilatedVcd object");
|
|
}
|
|
stfp->spTrace()->addModel(this);
|
|
stfp->spTrace()->addInitCb(&trace_init, &(vlSymsp->TOP));
|
|
Vtop___024root__trace_register(&(vlSymsp->TOP), stfp->spTrace());
|
|
}
|