radare2/libr/asm/p/asm_riscv.c
Damien Zammit af0a865d9f WIP - Totally remove host endianness dependence
- Adds endian aware functions
- Removes references to host endian
- Uses binary detected endianness else tries LE and restricts by RAsmPlugin
- Fixes gdb debugger endianness when debugging BE qemu gdbserver

Signed-off-by: Damien Zammit <damien@zamaudio.com>
2016-05-04 23:42:17 +10:00

31 lines
675 B
C

/* radare - LGPL - Copyright 2015-2016 - qnix */
#include <r_types.h>
#include <r_util.h>
#include <r_asm.h>
#include <r_lib.h>
#include "../arch/riscv/riscv-opc.c"
#include "../arch/riscv/riscv.c"
static int disassemble(RAsm *a, RAsmOp *op, const ut8 *buf, int len) {
return op->size = riscv_dis (a, op, buf, len);
}
RAsmPlugin r_asm_plugin_riscv = {
.name = "riscv",
.desc = "RISC-V",
.arch = "riscv",
.bits = 32|64,
.endian = R_SYS_ENDIAN_LITTLE | R_SYS_ENDIAN_BIG,
.license = "GPL",
.disassemble = &disassemble,
};
#ifndef CORELIB
struct r_lib_struct_t radare_plugin = {
.type = R_LIB_TYPE_ASM,
.data = &r_asm_plugin_riscv,
.version = R2_VERSION
};
#endif