30#include "../devices/bitbang_i2c.h"
31#include "../devices/bitbang_out.h"
32#include "../devices/bitbang_pwm.h"
33#include "../devices/bitbang_spi.h"
34#include "../devices/bitbang_uart.h"
35#include "../lib/board.h"
38typedef enum { QEMU_SIM_NONE = 0, QEMU_SIM_STM32, QEMU_SIM_ESP32, QEMU_SIM_ESP32_C3 } QEMUSimType;
40#define TTIMEOUT (BASETIMER * 1000000L)
42class bsim_qemu :
virtual public board {
51 int MInit(
const char* processor,
const char* fname,
float freq)
override;
52 void MEnd(
void)
override;
58 void MSetVCC(
float vcc)
override;
61 void MSetPin(
int pin,
unsigned char value)
override;
62 void MSetPinDOV(
int pin,
unsigned char ovalue)
override;
63 void MSetPinOAV(
int pin,
float value)
override;
64 unsigned char MGetPin(
int pin)
override;
67 void MStep(
void)
override;
69 int MReset(
int flags)
override;
75 int GetInc_ns(
void) {
return inc_ns; };
76 virtual void PinsExtraConfig(
int cfg) {};
78 virtual void Run_CPU_ns(uint64_t time) = 0;
79 bitbang_i2c_t master_i2c[2];
80 bitbang_spi_t master_spi[2];
81 bitbang_uart_t master_uart[3];
82 bitbang_pwm_t pwm_out;
83 bitbang_out_t rmt_out;
86 int GetUARTRX(
const int uart_num)
override;
87 int GetUARTTX(
const int uart_num)
override;
88 virtual std::string
GetClkLabel(
void)
override {
return "IO (Mhz)"; };
93 int MipsStrToIcount(
const char* mipstr);
94 const char* IcountToMipsStr(
int icount);
95 const char* IcountToMipsItens(
char* buffer);
96 unsigned int ns_count;
97 void pins_reset(
void);
98 virtual void BoardOptions(
int* argc,
char** argv) {};
99 virtual const short int* GetPinMap(
void) = 0;
107 picpin pins[MAX_PIN_COUNT];
108 unsigned int serialbaud;
114 char fname_bak[2048];
115 unsigned short ADCvalues[16];
117 std::atomic_int qemu_started;
120 int use_cmdline_extra;
121 std::string cmdline_extra;
123 unsigned int application_offset;
124 int ConfEnableSerial;
128 int load_qemu_lib(
const char* path);
board(void)
Called once on board creation.
Definition board.cc:34
void MSetPinDOV(int pin, unsigned char ovalue) override
board microcontroller set Default Open Value (external pull)
Definition bsim_qemu.cc:1153
float MGetFreq(void) override
board microcontroller get frequency
Definition bsim_qemu.cc:1001
int MInit(const char *processor, const char *fname, float freq) override
board microcontroller init
Definition bsim_qemu.cc:360
void MSetFreq(float freq) override
board microcontroller set frequency
Definition bsim_qemu.cc:995
void IoLockAccess(void) override
Lock IO to others threads access.
Definition bsim_qemu.cc:1319
void MEraseFlash(void) override
board microcontroller erase flash memory (program)
Definition bsim_qemu.cc:991
float MGetVCC(void) override
board microcontroller get vcc
Definition bsim_qemu.cc:1009
int GetDefaultClock(void) override
Get board default clock in MHz.
Definition bsim_qemu.h:74
void MSetPinOAV(int pin, float value) override
board microcontroller set digital pin output average value
Definition bsim_qemu.cc:1157
float MGetInstClockFreq(void) override
board microcontroller get cpu internal clock (in PIC frequency/4)
Definition bsim_qemu.cc:1013
unsigned char MGetPin(int pin) override
board microcontroller get digital pin value
Definition bsim_qemu.cc:1161
float * MGetPinOAVPtr(int pin) override
board microcontroller get pointer to digital pin average value
Definition bsim_qemu.cc:1212
virtual std::string GetClkLabel(void) override
Return the description of clk label.
Definition bsim_qemu.h:88
void MEnd(void) override
board microcontroller end
Definition bsim_qemu.cc:960
std::string GetDebugName(void) override
Get debug interface name.
Definition bsim_qemu.h:47
int MReset(int flags) override
board microcontroller reset
Definition bsim_qemu.cc:1168
void MStep(void) override
board microcontroller run one step
Definition bsim_qemu.cc:1216
int MGetResetPin(void) override
Get the Reset pin of microcontroller.
Definition bsim_qemu.cc:1196
void MStepResume(void) override
board microcontroller run one or two steps to resume instruction
Definition bsim_qemu.h:68
void EvThreadRun(void) override
Event on the board.
Definition bsim_qemu.cc:416
int DebugInit(int dtyppe) override
Start debug support.
Definition bsim_qemu.cc:1112
int MGetArchitecture(void) override
Return board microcontroller architecture.
Definition bsim_qemu.cc:983
void RefreshStatus(void) override
Called ever 1s to refresh status.
Definition bsim_qemu.cc:1343
int GetUARTTX(const int uart_num) override
Return the UART N TX pin number.
Definition bsim_qemu.cc:1334
void MSetSerial(const char *port) override
Set serial port name to use.
Definition bsim_qemu.cc:358
int GetUARTRX(const int uart_num) override
Return the UART N RX pin number.
Definition bsim_qemu.cc:1327
int MDumpMemory(const char *fname) override
board microcontroller save non volatile memory to hex file
Definition bsim_qemu.cc:1023
const picpin * MGetPinsValues(void) override
board microcontroller get all pins list struct
Definition bsim_qemu.cc:1208
void MClearIOUpdated(void) override
clear microcontroler status IO updated
Definition bsim_qemu.cc:1204
int CpuInitialized(void) override
return true if microcontroller is initialized
Definition bsim_qemu.cc:1017
void DebugLoop(void) override
debug step (pooling)
Definition bsim_qemu.cc:1021
void MSetPin(int pin, unsigned char value) override
board microcontroller set digital pin
Definition bsim_qemu.cc:1142
int MGetIOUpdated(void) override
get microcontroler status IO updated
Definition bsim_qemu.cc:1200
void MSetVCC(float vcc) override
board microcontroller set vcc
Definition bsim_qemu.cc:1005
void IoUnlockAccess(void) override
Unlock IO to others threads access.
Definition bsim_qemu.cc:1323