PICSimLab - Programmable IC Simulator Laboratory 0.9.3
PICSimLab - API
Loading...
Searching...
No Matches
bsim_qemu.h
1/* ########################################################################
2
3 PICSimLab - Programmable IC Simulator Laboratory
4
5 ########################################################################
6
7 Copyright (c) : 2010-2026 Luis Claudio GambĂ´a Lopes <lcgamboa@yahoo.com>
8
9 This program is free software; you can redistribute it and/or modify
10 it under the terms of the GNU General Public License as published by
11 the Free Software Foundation; either version 2, or (at your option)
12 any later version.
13
14 This program is distributed in the hope that it will be useful,
15 but WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 GNU General Public License for more details.
18
19 You should have received a copy of the GNU General Public License
20 along with this program; if not, write to the Free Software
21 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
22
23 For e-mail suggestions : lcgamboa@yahoo.com
24 ######################################################################## */
25
26#ifndef BOARD_QEMU_H
27#define BOARD_QEMU_H
28
29#include <atomic>
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"
36#include "qemu.h"
37
38typedef enum { QEMU_SIM_NONE = 0, QEMU_SIM_STM32, QEMU_SIM_ESP32, QEMU_SIM_ESP32_C3 } QEMUSimType;
39
40#define TTIMEOUT (BASETIMER * 1000000L)
41
42class bsim_qemu : virtual public board {
43public:
44 bsim_qemu(void);
45 ~bsim_qemu(void);
46 int DebugInit(int dtyppe) override;
47 std::string GetDebugName(void) override { return "GDB"; };
48 void DebugLoop(void) override;
49 int CpuInitialized(void) override;
50 void MSetSerial(const char* port) override;
51 int MInit(const char* processor, const char* fname, float freq) override;
52 void MEnd(void) override;
53 int MGetArchitecture(void) override;
54 int MDumpMemory(const char* fname) override;
55 void MEraseFlash(void) override;
56 void MSetFreq(float freq) override;
57 float MGetFreq(void) override;
58 void MSetVCC(float vcc) override;
59 float MGetVCC(void) override;
60 float MGetInstClockFreq(void) 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;
65 const picpin* MGetPinsValues(void) override;
66 float* MGetPinOAVPtr(int pin) override;
67 void MStep(void) override;
68 void MStepResume(void) override {};
69 int MReset(int flags) override;
70 int MGetResetPin(void) override;
71 int MGetIOUpdated(void) override;
72 void MClearIOUpdated(void) override;
73 void EvThreadRun(void) override;
74 int GetDefaultClock(void) override { return 1; };
75 int GetInc_ns(void) { return inc_ns; };
76 virtual void PinsExtraConfig(int cfg) {};
77 user_timer_t timer;
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;
84 void IoLockAccess(void) override;
85 void IoUnlockAccess(void) override;
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)"; };
89 // Called ever 1s to refresh status
90 void RefreshStatus(void) override;
91
92protected:
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;
100 int icount;
101#ifdef _WIN_
102 HANDLE serialfd[4];
103#else
104 int serialfd[4];
105#endif
106 int procid;
107 picpin pins[MAX_PIN_COUNT];
108 unsigned int serialbaud;
109 float serialexbaud;
110 float freq;
111 unsigned int inc_ns;
112 char fname[2048];
113 char fname_[2048];
114 char fname_bak[2048];
115 unsigned short ADCvalues[16];
116 int mtx_qinitId;
117 std::atomic_int qemu_started;
118 QEMUSimType SimType;
119 std::string cmdline;
120 int use_cmdline_extra;
121 std::string cmdline_extra;
122 int serial_open;
123 unsigned int application_offset;
124 int ConfEnableSerial;
125 int ConfigWaitGdb;
126
127private:
128 int load_qemu_lib(const char* path);
129};
130
131#endif /* BOARD_QEMU_H */
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