Merge asm_rsp into anal_rsp ##refactor

This commit is contained in:
condret 2022-06-30 18:25:23 +02:00
parent 39cd506acf
commit e9e427876f
16 changed files with 90 additions and 147 deletions

View File

@ -81,7 +81,6 @@ asm.or1k
asm.ppc_as
asm.ppc_cs
asm.riscv
asm.rsp
asm.lanai_gnu
asm.sh
asm.sparc_gnu

View File

@ -73,7 +73,6 @@ asm.or1k
asm.ppc_as
asm.ppc_cs
asm.riscv
asm.rsp
asm.lanai_gnu
asm.sh
asm.sparc_gnu

View File

@ -59,7 +59,6 @@ asm.mips_gnu
asm.or1k
asm.ppc_as
asm.riscv
asm.rsp
asm.lanai_gnu
asm.sh
asm.sparc_gnu

View File

@ -48,7 +48,6 @@ asm.mips_gnu
asm.ppc_as
asm.ppc_cs
asm.riscv
asm.rsp
asm.sparc_gnu
asm.tms320
asm.m68k_gnu

View File

@ -309,3 +309,4 @@ Process[15449] crashed: radare2. Too many corpses being created.
You can't sleep now there are monsters nearby
Every journey begins with a choice
Do 'r2pm -i r2premium; echo "e cfg.fortunes.type = nsfw" >> ~/.radare2rc' for a even more fun with r2
pneumonic

View File

