typedef long int INT32;
typedef unsigned long int UINT32;
typedef unsigned long int ADDR32;
typedef unsigned long int INST32;
typedef long int BOOLEAN;
typedef unsigned char BYTE;
typedef short int INT16;
typedef unsigned short int UINT16;
#define EMUSAGE 1
#define EMFAIL 2
#define EMBADADDR 3
#define EMBADREG 4
#define EMSYNTAX 5
#define EMACCESS 6
#define EMALLOC 7
#define EMTARGET 8
#define EMHINIT 9
#define EMCOMM 10
#define EMBADMSG 11
#define EMMSG2BIG 12
#define EMNOSEND 13
#define EMNORECV 14
#define EMRESET 15
#define EMCONFIG 16
#define EMSTATUS 17
#define EMREAD 18
#define EMWRITE 19
#define EMBKPTSET 20
#define EMBKPTRM 21
#define EMBKPTSTAT 22
#define EMBKPTNONE 23
#define EMBKPTUSED 24
#define EMCOPY 25
#define EMFILL 26
#define EMINIT 27
#define EMGO 28
#define EMSTEP 29
#define EMBREAK 30
#define EMHIF 31
#define EMCHANNEL0 32
#define EMCHANNEL1 33
#define EMOPEN 34
#define EMHDR 35
#define EMMAGIC 36
#define EMAOUT 37
#define EMSCNHDR 38
#define EMSCN 39
#define EMCLOSE 40
#define EMLOGOPEN 41
#define EMLOGREAD 42
#define EMLOGWRITE 43
#define EMLOGCLOSE 44
#define EMCMDOPEN 45
#define EMCMDREAD 46
#define EMCMDWRITE 47
#define EMCMDCLOSE 48
#define EMTIMEOUT 49
#define EMCOMMTYPE 50
#define EMCOMMERR 51
#define EMBAUD 52
#define LOCAL_REG 0
#define GLOBAL_REG 1
#define SPECIAL_REG 2
#define TLB_REG 3
#define COPROC_REG 4
#define I_MEM 5
#define D_MEM 6
#define I_ROM 7
#define D_ROM 8
#define I_O 9
#define I_CACHE 10
#define D_CACHE 11
#define DUMMY 1
#define RESET 0
#define CONFIG_REQ 1
#define STATUS_REQ 2
#define READ_REQ 3
#define WRITE_REQ 4
#define BKPT_SET 5
#define BKPT_RM 6
#define BKPT_STAT 7
#define COPY 8
#define FILL 9
#define INIT 10
#define GO 11
#define STEP 12
#define BREAK 13
#define HIF_CALL_RTN 64
#define CHANNEL0 65
#define CHANNEL1_ACK 66
#define RESET_ACK 32
#define CONFIG 33
#define STATUS 34
#define READ_ACK 35
#define WRITE_ACK 36
#define BKPT_SET_ACK 37
#define BKPT_RM_ACK 38
#define BKPT_STAT_ACK 39
#define COPY_ACK 40
#define FILL_ACK 41
#define INIT_ACK 42
#define HALT 43
#define ERROR 63
#define HIF_CALL 96
#define CHANNEL0_ACK 97
#define CHANNEL1 98
struct generic_msg_t
{
INT32 code;
INT32 length;
BYTE byte[DUMMY];
};
struct generic_int32_msg_t
{
INT32 code;
INT32 length;
INT32 int32[DUMMY];
};
struct reset_msg_t
{
INT32 code;
INT32 length;
};
struct config_req_msg_t
{
INT32 code;
INT32 length;
};
struct status_req_msg_t
{
INT32 code;
INT32 length;
};
struct read_req_msg_t
{
INT32 code;
INT32 length;
INT32 memory_space;
ADDR32 address;
INT32 byte_count;
};
struct write_req_msg_t
{
INT32 code;
INT32 length;
INT32 memory_space;
ADDR32 address;
INT32 byte_count;
BYTE data[DUMMY];
};
struct write_r_msg_t
{
INT32 code;
INT32 length;
INT32 memory_space;
ADDR32 address;
INT32 byte_count;
INT32 data[DUMMY];
};
struct bkpt_set_msg_t
{
INT32 code;
INT32 length;
INT32 memory_space;
ADDR32 bkpt_addr;
INT32 pass_count;
INT32 bkpt_type;
};
struct bkpt_rm_msg_t
{
INT32 code;
INT32 length;
INT32 memory_space;
ADDR32 bkpt_addr;
};
struct bkpt_stat_msg_t
{
INT32 code;
INT32 length;
INT32 memory_space;
ADDR32 bkpt_addr;
};
struct copy_msg_t
{
INT32 code;
INT32 length;
INT32 source_space;
ADDR32 source_addr;
INT32 dest_space;
ADDR32 dest_addr;
INT32 byte_count;
};
struct fill_msg_t
{
INT32 code;
INT32 length;
INT32 memory_space;
ADDR32 start_addr;
INT32 fill_count;
INT32 byte_count;
BYTE fill_data[DUMMY];
};
struct init_msg_t
{
INT32 code;
INT32 length;
ADDR32 text_start;
ADDR32 text_end;
ADDR32 data_start;
ADDR32 data_end;
ADDR32 entry_point;
INT32 mem_stack_size;
INT32 reg_stack_size;
ADDR32 arg_start;
INT32 os_control;
};
struct go_msg_t
{
INT32 code;
INT32 length;
};
struct step_msg_t
{
INT32 code;
INT32 length;
INT32 count;
};
struct break_msg_t
{
INT32 code;
INT32 length;
};
struct hif_call_rtn_msg_t
{
INT32 code;
INT32 length;
INT32 service_number;
INT32 gr121;
INT32 gr96;
INT32 gr97;
};
struct channel0_msg_t
{
INT32 code;
INT32 length;
BYTE data;
};
struct channel1_ack_msg_t
{
INT32 code;
INT32 length;
};
struct reset_ack_msg_t
{
INT32 code;
INT32 length;
};
struct config_msg_t
{
INT32 code;
INT32 length;
INT32 processor_id;
INT32 version;
ADDR32 I_mem_start;
INT32 I_mem_size;
ADDR32 D_mem_start;
INT32 D_mem_size;
ADDR32 ROM_start;
INT32 ROM_size;
INT32 max_msg_size;
INT32 max_bkpts;
INT32 coprocessor;
INT32 reserved;
};
struct status_msg_t
{
INT32 code;
INT32 length;
INT32 msgs_sent;
INT32 msgs_received;
INT32 errors;
INT32 bkpts_hit;
INT32 bkpts_free;
INT32 traps;
INT32 fills;
INT32 spills;
INT32 cycles;
INT32 reserved;
};
struct read_ack_msg_t
{
INT32 code;
INT32 length;
INT32 memory_space;
ADDR32 address;
INT32 byte_count;
BYTE data[DUMMY];
};
struct read_r_ack_msg_t
{
INT32 code;
INT32 length;
INT32 memory_space;
ADDR32 address;
INT32 byte_count;
INT32 data[DUMMY];
};
struct write_ack_msg_t
{
INT32 code;
INT32 length;
INT32 memory_space;
ADDR32 address;
INT32 byte_count;
};
struct bkpt_set_ack_msg_t
{
INT32 code;
INT32 length;
INT32 memory_space;
ADDR32 address;
INT32 pass_count;
INT32 bkpt_type;
};
struct bkpt_rm_ack_msg_t
{
INT32 code;
INT32 length;
INT32 memory_space;
ADDR32 address;
};
struct bkpt_stat_ack_msg_t
{
INT32 code;
INT32 length;
INT32 memory_space;
ADDR32 address;
INT32 pass_count;
INT32 bkpt_type;
};
struct copy_ack_msg_t
{
INT32 code;
INT32 length;
INT32 source_space;
ADDR32 source_addr;
INT32 dest_space;
ADDR32 dest_addr;
INT32 byte_count;
};
struct fill_ack_msg_t
{
INT32 code;
INT32 length;
INT32 memory_space;
ADDR32 start_addr;
INT32 fill_count;
INT32 byte_count;
};
struct init_ack_msg_t
{
INT32 code;
INT32 length;
};
struct halt_msg_t
{
INT32 code;
INT32 length;
INT32 memory_space;
ADDR32 pc0;
ADDR32 pc1;
INT32 trap_number;
};
struct error_msg_t
{
INT32 code;
INT32 length;
INT32 error_code;
INT32 memory_space;
ADDR32 address;
};
struct hif_call_msg_t
{
INT32 code;
INT32 length;
INT32 service_number;
INT32 lr2;
INT32 lr3;
INT32 lr4;
};
struct channel0_ack_msg_t
{
INT32 code;
INT32 length;
};
struct channel1_msg_t
{
INT32 code;
INT32 length;
BYTE data[DUMMY];
};
union msg_t
{
struct generic_msg_t generic_msg;
struct generic_int32_msg_t generic_int32_msg;
struct reset_msg_t reset_msg;
struct config_req_msg_t config_req_msg;
struct status_req_msg_t status_req_msg;
struct read_req_msg_t read_req_msg;
struct write_req_msg_t write_req_msg;
struct write_r_msg_t write_r_msg;
struct bkpt_set_msg_t bkpt_set_msg;
struct bkpt_rm_msg_t bkpt_rm_msg;
struct bkpt_stat_msg_t bkpt_stat_msg;
struct copy_msg_t copy_msg;
struct fill_msg_t fill_msg;
struct init_msg_t init_msg;
struct go_msg_t go_msg;
struct step_msg_t step_msg;
struct break_msg_t break_msg;
struct hif_call_rtn_msg_t hif_call_rtn_msg;
struct channel0_msg_t channel0_msg;
struct channel1_ack_msg_t channel1_ack_msg;
struct reset_ack_msg_t reset_ack_msg;
struct config_msg_t config_msg;
struct status_msg_t status_msg;
struct read_ack_msg_t read_ack_msg;
struct read_r_ack_msg_t read_r_ack_msg;
struct write_ack_msg_t write_ack_msg;
struct bkpt_set_ack_msg_t bkpt_set_ack_msg;
struct bkpt_rm_ack_msg_t bkpt_rm_ack_msg;
struct bkpt_stat_ack_msg_t bkpt_stat_ack_msg;
struct copy_ack_msg_t copy_ack_msg;
struct fill_ack_msg_t fill_ack_msg;
struct init_ack_msg_t init_ack_msg;
struct halt_msg_t halt_msg;
struct error_msg_t error_msg;
struct hif_call_msg_t hif_call_msg;
struct channel0_ack_msg_t channel0_ack_msg;
struct channel1_msg_t channel1_msg;
};