aboutsummaryrefslogtreecommitdiffstats
path: root/capstone/arch/RISCV/RISCVModule.c
blob: cefd4b11a62e60bd75630d12b933201c44b81c02 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
/* Capstone Disassembly Engine */
/* RISC-V Backend By Rodrigo Cortes Porto <porto703@gmail.com> & 
   Shawn Chang <citypw@gmail.com>, HardenedLinux@2018 */

#ifdef CAPSTONE_HAS_RISCV

#include "../../utils.h"
#include "../../MCRegisterInfo.h"
#include "RISCVDisassembler.h"
#include "RISCVInstPrinter.h"
#include "RISCVMapping.h"
#include "RISCVModule.h"

cs_err RISCV_global_init(cs_struct * ud)
{
	MCRegisterInfo *mri;
	mri = cs_mem_malloc(sizeof(*mri));

	RISCV_init(mri);
	ud->printer = RISCV_printInst;
	ud->printer_info = mri;
	ud->getinsn_info = mri;
	ud->disasm = RISCV_getInstruction;
	ud->post_printer = NULL;

	ud->reg_name = RISCV_reg_name;
	ud->insn_id = RISCV_get_insn_id;
	ud->insn_name = RISCV_insn_name;
	ud->group_name = RISCV_group_name;

	return CS_ERR_OK;
}

cs_err RISCV_option(cs_struct * handle, cs_opt_type type, size_t value)
{
	if (type == CS_OPT_SYNTAX)
		handle->syntax = (int)value;

	return CS_ERR_OK;
}

#endif