Merge commit '802798ce3c8baa4697120580f87bc1ee377306d3' as 'external/capstone'
This commit is contained in:
@@ -0,0 +1,53 @@
|
||||
/* Capstone Disassembly Engine */
|
||||
/* TMS320C64x Backend by Fotis Loukos <me@fotisl.com> 2016 */
|
||||
|
||||
#ifdef CAPSTONE_HAS_TMS320C64X
|
||||
|
||||
#include "../../utils.h"
|
||||
#include "../../MCRegisterInfo.h"
|
||||
#include "TMS320C64xDisassembler.h"
|
||||
#include "TMS320C64xInstPrinter.h"
|
||||
#include "TMS320C64xMapping.h"
|
||||
#include "TMS320C64xModule.h"
|
||||
|
||||
cs_err TMS320C64x_global_init(cs_struct *ud)
|
||||
{
|
||||
MCRegisterInfo *mri;
|
||||
|
||||
mri = cs_mem_malloc(sizeof(*mri));
|
||||
if (!mri)
|
||||
return CS_ERR_MEM;
|
||||
|
||||
TMS320C64x_init(mri);
|
||||
ud->printer = TMS320C64x_printInst;
|
||||
ud->printer_info = mri;
|
||||
ud->getinsn_info = mri;
|
||||
ud->disasm = TMS320C64x_getInstruction;
|
||||
ud->post_printer = TMS320C64x_post_printer;
|
||||
|
||||
ud->reg_name = TMS320C64x_reg_name;
|
||||
ud->insn_id = TMS320C64x_get_insn_id;
|
||||
ud->insn_name = TMS320C64x_insn_name;
|
||||
ud->group_name = TMS320C64x_group_name;
|
||||
ud->insn_map = TMS320C64x_insns;
|
||||
ud->insn_map_size = TMS320C64x_insn_count;
|
||||
|
||||
return CS_ERR_OK;
|
||||
}
|
||||
|
||||
cs_err TMS320C64x_option(cs_struct *handle, cs_opt_type type, size_t value)
|
||||
{
|
||||
switch (type) {
|
||||
case CS_OPT_MODE:
|
||||
handle->mode |= (cs_mode)value;
|
||||
break;
|
||||
case CS_OPT_SYNTAX:
|
||||
handle->syntax |= (int)value;
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
return CS_ERR_OK;
|
||||
}
|
||||
|
||||
#endif
|
||||
Reference in New Issue
Block a user