2014-05-14 11:26:41 +08:00
|
|
|
/* Capstone Disassembly Engine */
|
2013-12-21 12:19:44 +08:00
|
|
|
/* By Dang Hoang Vu <danghvu@gmail.com> 2013 */
|
|
|
|
|
2014-05-14 11:26:41 +08:00
|
|
|
#ifdef CAPSTONE_HAS_MIPS
|
|
|
|
|
2014-01-05 11:19:04 +08:00
|
|
|
#include "../../utils.h"
|
2013-12-21 12:19:44 +08:00
|
|
|
#include "../../MCRegisterInfo.h"
|
|
|
|
#include "MipsDisassembler.h"
|
|
|
|
#include "MipsInstPrinter.h"
|
2014-01-20 09:47:21 +08:00
|
|
|
#include "MipsMapping.h"
|
2013-12-21 12:19:44 +08:00
|
|
|
|
2017-10-09 08:44:01 +08:00
|
|
|
|
2013-12-28 14:34:21 +08:00
|
|
|
static cs_err init(cs_struct *ud)
|
2013-12-21 12:19:44 +08:00
|
|
|
{
|
2014-01-23 23:42:40 +08:00
|
|
|
MCRegisterInfo *mri;
|
2014-01-23 01:45:00 +08:00
|
|
|
|
2014-01-21 15:26:02 +08:00
|
|
|
// verify if requested mode is valid
|
|
|
|
if (ud->mode & ~(CS_MODE_LITTLE_ENDIAN | CS_MODE_32 | CS_MODE_64 |
|
2017-06-27 20:56:54 +08:00
|
|
|
CS_MODE_MICRO | CS_MODE_MIPS32R6 | CS_MODE_BIG_ENDIAN |
|
|
|
|
CS_MODE_MIPS2 | CS_MODE_MIPS3))
|
2014-01-21 15:26:02 +08:00
|
|
|
return CS_ERR_MODE;
|
|
|
|
|
2014-01-23 01:45:00 +08:00
|
|
|
mri = cs_mem_malloc(sizeof(*mri));
|
2013-12-21 12:19:44 +08:00
|
|
|
|
|
|
|
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;
|
2014-07-08 08:59:27 +08:00
|
|
|
ud->group_name = Mips_group_name;
|
2017-10-09 08:44:01 +08:00
|
|
|
|
2017-10-09 09:26:41 +08:00
|
|
|
ud->disasm = Mips_getInstruction;
|
2013-12-28 14:34:21 +08:00
|
|
|
|
|
|
|
return CS_ERR_OK;
|
2013-12-21 12:19:44 +08:00
|
|
|
}
|
|
|
|
|
2013-12-22 11:10:56 +08:00
|
|
|
static cs_err option(cs_struct *handle, cs_opt_type type, size_t value)
|
2013-12-21 12:19:44 +08:00
|
|
|
{
|
2015-03-04 13:58:07 +08:00
|
|
|
if (type == CS_OPT_MODE) {
|
|
|
|
handle->mode = (cs_mode)value;
|
2017-02-01 11:17:13 +08:00
|
|
|
handle->big_endian = ((handle->mode & CS_MODE_BIG_ENDIAN) != 0);
|
2015-03-04 13:58:07 +08:00
|
|
|
return CS_ERR_OK;
|
|
|
|
}
|
2014-01-03 17:08:58 +08:00
|
|
|
|
2015-03-04 13:58:07 +08:00
|
|
|
return CS_ERR_OPTION;
|
2014-01-03 17:08:58 +08:00
|
|
|
}
|
|
|
|
|
2014-01-19 12:03:22 +08:00
|
|
|
void Mips_enable(void)
|
2013-12-21 12:19:44 +08:00
|
|
|
{
|
2013-12-22 11:10:56 +08:00
|
|
|
arch_init[CS_ARCH_MIPS] = init;
|
|
|
|
arch_option[CS_ARCH_MIPS] = option;
|
2013-12-22 18:49:22 +08:00
|
|
|
|
|
|
|
// support this arch
|
|
|
|
all_arch |= (1 << CS_ARCH_MIPS);
|
2013-12-21 12:19:44 +08:00
|
|
|
}
|
2014-05-14 11:26:41 +08:00
|
|
|
|
|
|
|
#endif
|