Skip to content

Commit

Permalink
Improve initialization of the examples
Browse files Browse the repository at this point in the history
  • Loading branch information
JanOlencki committed Jan 21, 2025
1 parent f9b4139 commit a2969e4
Show file tree
Hide file tree
Showing 8 changed files with 133 additions and 50 deletions.
26 changes: 21 additions & 5 deletions samples/apb3uart/sim_main.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -34,15 +34,23 @@ void eval() {
uart->eval();
}

RenodeAgent *Init() {
UART* initAgent() {
const int murax_rxtx_reg = 0x0;
static UART uart_obj = UART(&uart_ctrl->io_uart_txd, &uart_ctrl->io_uart_rxd, prescaler, murax_rxtx_reg, &uart_ctrl->io_interrupt);

// These need static lifetime because we assign them to global pointers.
// By having the initialization here we guarantee that any static initialization
// from other compilation units (e. g. Verilator) is already done.
static VerilatedContext context;
static VApb3UartCtrl uart_ctrl_obj(&context);

uart_ctrl = &uart_ctrl_obj;
uart = &uart_obj;
return uart;
}

void initBus(RenodeAgent *agent)
{
APB3* bus = new APB3();

//=================================================
Expand All @@ -66,9 +74,13 @@ RenodeAgent *Init() {
//=================================================
// Init peripheral
//=================================================
const int murax_rxtx_reg = 0x0;
static UART uart_obj = UART(bus, &uart_ctrl->io_uart_txd, &uart_ctrl->io_uart_rxd, prescaler, murax_rxtx_reg, &uart_ctrl->io_interrupt);
uart = &uart_obj;
agent->addBus(bus);
}

RenodeAgent* Init() {
uart = initAgent();
uart->connectNative();
initBus(uart);
return uart;
}

Expand All @@ -87,7 +99,11 @@ int main(int argc, char **argv, char **env) {
uart_ctrl->trace(tfp, 99);
tfp->open("simx.fst");
#endif
uart->simulate(atoi(argv[1]), atoi(argv[2]), address);

uart = initAgent();
uart->connect(atoi(argv[1]), atoi(argv[2]), address);
initBus(uart);
uart->simulate();
uart_ctrl->final();

#if VM_TRACE
Expand Down
20 changes: 16 additions & 4 deletions samples/cpu_ibex/sim_main.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -24,14 +24,19 @@ void evaluateModel()
ibex->evaluateModel();
}

RenodeAgent *Init()
CpuAgent* initAgent()
{
Verilated::commandArgs(0, (const char **)nullptr);
CpuAgent* agent = new CpuAgent();
return agent;
}

void initBus(CpuAgent* agent)
{
WishboneInitiator<uint32_t, uint32_t> *instructionFetchBus = new WishboneInitiator<uint32_t, uint32_t>();
WishboneInitiator<uint32_t, uint32_t> *loadStoreBus = new WishboneInitiator<uint32_t, uint32_t>();

agent = new CpuAgent(instructionFetchBus);
agent->addBus(instructionFetchBus);
agent->addBus(loadStoreBus);

ibex = new Ibex();
Expand All @@ -43,7 +48,12 @@ RenodeAgent *Init()

instructionFetchBus->evaluateModel = evaluateModel;
loadStoreBus->evaluateModel = evaluateModel;
}

RenodeAgent* Init() {
agent = initAgent();
agent->connectNative();
initBus(agent);
return agent;
}

Expand All @@ -56,8 +66,10 @@ int main(int argc, char **argv, char **env)
}
const char *address = argc < 4 ? "127.0.0.1" : argv[3];

Init();
agent->simulate(atoi(argv[1]), atoi(argv[2]), address);
agent = initAgent();
agent->connect(atoi(argv[1]), atoi(argv[2]), address);
initBus(agent);
agent->simulate();

return 0;
}
Expand Down
25 changes: 16 additions & 9 deletions samples/fastvdma/sim_main.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@
#include "src/buses/axilite.h"
#include "src/renode_bus.h"

