29#include "../lib/board.h"
31#include "../devices/bitbang_uart.h"
32#include "../devices/mplabxd.h"
33#include "../lib/serial_port.h"
35#include <simavr/avr_adc.h>
36#include <simavr/avr_ioport.h>
37#include <simavr/avr_twi.h>
38#include <simavr/avr_uart.h>
39#include <simavr/sim_avr.h>
40#include <simavr/sim_elf.h>
41#include <simavr/sim_gdb.h>
42#include <simavr/sim_hex.h>
44#define MAX_UART_COUNT 4
64 int MInit(
const char* processor,
const char* fname,
float freq)
override;
65 void MEnd(
void)
override;
71 void MSetVCC(
float vcc)
override;
76 void MSetPin(
int pin,
unsigned char value)
override;
77 void MSetPinDOV(
int pin,
unsigned char ovalue)
override;
78 void MSetPinOAV(
int pin,
float value)
override;
79 void MSetAPin(
int pin,
float value)
override;
80 unsigned char MGetPin(
int pin)
override;
83 void MStep(
void)
override;
85 int MReset(
int flags)
override;
90 unsigned int DBGGetPC(
void)
override;
91 void DBGSetPC(
unsigned int pc)
override;
104 int GetUARTRX(
const int uart_num)
override;
105 int GetUARTTX(
const int uart_num)
override;
106 std::string GetUARTStrStatus(
const int uart_num)
override;
107 virtual void UpdateHardware(
void);
109 static void out_hook(
struct avr_irq_t* irq, uint32_t value,
void* param) {
110 picpin* p = (picpin*)param;
115 static void ddr_hook(
struct avr_irq_t* irq, uint32_t value,
void* param) {
116 picpin* p = (picpin*)param;
117 p->dir = !(value & (1 << p->pord));
121 void SerialSend(
bitbang_uart_t* _bb_uart,
const unsigned char value);
127 avr_irq_t* serial_irq[MAX_UART_COUNT];
128 picpin pins[MAX_PIN_COUNT];
129 avr_irq_t* Write_stat_irq[100];
130 unsigned int serialbaud[MAX_UART_COUNT];
131 float serialexbaud[MAX_UART_COUNT];
132 void pins_reset(
void);
136 unsigned char* eeprom;
137 unsigned char uart_config[MAX_UART_COUNT];
138 unsigned char usart_count;
139 unsigned int UCSR_base[MAX_UART_COUNT];
142 int parse_hex(
const char* line,
int bytes);
143 unsigned char checksum(
char* str);
144 int read_ihx_avr(
const char* fname,
int leeprom);
145 int write_ihx_avr(
const char* fname);
Board class.
Definition board.h:114
Definition bsim_simavr.h:56
float MGetVCC(void) override
board microcontroller get vcc
Definition bsim_simavr.cc:546
int DebugInit(int dtyppe) override
Start debug support.
Definition bsim_simavr.cc:592
unsigned int DBGGetEEPROM_Size(void) override
board microcontroller get data EEPROM memory size
Definition bsim_simavr.cc:1632
unsigned char * DBGGetCONFIG_p(void) override
board microcontroller get CONFIG memory pointer
Definition bsim_simavr.cc:1601
void MSetPin(int pin, unsigned char value) override
board microcontroller set digital pin
Definition bsim_simavr.cc:1188
float MGetFreq(void) override
board microcontroller get frequency
Definition bsim_simavr.cc:538
void MSetAPin(int pin, float value) override
board microcontroller set analog pin
Definition bsim_simavr.cc:1220
const picpin * MGetPinsValues(void) override
board microcontroller get all pins list struct
Definition bsim_simavr.cc:1393
unsigned int DBGGetRAMSize(void) override
board microcontroller get RAM memory size
Definition bsim_simavr.cc:1614
float * MGetPinOAVPtr(int pin) override
board microcontroller get pointer to digital pin average value
Definition bsim_simavr.cc:1397
void MStep(void) override
board microcontroller run one step
Definition bsim_simavr.cc:1538
unsigned char * DBGGetID_p(void) override
board microcontroller get internal IDS memory pointer
Definition bsim_simavr.cc:1605
void EndServers(void) override
board servers shutdown
Definition bsim_simavr.cc:1636
unsigned int DBGGetIDSize(void) override
board microcontroller get internal IDS memory size
Definition bsim_simavr.cc:1627
void MSetPinOAV(int pin, float value) override
board microcontroller set digital pin output average value
Definition bsim_simavr.cc:1216
unsigned int DBGGetROMSize(void) override
board microcontroller get ROM (FLASH) memory size
Definition bsim_simavr.cc:1618
int MGetArchitecture(void) override
Return board microcontroller architecture.
Definition bsim_simavr.cc:522
int MInit(const char *processor, const char *fname, float freq) override
board microcontroller init
Definition bsim_simavr.cc:283
int GetUARTRX(const int uart_num) override
Return the UART N RX pin number.
Definition bsim_simavr.cc:1640
unsigned char MGetPin(int pin) override
board microcontroller get digital pin value
Definition bsim_simavr.cc:1386
void MSetFreq(float freq) override
board microcontroller set frequency
Definition bsim_simavr.cc:531
int MGetPinCount(void) override
board microcontroller pin count
Definition bsim_simavr.cc:638
void MSetPinDOV(int pin, unsigned char ovalue) override
board microcontroller set Default Open Value (external pull)
Definition bsim_simavr.cc:1203
int MGetIOUpdated(void) override
get microcontroler status IO updated
Definition bsim_simavr.cc:1573
void MSetVCC(float vcc) override
board microcontroller set vcc
Definition bsim_simavr.cc:542
int GetUARTTX(const int uart_num) override
Return the UART N TX pin number.
Definition bsim_simavr.cc:1646
int CpuInitialized(void) override
return true if microcontroller is initialized
Definition bsim_simavr.cc:634
void MSetSerial(const char *port) override
Set serial port name to use.
Definition bsim_simavr.cc:83
unsigned int DBGGetCONFIGSize(void) override
board microcontroller get CONFIG memory size
Definition bsim_simavr.cc:1622
unsigned int DBGGetPC(void) override
board microcontroller get PC
Definition bsim_simavr.cc:1585
void DebugLoop(void) override
debug step (pooling)
Definition bsim_simavr.cc:623
int GetDefaultClock(void) override
Get board default clock in MHz.
Definition bsim_simavr.h:103
unsigned char * DBGGetRAM_p(void) override
board microcontroller get RAM memory pointer
Definition bsim_simavr.cc:1593
void MEraseFlash(void) override
board microcontroller erase flash memory (program)
Definition bsim_simavr.cc:526
int MReset(int flags) override
board microcontroller reset
Definition bsim_simavr.cc:1544
float MGetInstClockFreq(void) override
board microcontroller get cpu internal clock (in PIC frequency/4)
Definition bsim_simavr.cc:553
unsigned char * DBGGetROM_p(void) override
board microcontroller get ROM (FLASH) memory pointer
Definition bsim_simavr.cc:1597
std::string GetDebugName(void) override
Get debug interface name.
Definition bsim_simavr.cc:615
void MStepResume(void) override
board microcontroller run one or two steps to resume instruction
Definition bsim_simavr.cc:1542
int MDumpMemory(const char *fname) override
board microcontroller save non volatile memory to hex file
Definition bsim_simavr.cc:557
unsigned char * DBGGetEEPROM_p(void) override
board microcontroller get data EEPROM memory pointer
Definition bsim_simavr.cc:1610
int MGetResetPin(void) override
Get the Reset pin of microcontroller.
Definition bsim_simavr.cc:1569
void MEnd(void) override
board microcontroller end
Definition bsim_simavr.cc:470
std::string MGetPinName(int pin) override
board microcontroller pin name
Definition bsim_simavr.cc:662
void DBGSetPC(unsigned int pc) override
board microcontroller set PC
Definition bsim_simavr.cc:1589
unsigned short * DBGGetProcID_p(void) override
board microcontroller get pointer to processor ID
Definition bsim_simavr.cc:1581
void MClearIOUpdated(void) override
clear microcontroler status IO updated
Definition bsim_simavr.cc:1577
Definition bitbang_uart.h:35
Definition bsim_simavr.h:46