fpga/flash/obj_dir/Vtop.cpp
2026-02-03 14:26:16 +01:00

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());
}