2015-06-28 18:42:25 +00:00
|
|
|
#ifndef __ATOMBUSMON_DEFINES__
|
|
|
|
#define __ATOMBUSMON_DEFINES__
|
|
|
|
|
2019-11-10 16:18:23 +00:00
|
|
|
#include <stdio.h>
|
|
|
|
|
|
|
|
typedef uint8_t data_t;
|
|
|
|
typedef uint16_t addr_t;
|
|
|
|
typedef uint8_t offset_t;
|
|
|
|
typedef uint16_t modes_t;
|
|
|
|
typedef uint8_t trigger_t;
|
|
|
|
typedef uint16_t cmd_t;
|
|
|
|
typedef uint16_t param_t;
|
|
|
|
typedef int16_t bknum_t;
|
|
|
|
|
2015-06-28 18:42:25 +00:00
|
|
|
#include "status.h"
|
|
|
|
#include "dis.h"
|
|
|
|
|
2015-07-01 11:08:30 +00:00
|
|
|
// The Atom CRC Polynomial
|
|
|
|
#define CRC_POLY 0x002d
|
|
|
|
|
|
|
|
#define Delay_us(__us) \
|
|
|
|
if((unsigned long) (F_CPU/1000000.0 * __us) != F_CPU/1000000.0 * __us)\
|
|
|
|
__builtin_avr_delay_cycles((unsigned long) ( F_CPU/1000000.0 * __us)+1);\
|
|
|
|
else __builtin_avr_delay_cycles((unsigned long) ( F_CPU/1000000.0 * __us))
|
|
|
|
|
|
|
|
#define Delay_ms(__ms) \
|
|
|
|
if((unsigned long) (F_CPU/1000.0 * __ms) != F_CPU/1000.0 * __ms)\
|
|
|
|
__builtin_avr_delay_cycles((unsigned long) ( F_CPU/1000.0 * __ms)+1);\
|
|
|
|
else __builtin_avr_delay_cycles((unsigned long) ( F_CPU/1000.0 * __ms))
|
|
|
|
|
2019-11-06 17:15:06 +00:00
|
|
|
|
|
|
|
uint8_t hwRead8(offset_t offset);
|
|
|
|
uint16_t hwRead16(offset_t offset);
|
|
|
|
|
|
|
|
addr_t disMem(addr_t addr);
|
|
|
|
void loadData(data_t data);
|
|
|
|
void loadAddr(addr_t addr);
|
|
|
|
data_t readMemByte();
|
|
|
|
data_t readMemByteInc();
|
2015-06-29 12:03:32 +00:00
|
|
|
void writeMemByte();
|
|
|
|
void writeMemByteInc();
|
2019-11-06 17:15:06 +00:00
|
|
|
addr_t disMem(addr_t addr);
|
2015-06-28 18:42:25 +00:00
|
|
|
|
2019-11-06 17:15:06 +00:00
|
|
|
void doCmdBreak(char *params, modes_t mode);
|
2015-07-01 11:08:30 +00:00
|
|
|
void doCmdBreakI(char *params);
|
|
|
|
void doCmdBreakRdIO(char *params);
|
|
|
|
void doCmdBreakRdMem(char *params);
|
|
|
|
void doCmdBreakWrIO(char *params);
|
|
|
|
void doCmdBreakWrMem(char *params);
|
|
|
|
void doCmdClear(char *params);
|
|
|
|
void doCmdContinue(char *params);
|
|
|
|
void doCmdCrc(char *params);
|
|
|
|
void doCmdDis(char *params);
|
2019-11-12 12:57:30 +00:00
|
|
|
void doCmdFlush(char *params);
|
2015-07-01 11:08:30 +00:00
|
|
|
void doCmdFill(char *params);
|
|
|
|
void doCmdHelp(char *params);
|
2019-11-06 17:34:54 +00:00
|
|
|
#if defined(COMMAND_HISTORY)
|
|
|
|
void doCmdHistory(char *params);
|
|
|
|
#endif
|
2015-07-01 11:08:30 +00:00
|
|
|
void doCmdIO(char *params);
|
|
|
|
void doCmdList(char *params);
|
|
|
|
void doCmdMem(char *params);
|
2019-10-29 15:48:43 +00:00
|
|
|
void doCmdNext(char *params);
|
2015-07-01 11:08:30 +00:00
|
|
|
void doCmdReadIO(char *params);
|
|
|
|
void doCmdReadMem(char *params);
|
|
|
|
void doCmdRegs(char *params);
|
|
|
|
void doCmdReset(char *params);
|
|
|
|
void doCmdStep(char *params);
|
|
|
|
void doCmdTest(char *params);
|
2016-09-09 10:31:50 +00:00
|
|
|
void doCmdSRec(char *params);
|
2019-06-15 16:50:29 +00:00
|
|
|
void doCmdSpecial(char *params);
|
2015-07-01 11:08:30 +00:00
|
|
|
void doCmdTrace(char *params);
|
|
|
|
void doCmdTrigger(char *params);
|
|
|
|
void doCmdWatchI(char *params);
|
|
|
|
void doCmdWatchRdIO(char *params);
|
|
|
|
void doCmdWatchRdMem(char *params);
|
|
|
|
void doCmdWatchWrIO(char *params);
|
|
|
|
void doCmdWatchWrMem(char *params);
|
|
|
|
void doCmdWriteIO(char *params);
|
|
|
|
void doCmdWriteMem(char *params);
|
|
|
|
|
2015-06-28 18:42:25 +00:00
|
|
|
#endif
|