/src/capstonenext/arch/Mips/MipsModule.c
Line | Count | Source (jump to first uncovered line) |
1 | | /* Capstone Disassembly Engine */ |
2 | | /* By Dang Hoang Vu <danghvu@gmail.com> 2013 */ |
3 | | |
4 | | #ifdef CAPSTONE_HAS_MIPS |
5 | | |
6 | | #include "../../utils.h" |
7 | | #include "../../MCRegisterInfo.h" |
8 | | #include "MipsDisassembler.h" |
9 | | #include "MipsInstPrinter.h" |
10 | | #include "MipsMapping.h" |
11 | | #include "MipsModule.h" |
12 | | |
13 | | // Returns mode value with implied bits set |
14 | | static cs_mode updated_mode(cs_mode mode) |
15 | 0 | { |
16 | 0 | if (mode & CS_MODE_MIPS32R6) { |
17 | 0 | mode |= CS_MODE_32; |
18 | 0 | } |
19 | |
|
20 | 0 | return mode; |
21 | 0 | } |
22 | | |
23 | | cs_err Mips_global_init(cs_struct *ud) |
24 | 4.47k | { |
25 | 4.47k | MCRegisterInfo *mri; |
26 | 4.47k | mri = cs_mem_malloc(sizeof(*mri)); |
27 | | |
28 | 4.47k | Mips_init(mri); |
29 | 4.47k | ud->printer = Mips_printInst; |
30 | 4.47k | ud->printer_info = mri; |
31 | 4.47k | ud->getinsn_info = mri; |
32 | 4.47k | ud->reg_name = Mips_reg_name; |
33 | 4.47k | ud->insn_id = Mips_get_insn_id; |
34 | 4.47k | ud->insn_name = Mips_insn_name; |
35 | 4.47k | ud->group_name = Mips_group_name; |
36 | | |
37 | 4.47k | ud->disasm = Mips_getInstruction; |
38 | | |
39 | 4.47k | return CS_ERR_OK; |
40 | 4.47k | } |
41 | | |
42 | | cs_err Mips_option(cs_struct *handle, cs_opt_type type, size_t value) |
43 | 1.02k | { |
44 | 1.02k | if (type == CS_OPT_MODE) { |
45 | 0 | handle->mode = updated_mode(value); |
46 | 0 | return CS_ERR_OK; |
47 | 0 | } |
48 | | |
49 | 1.02k | return CS_ERR_OPTION; |
50 | 1.02k | } |
51 | | |
52 | | #endif |