29#include "../lib/board.h"
30#include "../lib/serial_port.h"
32#include "../devices/mplabxd.h"
34class bsim_picsim :
virtual public board {
42 int MInit(
const char* processor,
const char* fname,
float freq)
override;
43 void MEnd(
void)
override;
49 void MSetVCC(
float vcc)
override;
54 void MSetPin(
int pin,
unsigned char value)
override;
55 void MSetPinDOV(
int pin,
unsigned char ovalue)
override;
56 void MSetPinOAV(
int pin,
float value)
override;
57 void MSetAPin(
int pin,
float value)
override;
58 unsigned char MGetPin(
int pin)
override;
61 void MStep(
void)
override;
63 int MReset(
int flags)
override;
68 unsigned int DBGGetPC(
void)
override;
69 void DBGSetPC(
unsigned int pc)
override;
84 int GetUARTRX(
const int uart_num)
override;
85 int GetUARTTX(
const int uart_num)
override;
86 std::string GetUARTStrStatus(
const int uart_num)
override;
92 unsigned char error_flags;
board(void)
Called once on board creation.
Definition board.cc:34
unsigned short * DBGGetProcID_p(void) override
board microcontroller get pointer to processor ID
Definition bsim_picsim.cc:224
int MDumpMemory(const char *fname) override
board microcontroller save non volatile memory to hex file
Definition bsim_picsim.cc:124
int MGetPinCount(void) override
board microcontroller pin count
Definition bsim_picsim.cc:157
void MSetAPin(int pin, float value) override
board microcontroller set analog pin
Definition bsim_picsim.cc:182
int GetDefaultClock(void) override
Get board default clock in MHz.
Definition bsim_picsim.h:83
std::string GetDebugName(void) override
Get debug interface name.
Definition bsim_picsim.h:38
int MGetArchitecture(void) override
Return board microcontroller architecture.
Definition bsim_picsim.cc:80
int MInit(const char *processor, const char *fname, float freq) override
board microcontroller init
Definition bsim_picsim.cc:44
unsigned char * DBGGetRAM_p(void) override
board microcontroller get RAM memory pointer
Definition bsim_picsim.cc:236
unsigned int DBGGetEEPROM_Size(void) override
board microcontroller get data EEPROM memory size
Definition bsim_picsim.cc:278
unsigned int DBGGetROMSize(void) override
board microcontroller get ROM (FLASH) memory size
Definition bsim_picsim.cc:260
void MSetPin(int pin, unsigned char value) override
board microcontroller set digital pin
Definition bsim_picsim.cc:170
unsigned int DBGGetRAMSize(void) override
board microcontroller get RAM memory size
Definition bsim_picsim.cc:256
void MSetPinOAV(int pin, float value) override
board microcontroller set digital pin output average value
Definition bsim_picsim.cc:178
unsigned char * DBGGetROM_p(void) override
board microcontroller get ROM (FLASH) memory pointer
Definition bsim_picsim.cc:240
int MGetResetPin(void) override
Get the Reset pin of microcontroller.
Definition bsim_picsim.cc:212
void MSetSerial(const char *port) override
Set serial port name to use.
Definition bsim_picsim.cc:35
std::string MGetPinName(int pin) override
board microcontroller pin name
Definition bsim_picsim.cc:161
unsigned char * DBGGetCONFIG_p(void) override
board microcontroller get CONFIG memory pointer
Definition bsim_picsim.cc:244
unsigned int DBGGetRAMLARD(void) override
board microcontroller get last ram read address
Definition bsim_picsim.cc:286
void MSetFreq(float freq) override
board microcontroller set frequency
Definition bsim_picsim.cc:99
int DebugInit(int dtyppe) override
Start debug support.
Definition bsim_picsim.cc:139
void DebugLoop(void) override
debug step (pooling)
Definition bsim_picsim.cc:150
unsigned int DBGGetPC(void) override
board microcontroller get PC
Definition bsim_picsim.cc:228
int CpuInitialized(void) override
return true if microcontroller is initialized
Definition bsim_picsim.cc:120
void DBGSetPC(unsigned int pc) override
board microcontroller set PC
Definition bsim_picsim.cc:232
void MEraseFlash(void) override
board microcontroller erase flash memory (program)
Definition bsim_picsim.cc:95
unsigned int DBGGetCONFIGSize(void) override
board microcontroller get CONFIG memory size
Definition bsim_picsim.cc:270
void MSetPinDOV(int pin, unsigned char ovalue) override
board microcontroller set Default Open Value (external pull)
Definition bsim_picsim.cc:174
const picpin * MGetPinsValues(void) override
board microcontroller get all pins list struct
Definition bsim_picsim.cc:190
unsigned char * DBGGetEEPROM_p(void) override
board microcontroller get data EEPROM memory pointer
Definition bsim_picsim.cc:252
void RefreshStatus(void) override
Called ever 1s to refresh status.
Definition bsim_picsim.cc:319
void MStepResume(void) override
board microcontroller run one or two steps to resume instruction
Definition bsim_picsim.cc:202
unsigned char MGetPin(int pin) override
board microcontroller get digital pin value
Definition bsim_picsim.cc:186
int GetUARTRX(const int uart_num) override
Return the UART N RX pin number.
Definition bsim_picsim.cc:294
float * MGetPinOAVPtr(int pin) override
board microcontroller get pointer to digital pin average value
Definition bsim_picsim.cc:194
unsigned char * DBGGetID_p(void) override
board microcontroller get internal IDS memory pointer
Definition bsim_picsim.cc:248
float MGetInstClockFreq(void) override
board microcontroller get cpu internal clock (in PIC frequency/4)
Definition bsim_picsim.cc:116
void MStep(void) override
board microcontroller run one step
Definition bsim_picsim.cc:198
void MClearIOUpdated(void) override
clear microcontroler status IO updated
Definition bsim_picsim.cc:220
float MGetVCC(void) override
board microcontroller get vcc
Definition bsim_picsim.cc:112
int MGetIOUpdated(void) override
get microcontroler status IO updated
Definition bsim_picsim.cc:216
void MEnd(void) override
board microcontroller end
Definition bsim_picsim.cc:74
unsigned int DBGGetRAMLAWR(void) override
board microcontroller get last ram write address
Definition bsim_picsim.cc:282
void MSetVCC(float vcc) override
board microcontroller set vcc
Definition bsim_picsim.cc:108
unsigned int DBGGetIDSize(void) override
board microcontroller get internal IDS memory size
Definition bsim_picsim.cc:274
int GetUARTTX(const int uart_num) override
Return the UART N TX pin number.
Definition bsim_picsim.cc:301
void EndServers(void) override
board servers shutdown
Definition bsim_picsim.cc:290
float MGetFreq(void) override
board microcontroller get frequency
Definition bsim_picsim.cc:104
int MReset(int flags) override
board microcontroller reset
Definition bsim_picsim.cc:207