RenodeAgent *fastvdma;
RenodeAgent *fastvdma = new RenodeAgent;
VDMATop *top = new VDMATop;
VerilatedVcdC *tfp;
vluint64_t main_time = 0;
Expand All @@ -34,7 +34,8 @@ void eval() {
fastvdma->handleInterrupts();
}

RenodeAgent *Init() {
void initAgent(RenodeAgent *agent)
{
AxiLite* bus = new AxiLite();
AxiSlave* slaveBus = new AxiSlave(32, 32);

Expand Down Expand Up @@ -121,13 +122,16 @@ RenodeAgent *Init() {
//=================================================
// Init peripheral
//=================================================
fastvdma = new RenodeAgent(bus);
fastvdma->addBus(slaveBus);
agent->addBus(bus);
agent->addBus(slaveBus);

fastvdma->registerInterrupt(&top->io_irq_writerDone, 0);
fastvdma->registerInterrupt(&top->io_irq_readerDone, 0);
agent->registerInterrupt(&top->io_irq_writerDone, 0);
agent->registerInterrupt(&top->io_irq_readerDone, 0);
}

slaveBus->setAgent(fastvdma);
RenodeAgent* Init() {
fastvdma->connectNative();
initAgent(fastvdma);
return fastvdma;
}

Expand All @@ -145,9 +149,12 @@ int main(int argc, char **argv, char **env) {
top->trace(tfp, 99);
tfp->open("simx.vcd");
#endif
Init();

fastvdma->connect(atoi(argv[1]), atoi(argv[2]), address);
initAgent(fastvdma);
fastvdma->simulate();
fastvdma->reset();
fastvdma->simulate(atoi(argv[1]), atoi(argv[2]), address);

top->final();
exit(0);
}
20 changes: 11 additions & 9 deletions samples/fpga_isp/sim_main.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@
#include "src/buses/axi.h"
#include "src/renode_bus.h"

RenodeAgent *isp;
RenodeAgent *isp = new RenodeAgent;
Vfpga_isp *top = new Vfpga_isp;
vluint64_t main_time = 0;

Expand All @@ -43,7 +43,7 @@ void eval() {
isp->handleInterrupts();
}

RenodeAgent *Init() {
void initAgent(RenodeAgent *agent) {
AxiSlave* slaveBus = new AxiSlave(32, 32);
Axi* axi = new Axi(32, 32);

Expand Down Expand Up @@ -152,11 +152,8 @@ RenodeAgent *Init() {
//=================================================
// Init peripheral
//=================================================
isp = new RenodeAgent(axi);
isp->addBus(slaveBus);

slaveBus->setAgent(isp);
axi->setAgent(isp);
agent->addBus(axi);
agent->addBus(slaveBus);

isp->registerInterrupt(&top->irq_dmaIn, 0);
isp->registerInterrupt(&top->irq_dmaOut, 1);
Expand All @@ -167,7 +164,11 @@ RenodeAgent *Init() {
top->trace(tfp, 99);
tfp->open(DEF_TRACE_FILEPATH);
#endif
}

RenodeAgent* Init() {
isp->connectNative();
initAgent(isp);
return isp;
}

Expand All @@ -179,9 +180,10 @@ int main(int argc, char **argv, char **env) {
const char *address = argc < 4 ? "127.0.0.1" : argv[3];

Verilated::commandArgs(argc, argv);
Init();
isp->connect(atoi(argv[1]), atoi(argv[2]), address);
initAgent(isp);
isp->reset();
isp->simulate(atoi(argv[1]), atoi(argv[2]), address);
isp->simulate();
top->final();
exit(0);
}
24 changes: 19 additions & 5 deletions samples/liteuart/sim_main.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,13 @@ void eval() {
uart->eval();
}

RenodeAgent *Init() {
UART* initAgent() {
const int litex_rxtx_reg = 0x800;
return new UART(&top->serial_tx, &top->serial_rx, prescaler, litex_rxtx_reg, &top->irq_uart0);
}

void initBus(RenodeAgent *agent)
{
Wishbone* bus = new Wishbone();

//=================================================
Expand All @@ -60,8 +66,13 @@ RenodeAgent *Init() {
//=================================================
// Init peripheral
//=================================================
const int litex_rxtx_reg = 0x800;
uart = new UART(bus, &top->serial_tx, &top->serial_rx, prescaler, litex_rxtx_reg, &top->irq_uart0);
agent->addBus(bus);
}

RenodeAgent* Init() {
uart = initAgent();
uart->connectNative();
initBus(uart);
return uart;
}

Expand All @@ -79,8 +90,11 @@ int main(int argc, char **argv, char **env) {
top->trace(tfp, 99);
tfp->open("simx.fst");
#endif
Init();
uart->simulate(atoi(argv[1]), atoi(argv[2]), address);
uart = initAgent();
uart->connect(atoi(argv[1]), atoi(argv[2]), address);
initBus(uart);
uart->simulate();

top->final();
exit(0);
}
23 changes: 16 additions & 7 deletions samples/ram/sim_main.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -11,12 +11,12 @@
#include <stdlib.h>
#include <stdint.h>
#if VM_TRACE
# include <verilated_vcd_c.h>
#include <verilated_vcd_c.h>
#endif
#include "src/buses/axi.h"
#include "src/renode.h"

RenodeAgent *axi_ram;
RenodeAgent *axi_ram = new RenodeAgent;
Vaxi_ram *top = new Vaxi_ram;
VerilatedVcdC *tfp;
vluint64_t main_time = 0;
Expand All @@ -30,7 +30,8 @@ void eval() {
top->eval();
}

RenodeAgent *Init() {
void initAgent(RenodeAgent *agent)
{
Axi* bus = new Axi(32, 32);

//=================================================
Expand Down Expand Up @@ -84,8 +85,13 @@ RenodeAgent *Init() {
//=================================================
// Init peripheral
//=================================================
axi_ram = new RenodeAgent(bus);
bus->setAgent(axi_ram);

agent->addBus(bus);
}

RenodeAgent* Init() {
axi_ram->connectNative();
initAgent(axi_ram);
return axi_ram;
}

Expand All @@ -103,8 +109,11 @@ int main(int argc, char **argv, char **env) {
top->trace(tfp, 99);
tfp->open("simx.vcd");
#endif
Init();
axi_ram->simulate(atoi(argv[1]), atoi(argv[2]), address);

axi_ram->connect(atoi(argv[1]), atoi(argv[2]), address);
initAgent(axi_ram);
axi_ram->simulate();

top->final();
exit(0);
}
17 changes: 13 additions & 4 deletions samples/uartlite/sim_main.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,8 @@ void eval() {
top->eval();
}

RenodeAgent *Init() {
RenodeAgent *initAgent() {
RenodeAgent * agent = new UART(&top->txd, &top->rxd, prescaler);
AxiLite* bus = new AxiLite();

//=================================================
Expand Down Expand Up @@ -66,7 +67,14 @@ RenodeAgent *Init() {
//=================================================
// Init peripheral
//=================================================
return new UART(bus, &top->txd, &top->rxd, prescaler);
agent->addBus(bus);
return agent;
}

RenodeAgent* Init() {
RenodeAgent *agent = initAgent();
agent->connectNative();
return agent;
}

int main(int argc, char **argv, char **env) {
Expand All @@ -83,8 +91,9 @@ int main(int argc, char **argv, char **env) {
top->trace(tfp, 99);
tfp->open("simx.vcd");
#endif
RenodeAgent *uart = Init();
uart->simulate(atoi(argv[1]), atoi(argv[2]), address);
RenodeAgent *uart = initAgent();
uart->connect(atoi(argv[1]), atoi(argv[2]), address);
uart->simulate();
top->final();
exit(0);
}
Loading

0 comments on commit a2969e4

Please sign in to comment.