nkeynes@9: nkeynes@9: #ifndef dream_disasm_H nkeynes@9: #define dream_disasm_H 1 nkeynes@9: nkeynes@9: #include nkeynes@9: nkeynes@9: #ifdef __cplusplus nkeynes@9: extern "C" { nkeynes@9: #endif nkeynes@9: nkeynes@9: /** nkeynes@9: * Disassembly function pointer typedef. nkeynes@9: * nkeynes@9: * @param pc Address to disassemble nkeynes@9: * @param buffer String buffer to write disassembly into nkeynes@9: * @param buflen Maximum length of buffer nkeynes@9: * @return next address to disassemble nkeynes@9: */ nkeynes@11: typedef uint32_t (*disasm_func_t)(uint32_t pc, char *buffer, int buflen, char *opcode ); nkeynes@11: nkeynes@11: typedef int (*is_valid_page_t)(uint32_t pc); nkeynes@9: nkeynes@9: #define REG_INT 0 nkeynes@9: #define REG_FLT 1 nkeynes@9: #define REG_SPECIAL 2 nkeynes@9: nkeynes@9: /** nkeynes@9: * Structure that defines a single register in a CPU for display purposes. nkeynes@9: */ nkeynes@9: typedef struct reg_desc_struct { nkeynes@9: char *name; nkeynes@9: int type; nkeynes@9: void *value; nkeynes@9: } reg_desc_t; nkeynes@9: nkeynes@9: typedef struct cpu_desc_struct { nkeynes@9: char *name; /* CPU Name */ nkeynes@9: disasm_func_t disasm_func; /* Disassembly function */ nkeynes@9: size_t instr_size; /* Size of instruction */ nkeynes@9: char *regs; /* Pointer to start of registers */ nkeynes@9: size_t regs_size; /* Size of register structure in bytes */ nkeynes@13: const struct reg_desc_struct *regs_info; /* Description of all registers */ nkeynes@9: uint32_t *pc; /* Pointer to PC register */ nkeynes@9: uint32_t *icount; /* Pointer to instruction counter */ nkeynes@9: /* Memory map? */ nkeynes@14: is_valid_page_t is_valid_page_func; /* Test for valid memory page */ nkeynes@9: } *cpu_desc_t; nkeynes@9: nkeynes@9: #ifdef __cplusplus nkeynes@9: } nkeynes@9: #endif nkeynes@9: nkeynes@9: #endif /* !dream_disasm_H */