/* Capstone Disassembly Engine */ /* By Dang Hoang Vu 2013 */ #ifdef CAPSTONE_HAS_MIPS #include "../../utils.h" #include "../../MCRegisterInfo.h" #include "MipsDisassembler.h" #include "MipsInstPrinter.h" #include "MipsMapping.h" // Returns mode value with implied bits set static inline cs_mode updated_mode(cs_mode mode) { if (mode & CS_MODE_MIPS32R6) { mode |= CS_MODE_32; } return mode; } static cs_err init(cs_struct *ud) { MCRegisterInfo *mri; mri = cs_mem_malloc(sizeof(*mri)); Mips_init(mri); ud->printer = Mips_printInst; ud->printer_info = mri; ud->getinsn_info = mri; ud->reg_name = Mips_reg_name; ud->insn_id = Mips_get_insn_id; ud->insn_name = Mips_insn_name; ud->group_name = Mips_group_name; ud->mode = updated_mode(ud->mode); if (ud->mode & CS_MODE_32) ud->disasm = Mips_getInstruction; else ud->disasm = Mips64_getInstruction; return CS_ERR_OK; } static cs_err option(cs_struct *handle, cs_opt_type type, size_t value) { if (type == CS_OPT_MODE) { value = updated_mode(value); if (value & CS_MODE_32) handle->disasm = Mips_getInstruction; else handle->disasm = Mips64_getInstruction; handle->mode = (cs_mode)value; } return CS_ERR_OK; } static void destroy(cs_struct *handle) { } void Mips_enable(void) { arch_init[CS_ARCH_MIPS] = init; arch_option[CS_ARCH_MIPS] = option; arch_destroy[CS_ARCH_MIPS] = destroy; arch_disallowed_mode_mask[CS_ARCH_MIPS] = ~(CS_MODE_LITTLE_ENDIAN | CS_MODE_32 | CS_MODE_64 | CS_MODE_MICRO | CS_MODE_MIPS32R6 | CS_MODE_MIPSGP64 | CS_MODE_BIG_ENDIAN); // support this arch all_arch |= (1 << CS_ARCH_MIPS); } #endif