// Verilated -*- C++ -*- // DESCRIPTION: Verilator output: Model implementation (design independent parts) #include "Vwave__pch.h" #include "verilated_vcd_c.h" //============================================================ // Constructors Vwave::Vwave(VerilatedContext* _vcontextp__, const char* _vcname__) : VerilatedModel{*_vcontextp__} , vlSymsp{new Vwave__Syms(contextp(), _vcname__, this)} , i_clk{vlSymsp->TOP.i_clk} , o_led{vlSymsp->TOP.o_led} , rootp{&(vlSymsp->TOP)} { // Register model with the context contextp()->addModel(this); contextp()->traceBaseModelCbAdd( [this](VerilatedTraceBaseC* tfp, int levels, int options) { traceBaseModel(tfp, levels, options); }); } Vwave::Vwave(const char* _vcname__) : Vwave(Verilated::threadContextp(), _vcname__) { } //============================================================ // Destructor Vwave::~Vwave() { delete vlSymsp; } //============================================================ // Evaluation function #ifdef VL_DEBUG void Vwave___024root___eval_debug_assertions(Vwave___024root* vlSelf); #endif // VL_DEBUG void Vwave___024root___eval_static(Vwave___024root* vlSelf); void Vwave___024root___eval_initial(Vwave___024root* vlSelf); void Vwave___024root___eval_settle(Vwave___024root* vlSelf); void Vwave___024root___eval(Vwave___024root* vlSelf); void Vwave::eval_step() { VL_DEBUG_IF(VL_DBG_MSGF("+++++TOP Evaluate Vwave::eval_step\n"); ); #ifdef VL_DEBUG // Debug assertions Vwave___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");); Vwave___024root___eval_static(&(vlSymsp->TOP)); Vwave___024root___eval_initial(&(vlSymsp->TOP)); Vwave___024root___eval_settle(&(vlSymsp->TOP)); } VL_DEBUG_IF(VL_DBG_MSGF("+ Eval\n");); Vwave___024root___eval(&(vlSymsp->TOP)); // Evaluate cleanup Verilated::endOfEval(vlSymsp->__Vm_evalMsgQp); } //============================================================ // Events and timing bool Vwave::eventsPending() { return false; } uint64_t Vwave::nextTimeSlot() { VL_FATAL_MT(__FILE__, __LINE__, "", "%Error: No delays in the design"); return 0; } //============================================================ // Utilities const char* Vwave::name() const { return vlSymsp->name(); } //============================================================ // Invoke final blocks void Vwave___024root___eval_final(Vwave___024root* vlSelf); VL_ATTR_COLD void Vwave::final() { Vwave___024root___eval_final(&(vlSymsp->TOP)); } //============================================================ // Implementations of abstract methods from VerilatedModel const char* Vwave::hierName() const { return vlSymsp->name(); } const char* Vwave::modelName() const { return "Vwave"; } unsigned Vwave::threads() const { return 1; } void Vwave::prepareClone() const { contextp()->prepareClone(); } void Vwave::atClone() const { contextp()->threadPoolpOnClone(); } std::unique_ptr Vwave::traceConfig() const { return std::unique_ptr{new VerilatedTraceConfig{false, false, false}}; }; //============================================================ // Trace configuration void Vwave___024root__trace_decl_types(VerilatedVcd* tracep); void Vwave___024root__trace_init_top(Vwave___024root* vlSelf, VerilatedVcd* tracep); VL_ATTR_COLD static void trace_init(void* voidSelf, VerilatedVcd* tracep, uint32_t code) { // Callback from tracep->open() Vwave___024root* const __restrict vlSelf VL_ATTR_UNUSED = static_cast(voidSelf); Vwave__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); Vwave___024root__trace_decl_types(tracep); Vwave___024root__trace_init_top(vlSelf, tracep); tracep->popPrefix(); } VL_ATTR_COLD void Vwave___024root__trace_register(Vwave___024root* vlSelf, VerilatedVcd* tracep); VL_ATTR_COLD void Vwave::traceBaseModel(VerilatedTraceBaseC* tfp, int levels, int options) { (void)levels; (void)options; VerilatedVcdC* const stfp = dynamic_cast(tfp); if (VL_UNLIKELY(!stfp)) { vl_fatal(__FILE__, __LINE__, __FILE__,"'Vwave::trace()' called on non-VerilatedVcdC object;" " use --trace-fst with VerilatedFst object, and --trace with VerilatedVcd object"); } stfp->spTrace()->addModel(this); stfp->spTrace()->addInitCb(&trace_init, &(vlSymsp->TOP)); Vwave___024root__trace_register(&(vlSymsp->TOP), stfp->spTrace()); }