@ -152,7 +152,7 @@ r_anal_sources = [
join_paths('../asm/arch','ppc','gnu','ppc-opc.c'),
# join_paths('arch','ppc','libvle','vle.c'),
# join_paths('arch','ppc','libps','libps.c'),
join_paths('..','asm','arch','rsp','rsp_idec.c'),
join_paths('arch','rsp','rsp_idec.c'),
join_paths('..','asm','arch','tms320','tms320_dasm.c'),
join_paths('..','asm','arch','tms320','c55x_plus','ins.c'),
join_paths('..','asm','arch','tms320','c55x_plus','c55plus.c'),
@ -177,7 +177,8 @@ r_anal_sources = [
incdirs = [
join_paths ('arch', 'gb'),
join_paths ('arch', 'kvx'),
join_paths ('arch', 'propeller')
join_paths ('arch', 'propeller'),
'arch'
]
if get_option('use_v35')

View File

@ -1,19 +1,89 @@
/* radare - LGPL - Copyright 2016-2017 - bobby.smiles32@gmail.com */
/* radare - LGPL - Copyright 2016-2022 - bobby.smiles32@gmail.com, condret */
/*
* TODO: finish esil support of the non vector instructions
* TODO: implement vector instruction using custom esil commands
* (will be easier than pure esil approach)
* TODO: refactor code to simplify per opcode analysis
*/
#include <string.h>
#include <r_types.h>
#include <r_lib.h>
#include <r_asm.h>
#include <r_anal.h>
#include "../../asm/arch/rsp/rsp_idec.h"
#include <rsp/rsp_idec.h>
static RStrBuf *disassemble(RStrBuf *buf_asm, rsp_instruction *r_instr) {
int i;
r_strbuf_append (buf_asm, r_instr->mnemonic);
for (i = 0; i < r_instr->noperands; i++) {
r_strbuf_append (buf_asm, (i == 0) ? " " : ", ");
switch (r_instr->operands[i].type) {
case RSP_OPND_GP_REG:
r_strbuf_append (buf_asm, rsp_gp_reg_soft_names[r_instr->operands[i].u]);
break;
case RSP_OPND_OFFSET:
case RSP_OPND_TARGET:
r_strbuf_appendf (buf_asm, "0x%08"PFMT64x, r_instr->operands[i].u);
break;
case RSP_OPND_ZIMM:
{
int shift = (r_instr->operands[i].u & ~0xffff) ? 16 : 0;
r_strbuf_appendf (buf_asm, "0x%04"PFMT64x,
r_instr->operands[i].u >> shift);
}
break;
case RSP_OPND_SIMM:
r_strbuf_appendf (buf_asm, "%s0x%04"PFMT64x,
(r_instr->operands[i].s<0)?"-":"",
(r_instr->operands[i].s<0)?-r_instr->operands[i].s:r_instr->operands[i].s);
break;
case RSP_OPND_SHIFT_AMOUNT:
r_strbuf_appendf (buf_asm, "%"PFMT64u, r_instr->operands[i].u);
break;
case RSP_OPND_BASE_OFFSET:
r_strbuf_appendf (buf_asm, "%s0x%04x(%s)",
(r_instr->operands[i].s<0)?"-":"",
(ut32)((r_instr->operands[i].s<0)?-r_instr->operands[i].s:r_instr->operands[i].s),
rsp_gp_reg_soft_names[r_instr->operands[i].u]);
break;
case RSP_OPND_C0_REG:
r_strbuf_append (buf_asm, rsp_c0_reg_soft_names[r_instr->operands[i].u]);
break;
case RSP_OPND_C2_CREG:
r_strbuf_append (buf_asm, rsp_c2_creg_names[r_instr->operands[i].u]);
break;
case RSP_OPND_C2_ACCU:
r_strbuf_append (buf_asm, rsp_c2_accu_names[r_instr->operands[i].u]);
break;
case RSP_OPND_C2_VREG:
r_strbuf_append (buf_asm, rsp_c2_vreg_names[r_instr->operands[i].u]);
break;
case RSP_OPND_C2_VREG_BYTE:
case RSP_OPND_C2_VREG_SCALAR:
r_strbuf_appendf (buf_asm, "%s[%u]", rsp_c2_vreg_names[r_instr->operands[i].u],
(ut32)r_instr->operands[i].s);
break;
case RSP_OPND_C2_VREG_ELEMENT:
r_strbuf_appendf (buf_asm, "%s%s", rsp_c2_vreg_names[r_instr->operands[i].u],
rsp_c2_vreg_element_names[r_instr->operands[i].s]);
break;
default: /* should not happend */
r_strbuf_append (buf_asm, "invalid");
break;
}
}
return buf_asm;
}
static int rsp_op(RAnal *anal, RAnalOp *op, ut64 addr, const ut8 *b, int len, RAnalOpMask mask) {
if (len < 4) {
op->type = R_ANAL_OP_TYPE_ILL;
if (mask & R_ANAL_OP_MASK_DISASM) {
op->mnemonic = strdup ("invalid");
}
return op->size = 0;
}
int i;
typedef struct {
RAnalValue* value;
@ -24,10 +94,6 @@ static int rsp_op(RAnal *anal, RAnalOp *op, ut64 addr, const ut8 *b, int len, RA
memset (parsed_operands, 0, sizeof (ParsedOperands) * RSP_MAX_OPNDS);
rsp_instruction r_instr;
if (!op) {
return 4;
}
op->type = R_ANAL_OP_TYPE_UNK;
op->size = 4;
op->addr = addr;
@ -36,6 +102,13 @@ static int rsp_op(RAnal *anal, RAnalOp *op, ut64 addr, const ut8 *b, int len, RA
ut32 iw = r_read_ble32 (b, anal->config->big_endian);
r_instr = rsp_instruction_decode (addr, iw);
if (mask & R_ANAL_OP_MASK_DISASM) {
RStrBuf *buf_asm = r_strbuf_new ("");
if (buf_asm) {
op->mnemonic = r_strbuf_drain (disassemble (buf_asm, &r_instr));
} // else ???
}
/* parse operands */
for (i = 0; i < r_instr.noperands; i++) {
parsed_operands[i].value = r_anal_value_new ();

View File

@ -1,9 +1,9 @@
OBJ_RSP=anal_rsp.o
#RSP_ROOT=$(LIBR)/asm/arch/rsp
CFLAGS+=-I../asm/arch/rsp
CFLAGS+=-Iarch
STATIC_OBJ+=${OBJ_RSP}
OBJ_RSP+=../../asm/arch/rsp/rsp_idec.o
OBJ_RSP+=../arch/rsp/rsp_idec.o
TARGET_RSP=anal_rsp.${EXT_SO}
ALL_TARGETS+=${TARGET_RSP}

View File

@ -24,7 +24,6 @@ r_asm_sources = [
join_paths('p','asm_ppc_as.c'),
join_paths('p','asm_ppc_cs.c'),
join_paths('p','asm_riscv.c'),
join_paths('p','asm_rsp.c'),
join_paths('p','asm_sh.c'),
join_paths('p','asm_sparc_gnu.c'),
join_paths('p','asm_tms320.c'),
@ -72,7 +71,6 @@ r_asm_sources = [
join_paths('arch','or1k','or1k_disas.c'),
#join_paths('arch','riscv','riscv-opc.c'),
#join_paths('arch','riscv','riscv.c'),
join_paths('arch','rsp','rsp_idec.c'),
join_paths('arch','sh','gnu','sh-dis.c'),
join_paths('arch','sparc','gnu','sparc-dis.c'),
join_paths('arch','sparc','gnu','sparc-opc.c'),
@ -100,7 +98,6 @@ r_asm_inc = [
join_paths('arch','include'),
join_paths('arch'),
join_paths('arch','h8300'),
join_paths('arch','rsp'),
join_paths('arch','v850'),
join_paths('arch','v810'),
join_paths('arch','or1k')

View File

@ -21,9 +21,8 @@ ARCHS=mips_gnu.mk x86_cs.mk sparc_gnu.mk java.mk arm_gnu.mk dalvik.mk
ARCHS+=x86_as.mk x86_nz.mk cris_gnu.mk arc.mk
ARCHS+=ppc_gnu.mk ppc_as.mk ppc_cs.mk x86_nasm.mk avr.mk
ARCHS+=sh.mk arm_winedbg.mk tms320.mk ebc.mk
ARCHS+=cr16.mk v850.mk jdh8.mk
ARCHS+=v810.mk mcs96.mk lm32.mk
ARCHS+=riscv.mk rsp.mk mcore.mk
ARCHS+=cr16.mk v850.mk jdh8.mk riscv.mk
ARCHS+=v810.mk lm32.mk mcore.mk
# ARCHS+=loongarch_gnu.mk
include $(ARCHS)

View File

@ -1,107 +0,0 @@
/* radare - LGPL - Copyright 2016 - bobby.smiles32@gmail.com */
// TODO: add assembler
#include <r_types.h>
#include <r_util.h>
#include <r_asm.h>
#include <r_lib.h>
#include <stdarg.h>
#include <stdio.h>
#include "rsp_idec.h"
static int disassemble(RAsm *a, RAsmOp *op, const ut8 *buf, int len) {
rsp_instruction r_instr;
int i;
/* all instructions are 32bit words */
if (len < 4) {
op->size = 0;
return 0;
}
op->size = 4;
ut32 iw = r_read_ble32 (buf, a->config->big_endian);
r_instr = rsp_instruction_decode (a->pc, iw);
r_strbuf_append (&op->buf_asm, r_instr.mnemonic);
for (i = 0; i < r_instr.noperands; i++) {
r_strbuf_append (&op->buf_asm, (i == 0) ? " " : ", ");
switch (r_instr.operands[i].type) {
case RSP_OPND_GP_REG:
r_strbuf_append (&op->buf_asm, rsp_gp_reg_soft_names[r_instr.operands[i].u]);
break;
case RSP_OPND_OFFSET:
case RSP_OPND_TARGET:
r_strbuf_appendf (&op->buf_asm, "0x%08"PFMT64x, r_instr.operands[i].u);
break;
case RSP_OPND_ZIMM:
{
int shift = (r_instr.operands[i].u & ~0xffff) ? 16 : 0;
r_strbuf_appendf (&op->buf_asm, "0x%04"PFMT64x,
r_instr.operands[i].u >> shift);
}
break;
case RSP_OPND_SIMM:
r_strbuf_appendf (&op->buf_asm, "%s0x%04"PFMT64x,
(r_instr.operands[i].s<0)?"-":"",
(r_instr.operands[i].s<0)?-r_instr.operands[i].s:r_instr.operands[i].s);
break;
case RSP_OPND_SHIFT_AMOUNT:
r_strbuf_appendf (&op->buf_asm, "%"PFMT64u, r_instr.operands[i].u);
break;
case RSP_OPND_BASE_OFFSET:
r_strbuf_appendf (&op->buf_asm, "%s0x%04x(%s)",
(r_instr.operands[i].s<0)?"-":"",
(ut32)((r_instr.operands[i].s<0)?-r_instr.operands[i].s:r_instr.operands[i].s),
rsp_gp_reg_soft_names[r_instr.operands[i].u]);
break;
case RSP_OPND_C0_REG:
r_strbuf_append (&op->buf_asm, rsp_c0_reg_soft_names[r_instr.operands[i].u]);
break;
case RSP_OPND_C2_CREG:
r_strbuf_append (&op->buf_asm, rsp_c2_creg_names[r_instr.operands[i].u]);
break;
case RSP_OPND_C2_ACCU:
r_strbuf_append (&op->buf_asm, rsp_c2_accu_names[r_instr.operands[i].u]);
break;
case RSP_OPND_C2_VREG:
r_strbuf_append (&op->buf_asm, rsp_c2_vreg_names[r_instr.operands[i].u]);
break;
case RSP_OPND_C2_VREG_BYTE:
case RSP_OPND_C2_VREG_SCALAR:
r_strbuf_appendf (&op->buf_asm, "%s[%u]", rsp_c2_vreg_names[r_instr.operands[i].u],
(ut32)r_instr.operands[i].s);
break;
case RSP_OPND_C2_VREG_ELEMENT:
r_strbuf_appendf (&op->buf_asm, "%s%s", rsp_c2_vreg_names[r_instr.operands[i].u], rsp_c2_vreg_element_names[r_instr.operands[i].s]);
break;
default: /* should not happend */
r_strbuf_append (&op->buf_asm, "???");
break;
}
}
return op->size;
}
RAsmPlugin r_asm_plugin_rsp = {
.name = "rsp",
.desc = "Reality Signal Processor",
.arch = "rsp",
.bits = 32,
.endian = R_SYS_ENDIAN_BI, /* For conveniance, we don't force BIG endian but allow both to be used */
.license = "LGPL3",
.disassemble = &disassemble
};
#ifndef R2_PLUGIN_INCORE
R_API RLibStruct radare_plugin = {
.type = R_LIB_TYPE_ASM,
.data = &r_asm_plugin_rsp,
.version = R2_VERSION
};
#endif

View File

@ -1,15 +0,0 @@
OBJ_RSP=asm_rsp.o
RSP_ROOT=$(LIBR)/asm/arch/rsp
OBJ_RSP+=$(RSP_ROOT)/rsp_idec.o
CFLAGS+=-I$(RSP_ROOT)
STATIC_OBJ+=${OBJ_RSP}
TARGET_RSP=asm_rsp.${EXT_SO}
ifeq ($(WITHPIC),1)
ALL_TARGETS+=${TARGET_RSP}
${TARGET_RSP}: ${OBJ_RSP}
${CC} $(call libname,asm_rsp) ${LDFLAGS} ${CFLAGS} -o ${TARGET_RSP} ${OBJ_RSP}
endif

View File

@ -205,7 +205,6 @@ extern RAsmPlugin r_asm_plugin_pic;
extern RAsmPlugin r_asm_plugin_ppc_as;
extern RAsmPlugin r_asm_plugin_ppc_cs;
extern RAsmPlugin r_asm_plugin_riscv;
extern RAsmPlugin r_asm_plugin_rsp;
extern RAsmPlugin r_asm_plugin_sh;
extern RAsmPlugin r_asm_plugin_sparc_gnu;
extern RAsmPlugin r_asm_plugin_tms320;

View File

@ -136,7 +136,6 @@ asm_plugins += [
'ppc_as',
'ppc_cs',
'riscv',
'rsp',
'sh',
'tms320',
'x86_as',