2018-08-19 01:24:10 +00:00
|
|
|
/* radare2 - LGPL - Copyright 2014-2018 - pancake */
|
2014-01-15 11:31:57 +00:00
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdarg.h>
|
|
|
|
#include <string.h>
|
|
|
|
|
|
|
|
#include <r_types.h>
|
|
|
|
#include <r_lib.h>
|
|
|
|
#include <r_util.h>
|
|
|
|
#include <r_asm.h>
|
|
|
|
|
2018-08-04 19:43:57 +00:00
|
|
|
#include "disas-asm.h"
|
2014-01-15 11:31:57 +00:00
|
|
|
|
|
|
|
|
2014-05-17 02:27:49 +00:00
|
|
|
int print_insn_big_nios2 (bfd_vma address, disassemble_info *info);
|
|
|
|
int print_insn_little_nios2 (bfd_vma address, disassemble_info *info);
|
2014-01-15 11:31:57 +00:00
|
|
|
static unsigned long Offset = 0;
|
2018-09-23 10:13:34 +00:00
|
|
|
static RStrBuf *buf_global = NULL;
|
2014-01-15 11:31:57 +00:00
|
|
|
static unsigned char bytes[4];
|
|
|
|
|
2014-01-15 21:44:14 +00:00
|
|
|
static int nios2_buffer_read_memory (bfd_vma memaddr, bfd_byte *myaddr, ut32 length, struct disassemble_info *info) {
|
2014-01-15 11:31:57 +00:00
|
|
|
memcpy (myaddr, bytes, length);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int symbol_at_address(bfd_vma addr, struct disassemble_info * info) {
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void memory_error_func(int status, bfd_vma memaddr, struct disassemble_info *info) {
|
|
|
|
//--
|
|
|
|
}
|
|
|
|
|
2018-09-23 10:13:34 +00:00
|
|
|
DECLARE_GENERIC_PRINT_ADDRESS_FUNC()
|
|
|
|
DECLARE_GENERIC_FPRINTF_FUNC()
|
2014-01-15 11:31:57 +00:00
|
|
|
|
|
|
|
static int disassemble(RAsm *a, struct r_asm_op_t *op, const ut8 *buf, int len) {
|
2014-01-15 21:44:14 +00:00
|
|
|
struct disassemble_info disasm_obj;
|
2018-08-19 01:24:10 +00:00
|
|
|
if (len < 4) {
|
2014-01-15 11:31:57 +00:00
|
|
|
return -1;
|
2018-08-19 01:24:10 +00:00
|
|
|
}
|
2018-09-23 10:13:34 +00:00
|
|
|
buf_global = &op->buf_asm;
|
2014-01-15 11:31:57 +00:00
|
|
|
Offset = a->pc;
|
|
|
|
memcpy (bytes, buf, 4); // TODO handle thumb
|
|
|
|
|
|
|
|
/* prepare disassembler */
|
|
|
|
memset (&disasm_obj, '\0', sizeof (struct disassemble_info));
|
|
|
|
disasm_obj.disassembler_options = "";
|
|
|
|
disasm_obj.buffer = bytes;
|
2014-01-15 21:44:14 +00:00
|
|
|
disasm_obj.read_memory_func = &nios2_buffer_read_memory;
|
2014-01-15 11:31:57 +00:00
|
|
|
disasm_obj.symbol_at_address_func = &symbol_at_address;
|
|
|
|
disasm_obj.memory_error_func = &memory_error_func;
|
2018-09-23 10:13:34 +00:00
|
|
|
disasm_obj.print_address_func = &generic_print_address_func;
|
2014-01-15 11:31:57 +00:00
|
|
|
disasm_obj.endian = !a->big_endian;
|
2018-09-23 10:13:34 +00:00
|
|
|
disasm_obj.fprintf_func = &generic_fprintf_func;
|
2014-01-15 11:31:57 +00:00
|
|
|
disasm_obj.stream = stdout;
|
|
|
|
|
2018-08-19 01:24:10 +00:00
|
|
|
if (disasm_obj.endian == BFD_ENDIAN_BIG) {
|
2014-01-15 11:31:57 +00:00
|
|
|
op->size = print_insn_big_nios2 ((bfd_vma)Offset, &disasm_obj);
|
2018-08-19 01:24:10 +00:00
|
|
|
} else {
|
|
|
|
op->size = print_insn_little_nios2 ((bfd_vma)Offset, &disasm_obj);
|
|
|
|
}
|
|
|
|
if (op->size == -1) {
|
|
|
|
r_asm_op_set_asm (op, "(data)");
|
|
|
|
}
|
2014-01-15 11:31:57 +00:00
|
|
|
return op->size;
|
|
|
|
}
|
|
|
|
|
2014-01-15 21:44:14 +00:00
|
|
|
RAsmPlugin r_asm_plugin_nios2 = {
|
|
|
|
.name = "nios2",
|
|
|
|
.arch = "nios2",
|
2014-01-15 11:31:57 +00:00
|
|
|
.license = "GPL3",
|
|
|
|
.bits = 32,
|
2016-04-26 09:09:15 +00:00
|
|
|
.endian = R_SYS_ENDIAN_LITTLE | R_SYS_ENDIAN_BIG,
|
2014-02-25 16:03:12 +00:00
|
|
|
.desc = "NIOS II Embedded Processor",
|
2016-04-26 09:09:15 +00:00
|
|
|
.disassemble = &disassemble
|
2014-01-15 11:31:57 +00:00
|
|
|
};
|
|
|
|
|
2019-06-13 17:12:51 +00:00
|
|
|
#ifndef R2_PLUGIN_INCORE
|
2018-09-15 20:52:12 +00:00
|
|
|
R_API RLibStruct radare_plugin = {
|
2014-01-15 11:31:57 +00:00
|
|
|
.type = R_LIB_TYPE_ASM,
|
2015-07-12 14:04:10 +00:00
|
|
|
.data = &r_asm_plugin_nios2,
|
|
|
|
.version = R2_VERSION
|
2014-01-15 11:31:57 +00:00
|
|
|
};
|
|
|
|
#endif
|