[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v3 20/24] disas/nanomips: Expand Dis_info struct
From: |
Milica Lazarevic |
Subject: |
[PATCH v3 20/24] disas/nanomips: Expand Dis_info struct |
Date: |
Mon, 12 Sep 2022 14:26:31 +0200 |
This patch expands the Dis_info struct, which should hold the
necessary data for handling runtime errors. Fields fprintf_func and
stream are in charge of error printing. Field buf enables the use of
sigsetjmp() and siglongjmp() functions. Support for runtime error
handling will be added later.
We're filling Dis_info at the entrance of the nanoMIPS disassembler,
i.e. print_insn_nanomips. Next, we're adding that information as an
argument wherever we need to.
Signed-off-by: Milica Lazarevic <milica.lazarevic@syrmia.com>
---
disas/nanomips.cpp | 2708 ++++++++++++++++++++++----------------------
1 file changed, 1357 insertions(+), 1351 deletions(-)
diff --git a/disas/nanomips.cpp b/disas/nanomips.cpp
index 132cf89f6c..077dfe0dea 100644
--- a/disas/nanomips.cpp
+++ b/disas/nanomips.cpp
@@ -72,6 +72,9 @@ enum TABLE_ATTRIBUTE_TYPE {
typedef struct Dis_info {
img_address m_pc;
+ fprintf_function fprintf_func;
+ FILE *stream;
+ sigjmp_buf buf;
} Dis_info;
typedef bool (*conditional_function)(uint64 instruction);
@@ -124,7 +127,7 @@ static int64 sign_extend(int64 data, int msb)
static uint64 renumber_registers(uint64 index, uint64 *register_list,
- size_t register_list_size)
+ size_t register_list_size, Dis_info *info)
{
if (index < register_list_size) {
return register_list[index];
@@ -163,12 +166,12 @@ static uint64 renumber_registers(uint64 index, uint64
*register_list,
* - MUL[4X4]
* - SW[4X4]
*/
-static uint64 decode_gpr_gpr4(uint64 d)
+static uint64 decode_gpr_gpr4(uint64 d, Dis_info *info)
{
static uint64 register_list[] = { 8, 9, 10, 11, 4, 5, 6, 7,
16, 17, 18, 19, 20, 21, 22, 23 };
return renumber_registers(d, register_list,
- sizeof(register_list) / sizeof(register_list[0]));
+ sizeof(register_list) / sizeof(register_list[0]), info);
}
@@ -199,12 +202,12 @@ static uint64 decode_gpr_gpr4(uint64 d)
* - MOVEP
* - SW[4X4]
*/
-static uint64 decode_gpr_gpr4_zero(uint64 d)
+static uint64 decode_gpr_gpr4_zero(uint64 d, Dis_info *info)
{
static uint64 register_list[] = { 8, 9, 10, 0, 4, 5, 6, 7,
16, 17, 18, 19, 20, 21, 22, 23 };
return renumber_registers(d, register_list,
- sizeof(register_list) / sizeof(register_list[0]));
+ sizeof(register_list) / sizeof(register_list[0]), info);
}
@@ -258,11 +261,11 @@ static uint64 decode_gpr_gpr4_zero(uint64 d)
* - SW[16]
* - XOR[16]
*/
-static uint64 decode_gpr_gpr3(uint64 d)
+static uint64 decode_gpr_gpr3(uint64 d, Dis_info *info)
{
static uint64 register_list[] = { 16, 17, 18, 19, 4, 5, 6, 7 };
return renumber_registers(d, register_list,
- sizeof(register_list) / sizeof(register_list[0]));
+ sizeof(register_list) / sizeof(register_list[0]), info);
}
@@ -298,11 +301,11 @@ static uint64 decode_gpr_gpr3(uint64 d)
* - SW[16]
* - SW[GP16]
*/
-static uint64 decode_gpr_gpr3_src_store(uint64 d)
+static uint64 decode_gpr_gpr3_src_store(uint64 d, Dis_info *info)
{
static uint64 register_list[] = { 0, 17, 18, 19, 4, 5, 6, 7 };
return renumber_registers(d, register_list,
- sizeof(register_list) / sizeof(register_list[0]));
+ sizeof(register_list) / sizeof(register_list[0]), info);
}
@@ -328,11 +331,11 @@ static uint64 decode_gpr_gpr3_src_store(uint64 d)
* - MOVEP
* - MOVEP[REV]
*/
-static uint64 decode_gpr_gpr2_reg1(uint64 d)
+static uint64 decode_gpr_gpr2_reg1(uint64 d, Dis_info *info)
{
static uint64 register_list[] = { 4, 5, 6, 7 };
return renumber_registers(d, register_list,
- sizeof(register_list) / sizeof(register_list[0]));
+ sizeof(register_list) / sizeof(register_list[0]), info);
}
@@ -358,11 +361,11 @@ static uint64 decode_gpr_gpr2_reg1(uint64 d)
* - MOVEP
* - MOVEP[REV]
*/
-static uint64 decode_gpr_gpr2_reg2(uint64 d)
+static uint64 decode_gpr_gpr2_reg2(uint64 d, Dis_info *info)
{
static uint64 register_list[] = { 5, 6, 7, 8 };
return renumber_registers(d, register_list,
- sizeof(register_list) / sizeof(register_list[0]));
+ sizeof(register_list) / sizeof(register_list[0]), info);
}
@@ -387,11 +390,11 @@ static uint64 decode_gpr_gpr2_reg2(uint64 d)
*
* - MOVE.BALC
*/
-static uint64 decode_gpr_gpr1(uint64 d)
+static uint64 decode_gpr_gpr1(uint64 d, Dis_info *info)
{
static uint64 register_list[] = { 4, 5 };
return renumber_registers(d, register_list,
- sizeof(register_list) / sizeof(register_list[0]));
+ sizeof(register_list) / sizeof(register_list[0]), info);
}
@@ -450,7 +453,7 @@ static uint64 encode_rt1_from_rt(uint64 d)
}
-static const char *GPR(uint64 reg)
+static const char *GPR(uint64 reg, Dis_info *info)
{
static const char *gpr_reg[32] = {
"zero", "at", "v0", "v1", "a0", "a1", "a2", "a3",
@@ -468,7 +471,8 @@ static const char *GPR(uint64 reg)
}
-static char *save_restore_list(uint64 rt, uint64 count, uint64 gp)
+static char *save_restore_list(uint64 rt, uint64 count, uint64 gp,
+ Dis_info *info)
{
char *reg_list[34];
reg_list[0] = (char *)"";
@@ -478,7 +482,7 @@ static char *save_restore_list(uint64 rt, uint64 count,
uint64 gp)
bool use_gp = gp && (counter == count - 1);
uint64 this_rt = use_gp ? 28 : ((rt & 0x10) | (rt + counter)) & 0x1f;
/* glib usage below requires casting away const */
- reg_list[counter + 1] = (char *)GPR(this_rt);
+ reg_list[counter + 1] = (char *)GPR(this_rt, info);
}
reg_list[count + 1] = NULL;
@@ -486,7 +490,7 @@ static char *save_restore_list(uint64 rt, uint64 count,
uint64 gp)
}
-static const char *FPR(uint64 reg)
+static const char *FPR(uint64 reg, Dis_info *info)
{
static const char *fpr_reg[32] = {
"f0", "f1", "f2", "f3", "f4", "f5", "f6", "f7",
@@ -504,7 +508,7 @@ static const char *FPR(uint64 reg)
}
-static const char *AC(uint64 reg)
+static const char *AC(uint64 reg, Dis_info *info)
{
static const char *ac_reg[4] = {
"ac0", "ac1", "ac2", "ac3"
@@ -1545,8 +1549,8 @@ static char *ABS_D(uint64 instruction, Dis_info *info)
uint64 fd_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *fs = FPR(fs_value);
- const char *fd = FPR(fd_value);
+ const char *fs = FPR(fs_value, info);
+ const char *fd = FPR(fd_value, info);
return img_format("ABS.D %s, %s", fd, fs);
}
@@ -1567,8 +1571,8 @@ static char *ABS_S(uint64 instruction, Dis_info *info)
uint64 fd_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *fs = FPR(fs_value);
- const char *fd = FPR(fd_value);
+ const char *fs = FPR(fs_value, info);
+ const char *fd = FPR(fd_value, info);
return img_format("ABS.S %s, %s", fd, fs);
}
@@ -1589,8 +1593,8 @@ static char *ABSQ_S_PH(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("ABSQ_S.PH %s, %s", rt, rs);
}
@@ -1611,8 +1615,8 @@ static char *ABSQ_S_QB(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("ABSQ_S.QB %s, %s", rt, rs);
}
@@ -1633,8 +1637,8 @@ static char *ABSQ_S_W(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("ABSQ_S.W %s, %s", rt, rs);
}
@@ -1655,7 +1659,7 @@ static char *ACLR(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
- const char *rs = GPR(rs_value);
+ const char *rs = GPR(rs_value, info);
return img_format("ACLR 0x%" PRIx64 ", %" PRId64 "(%s)",
bit_value, s_value, rs);
@@ -1677,9 +1681,9 @@ static char *ADD(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("ADD %s, %s, %s", rd, rs, rt);
}
@@ -1702,9 +1706,9 @@ static char *ADD_D(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
- const char *fd = FPR(fd_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *fd = FPR(fd_value, info);
return img_format("ADD.D %s, %s, %s", fd, fs, ft);
}
@@ -1727,9 +1731,9 @@ static char *ADD_S(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
- const char *fd = FPR(fd_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *fd = FPR(fd_value, info);
return img_format("ADD.S %s, %s, %s", fd, fs, ft);
}
@@ -1750,8 +1754,8 @@ static char *ADDIU_32_(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 u_value = extract_u_15_to_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("ADDIU %s, %s, 0x%" PRIx64, rt, rs, u_value);
}
@@ -1771,7 +1775,7 @@ static char *ADDIU_48_(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_41_40_39_38_37(instruction);
int64 s_value = extract_s__se31_15_to_0_31_to_16(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("ADDIU %s, %" PRId64, rt, s_value);
}
@@ -1791,7 +1795,7 @@ static char *ADDIU_GP48_(uint64 instruction, Dis_info
*info)
uint64 rt_value = extract_rt_41_40_39_38_37(instruction);
int64 s_value = extract_s__se31_15_to_0_31_to_16(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("ADDIU %s, $%d, %" PRId64, rt, 28, s_value);
}
@@ -1811,7 +1815,7 @@ static char *ADDIU_GP_B_(uint64 instruction, Dis_info
*info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 u_value = extract_u_17_to_0(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("ADDIU %s, $%d, 0x%" PRIx64, rt, 28, u_value);
}
@@ -1831,7 +1835,7 @@ static char *ADDIU_GP_W_(uint64 instruction, Dis_info
*info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 u_value = extract_u_20_to_2__s2(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("ADDIU %s, $%d, 0x%" PRIx64, rt, 28, u_value);
}
@@ -1852,8 +1856,8 @@ static char *ADDIU_NEG_(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
int64 u = neg_copy(u_value);
return img_format("ADDIU %s, %s, %" PRId64, rt, rs, u);
@@ -1874,7 +1878,7 @@ static char *ADDIU_R1_SP_(uint64 instruction, Dis_info
*info)
uint64 u_value = extract_u_5_4_3_2_1_0__s2(instruction);
uint64 rt3_value = extract_rt3_9_8_7(instruction);
- const char *rt3 = GPR(decode_gpr_gpr3(rt3_value));
+ const char *rt3 = GPR(decode_gpr_gpr3(rt3_value, info), info);
return img_format("ADDIU %s, $%d, 0x%" PRIx64, rt3, 29, u_value);
}
@@ -1895,8 +1899,8 @@ static char *ADDIU_R2_(uint64 instruction, Dis_info *info)
uint64 rs3_value = extract_rs3_6_5_4(instruction);
uint64 u_value = extract_u_2_1_0__s2(instruction);
- const char *rt3 = GPR(decode_gpr_gpr3(rt3_value));
- const char *rs3 = GPR(decode_gpr_gpr3(rs3_value));
+ const char *rt3 = GPR(decode_gpr_gpr3(rt3_value, info), info);
+ const char *rs3 = GPR(decode_gpr_gpr3(rs3_value, info), info);
return img_format("ADDIU %s, %s, 0x%" PRIx64, rt3, rs3, u_value);
}
@@ -1915,7 +1919,7 @@ static char *ADDIU_RS5_(uint64 instruction, Dis_info
*info)
uint64 rt_value = extract_rt_9_8_7_6_5(instruction);
int64 s_value = extract_s__se3_4_2_1_0(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("ADDIU %s, %" PRId64, rt, s_value);
}
@@ -1936,7 +1940,7 @@ static char *ADDIUPC_32_(uint64 instruction, Dis_info
*info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
int64 s_value = extract_s__se21_0_20_to_1_s1(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
g_autofree char *s = ADDRESS(s_value, 4, info);
return img_format("ADDIUPC %s, %s", rt, s);
@@ -1958,7 +1962,7 @@ static char *ADDIUPC_48_(uint64 instruction, Dis_info
*info)
uint64 rt_value = extract_rt_41_40_39_38_37(instruction);
int64 s_value = extract_s__se31_15_to_0_31_to_16(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
g_autofree char *s = ADDRESS(s_value, 6, info);
return img_format("ADDIUPC %s, %s", rt, s);
@@ -1981,9 +1985,9 @@ static char *ADDQ_PH(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("ADDQ.PH %s, %s, %s", rd, rs, rt);
}
@@ -2006,9 +2010,9 @@ static char *ADDQ_S_PH(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("ADDQ_S.PH %s, %s, %s", rd, rs, rt);
}
@@ -2030,9 +2034,9 @@ static char *ADDQ_S_W(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("ADDQ_S.W %s, %s, %s", rd, rs, rt);
}
@@ -2055,9 +2059,9 @@ static char *ADDQH_PH(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("ADDQH.PH %s, %s, %s", rd, rs, rt);
}
@@ -2080,9 +2084,9 @@ static char *ADDQH_R_PH(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("ADDQH_R.PH %s, %s, %s", rd, rs, rt);
}
@@ -2105,9 +2109,9 @@ static char *ADDQH_R_W(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("ADDQH_R.W %s, %s, %s", rd, rs, rt);
}
@@ -2130,9 +2134,9 @@ static char *ADDQH_W(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("ADDQH.W %s, %s, %s", rd, rs, rt);
}
@@ -2154,9 +2158,9 @@ static char *ADDSC(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("ADDSC %s, %s, %s", rd, rs, rt);
}
@@ -2177,9 +2181,9 @@ static char *ADDU_16_(uint64 instruction, Dis_info *info)
uint64 rs3_value = extract_rs3_6_5_4(instruction);
uint64 rd3_value = extract_rd3_3_2_1(instruction);
- const char *rt3 = GPR(decode_gpr_gpr3(rt3_value));
- const char *rs3 = GPR(decode_gpr_gpr3(rs3_value));
- const char *rd3 = GPR(decode_gpr_gpr3(rd3_value));
+ const char *rt3 = GPR(decode_gpr_gpr3(rt3_value, info), info);
+ const char *rs3 = GPR(decode_gpr_gpr3(rs3_value, info), info);
+ const char *rd3 = GPR(decode_gpr_gpr3(rd3_value, info), info);
return img_format("ADDU %s, %s, %s", rd3, rs3, rt3);
}
@@ -2201,9 +2205,9 @@ static char *ADDU_32_(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("ADDU %s, %s, %s", rd, rs, rt);
}
@@ -2224,8 +2228,8 @@ static char *ADDU_4X4_(uint64 instruction, Dis_info *info)
uint64 rt4_value = extract_rt4_9_7_6_5(instruction);
uint64 rs4_value = extract_rs4_4_2_1_0(instruction);
- const char *rs4 = GPR(decode_gpr_gpr4(rs4_value));
- const char *rt4 = GPR(decode_gpr_gpr4(rt4_value));
+ const char *rs4 = GPR(decode_gpr_gpr4(rs4_value, info), info);
+ const char *rt4 = GPR(decode_gpr_gpr4(rt4_value, info), info);
return img_format("ADDU %s, %s", rs4, rt4);
}
@@ -2247,9 +2251,9 @@ static char *ADDU_PH(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("ADDU.PH %s, %s, %s", rd, rs, rt);
}
@@ -2271,9 +2275,9 @@ static char *ADDU_QB(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("ADDU.QB %s, %s, %s", rd, rs, rt);
}
@@ -2296,9 +2300,9 @@ static char *ADDU_S_PH(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("ADDU_S.PH %s, %s, %s", rd, rs, rt);
}
@@ -2320,9 +2324,9 @@ static char *ADDU_S_QB(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("ADDU_S.QB %s, %s, %s", rd, rs, rt);
}
@@ -2345,9 +2349,9 @@ static char *ADDUH_QB(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("ADDUH.QB %s, %s, %s", rd, rs, rt);
}
@@ -2370,9 +2374,9 @@ static char *ADDUH_R_QB(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("ADDUH_R.QB %s, %s, %s", rd, rs, rt);
}
@@ -2393,9 +2397,9 @@ static char *ADDWC(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("ADDWC %s, %s, %s", rd, rs, rt);
}
@@ -2416,7 +2420,7 @@ static char *ALUIPC(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
int64 s_value = extract_s__se31_0_11_to_2_20_to_12_s12(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
g_autofree char *s = ADDRESS(s_value, 4, info);
return img_format("ALUIPC %s, %%pcrel_hi(%s)", rt, s);
@@ -2437,8 +2441,8 @@ static char *AND_16_(uint64 instruction, Dis_info *info)
uint64 rt3_value = extract_rt3_9_8_7(instruction);
uint64 rs3_value = extract_rs3_6_5_4(instruction);
- const char *rt3 = GPR(decode_gpr_gpr3(rt3_value));
- const char *rs3 = GPR(decode_gpr_gpr3(rs3_value));
+ const char *rt3 = GPR(decode_gpr_gpr3(rt3_value, info), info);
+ const char *rs3 = GPR(decode_gpr_gpr3(rs3_value, info), info);
return img_format("AND %s, %s", rs3, rt3);
}
@@ -2460,9 +2464,9 @@ static char *AND_32_(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("AND %s, %s, %s", rd, rs, rt);
}
@@ -2483,8 +2487,8 @@ static char *ANDI_16_(uint64 instruction, Dis_info *info)
uint64 rs3_value = extract_rs3_6_5_4(instruction);
uint64 eu_value = extract_eu_3_2_1_0(instruction);
- const char *rt3 = GPR(decode_gpr_gpr3(rt3_value));
- const char *rs3 = GPR(decode_gpr_gpr3(rs3_value));
+ const char *rt3 = GPR(decode_gpr_gpr3(rt3_value, info), info);
+ const char *rs3 = GPR(decode_gpr_gpr3(rs3_value, info), info);
uint64 eu = encode_eu_from_u_andi16(eu_value);
return img_format("ANDI %s, %s, 0x%" PRIx64, rt3, rs3, eu);
@@ -2507,8 +2511,8 @@ static char *ANDI_32_(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("ANDI %s, %s, 0x%" PRIx64, rt, rs, u_value);
}
@@ -2530,8 +2534,8 @@ static char *APPEND(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 sa_value = extract_sa_15_14_13_12_11(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("APPEND %s, %s, 0x%" PRIx64, rt, rs, sa_value);
}
@@ -2553,7 +2557,7 @@ static char *ASET(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
- const char *rs = GPR(rs_value);
+ const char *rs = GPR(rs_value, info);
return img_format("ASET 0x%" PRIx64 ", %" PRId64 "(%s)",
bit_value, s_value, rs);
@@ -2615,8 +2619,8 @@ static char *BALRSC(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("BALRSC %s, %s", rt, rs);
}
@@ -2638,7 +2642,7 @@ static char *BBEQZC(uint64 instruction, Dis_info *info)
uint64 bit_value = extract_bit_16_15_14_13_12_11(instruction);
int64 s_value = extract_s__se11_0_10_9_8_7_6_5_4_3_2_1_0_s1(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
g_autofree char *s = ADDRESS(s_value, 4, info);
return img_format("BBEQZC %s, 0x%" PRIx64 ", %s", rt, bit_value, s);
@@ -2661,7 +2665,7 @@ static char *BBNEZC(uint64 instruction, Dis_info *info)
uint64 bit_value = extract_bit_16_15_14_13_12_11(instruction);
int64 s_value = extract_s__se11_0_10_9_8_7_6_5_4_3_2_1_0_s1(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
g_autofree char *s = ADDRESS(s_value, 4, info);
return img_format("BBNEZC %s, 0x%" PRIx64 ", %s", rt, bit_value, s);
@@ -2723,7 +2727,7 @@ static char *BC1EQZC(uint64 instruction, Dis_info *info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
int64 s_value = extract_s__se14_0_13_to_1_s1(instruction);
- const char *ft = FPR(ft_value);
+ const char *ft = FPR(ft_value, info);
g_autofree char *s = ADDRESS(s_value, 4, info);
return img_format("BC1EQZC %s, %s", ft, s);
@@ -2745,7 +2749,7 @@ static char *BC1NEZC(uint64 instruction, Dis_info *info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
int64 s_value = extract_s__se14_0_13_to_1_s1(instruction);
- const char *ft = FPR(ft_value);
+ const char *ft = FPR(ft_value, info);
g_autofree char *s = ADDRESS(s_value, 4, info);
return img_format("BC1NEZC %s, %s", ft, s);
@@ -2810,8 +2814,8 @@ static char *BEQC_16_(uint64 instruction, Dis_info *info)
uint64 rs3_value = extract_rs3_6_5_4(instruction);
uint64 u_value = extract_u_3_2_1_0__s1(instruction);
- const char *rs3 = GPR(decode_gpr_gpr3(rs3_value));
- const char *rt3 = GPR(decode_gpr_gpr3(rt3_value));
+ const char *rs3 = GPR(decode_gpr_gpr3(rs3_value, info), info);
+ const char *rt3 = GPR(decode_gpr_gpr3(rt3_value, info), info);
g_autofree char *u = ADDRESS(u_value, 2, info);
return img_format("BEQC %s, %s, %s", rs3, rt3, u);
@@ -2834,8 +2838,8 @@ static char *BEQC_32_(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se14_0_13_to_1_s1(instruction);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
g_autofree char *s = ADDRESS(s_value, 4, info);
return img_format("BEQC %s, %s, %s", rs, rt, s);
@@ -2858,7 +2862,7 @@ static char *BEQIC(uint64 instruction, Dis_info *info)
uint64 u_value = extract_u_17_16_15_14_13_12_11(instruction);
int64 s_value = extract_s__se11_0_10_9_8_7_6_5_4_3_2_1_0_s1(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
g_autofree char *s = ADDRESS(s_value, 4, info);
return img_format("BEQIC %s, 0x%" PRIx64 ", %s", rt, u_value, s);
@@ -2880,7 +2884,7 @@ static char *BEQZC_16_(uint64 instruction, Dis_info *info)
uint64 rt3_value = extract_rt3_9_8_7(instruction);
int64 s_value = extract_s__se7_0_6_5_4_3_2_1_s1(instruction);
- const char *rt3 = GPR(decode_gpr_gpr3(rt3_value));
+ const char *rt3 = GPR(decode_gpr_gpr3(rt3_value, info), info);
g_autofree char *s = ADDRESS(s_value, 2, info);
return img_format("BEQZC %s, %s", rt3, s);
@@ -2903,8 +2907,8 @@ static char *BGEC(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se14_0_13_to_1_s1(instruction);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
g_autofree char *s = ADDRESS(s_value, 4, info);
return img_format("BGEC %s, %s, %s", rs, rt, s);
@@ -2927,7 +2931,7 @@ static char *BGEIC(uint64 instruction, Dis_info *info)
uint64 u_value = extract_u_17_16_15_14_13_12_11(instruction);
int64 s_value = extract_s__se11_0_10_9_8_7_6_5_4_3_2_1_0_s1(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
g_autofree char *s = ADDRESS(s_value, 4, info);
return img_format("BGEIC %s, 0x%" PRIx64 ", %s", rt, u_value, s);
@@ -2950,7 +2954,7 @@ static char *BGEIUC(uint64 instruction, Dis_info *info)
uint64 u_value = extract_u_17_16_15_14_13_12_11(instruction);
int64 s_value = extract_s__se11_0_10_9_8_7_6_5_4_3_2_1_0_s1(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
g_autofree char *s = ADDRESS(s_value, 4, info);
return img_format("BGEIUC %s, 0x%" PRIx64 ", %s", rt, u_value, s);
@@ -2973,8 +2977,8 @@ static char *BGEUC(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se14_0_13_to_1_s1(instruction);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
g_autofree char *s = ADDRESS(s_value, 4, info);
return img_format("BGEUC %s, %s, %s", rs, rt, s);
@@ -2997,8 +3001,8 @@ static char *BLTC(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se14_0_13_to_1_s1(instruction);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
g_autofree char *s = ADDRESS(s_value, 4, info);
return img_format("BLTC %s, %s, %s", rs, rt, s);
@@ -3021,7 +3025,7 @@ static char *BLTIC(uint64 instruction, Dis_info *info)
uint64 u_value = extract_u_17_16_15_14_13_12_11(instruction);
int64 s_value = extract_s__se11_0_10_9_8_7_6_5_4_3_2_1_0_s1(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
g_autofree char *s = ADDRESS(s_value, 4, info);
return img_format("BLTIC %s, 0x%" PRIx64 ", %s", rt, u_value, s);
@@ -3044,7 +3048,7 @@ static char *BLTIUC(uint64 instruction, Dis_info *info)
uint64 u_value = extract_u_17_16_15_14_13_12_11(instruction);
int64 s_value = extract_s__se11_0_10_9_8_7_6_5_4_3_2_1_0_s1(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
g_autofree char *s = ADDRESS(s_value, 4, info);
return img_format("BLTIUC %s, 0x%" PRIx64 ", %s", rt, u_value, s);
@@ -3067,8 +3071,8 @@ static char *BLTUC(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se14_0_13_to_1_s1(instruction);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
g_autofree char *s = ADDRESS(s_value, 4, info);
return img_format("BLTUC %s, %s, %s", rs, rt, s);
@@ -3091,8 +3095,8 @@ static char *BNEC_16_(uint64 instruction, Dis_info *info)
uint64 rs3_value = extract_rs3_6_5_4(instruction);
uint64 u_value = extract_u_3_2_1_0__s1(instruction);
- const char *rs3 = GPR(decode_gpr_gpr3(rs3_value));
- const char *rt3 = GPR(decode_gpr_gpr3(rt3_value));
+ const char *rs3 = GPR(decode_gpr_gpr3(rs3_value, info), info);
+ const char *rt3 = GPR(decode_gpr_gpr3(rt3_value, info), info);
g_autofree char *u = ADDRESS(u_value, 2, info);
return img_format("BNEC %s, %s, %s", rs3, rt3, u);
@@ -3115,8 +3119,8 @@ static char *BNEC_32_(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se14_0_13_to_1_s1(instruction);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
g_autofree char *s = ADDRESS(s_value, 4, info);
return img_format("BNEC %s, %s, %s", rs, rt, s);
@@ -3139,7 +3143,7 @@ static char *BNEIC(uint64 instruction, Dis_info *info)
uint64 u_value = extract_u_17_16_15_14_13_12_11(instruction);
int64 s_value = extract_s__se11_0_10_9_8_7_6_5_4_3_2_1_0_s1(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
g_autofree char *s = ADDRESS(s_value, 4, info);
return img_format("BNEIC %s, 0x%" PRIx64 ", %s", rt, u_value, s);
@@ -3161,7 +3165,7 @@ static char *BNEZC_16_(uint64 instruction, Dis_info *info)
uint64 rt3_value = extract_rt3_9_8_7(instruction);
int64 s_value = extract_s__se7_0_6_5_4_3_2_1_s1(instruction);
- const char *rt3 = GPR(decode_gpr_gpr3(rt3_value));
+ const char *rt3 = GPR(decode_gpr_gpr3(rt3_value, info), info);
g_autofree char *s = ADDRESS(s_value, 2, info);
return img_format("BNEZC %s, %s", rt3, s);
@@ -3240,7 +3244,7 @@ static char *BRSC(uint64 instruction, Dis_info *info)
{
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rs = GPR(rs_value);
+ const char *rs = GPR(rs_value, info);
return img_format("BRSC %s", rs);
}
@@ -3262,7 +3266,7 @@ static char *CACHE(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
- const char *rs = GPR(rs_value);
+ const char *rs = GPR(rs_value, info);
return img_format("CACHE 0x%" PRIx64 ", %s(%s)", op_value, s_value, rs);
}
@@ -3284,7 +3288,7 @@ static char *CACHEE(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
- const char *rs = GPR(rs_value);
+ const char *rs = GPR(rs_value, info);
return img_format("CACHEE 0x%" PRIx64 ", %s(%s)", op_value, s_value, rs);
}
@@ -3305,8 +3309,8 @@ static char *CEIL_L_D(uint64 instruction, Dis_info *info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("CEIL.L.D %s, %s", ft, fs);
}
@@ -3327,8 +3331,8 @@ static char *CEIL_L_S(uint64 instruction, Dis_info *info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("CEIL.L.S %s, %s", ft, fs);
}
@@ -3349,8 +3353,8 @@ static char *CEIL_W_D(uint64 instruction, Dis_info *info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("CEIL.W.D %s, %s", ft, fs);
}
@@ -3371,8 +3375,8 @@ static char *CEIL_W_S(uint64 instruction, Dis_info *info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("CEIL.W.S %s, %s", ft, fs);
}
@@ -3393,7 +3397,7 @@ static char *CFC1(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 cs_value = extract_cs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("CFC1 %s, CP%" PRIu64, rt, cs_value);
}
@@ -3414,7 +3418,7 @@ static char *CFC2(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 cs_value = extract_cs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("CFC2 %s, CP%" PRIu64, rt, cs_value);
}
@@ -3435,8 +3439,8 @@ static char *CLASS_D(uint64 instruction, Dis_info *info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("CLASS.D %s, %s", ft, fs);
}
@@ -3457,8 +3461,8 @@ static char *CLASS_S(uint64 instruction, Dis_info *info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("CLASS.S %s, %s", ft, fs);
}
@@ -3479,8 +3483,8 @@ static char *CLO(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("CLO %s, %s", rt, rs);
}
@@ -3501,8 +3505,8 @@ static char *CLZ(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("CLZ %s, %s", rt, rs);
}
@@ -3524,9 +3528,9 @@ static char *CMP_AF_D(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.AF.D %s, %s, %s", fd, fs, ft);
}
@@ -3548,9 +3552,9 @@ static char *CMP_AF_S(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.AF.S %s, %s, %s", fd, fs, ft);
}
@@ -3572,9 +3576,9 @@ static char *CMP_EQ_D(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.EQ.D %s, %s, %s", fd, fs, ft);
}
@@ -3594,8 +3598,8 @@ static char *CMP_EQ_PH(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("CMP.EQ.PH %s, %s", rs, rt);
}
@@ -3617,9 +3621,9 @@ static char *CMP_EQ_S(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.EQ.S %s, %s, %s", fd, fs, ft);
}
@@ -3641,9 +3645,9 @@ static char *CMP_LE_D(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.LE.D %s, %s, %s", fd, fs, ft);
}
@@ -3663,8 +3667,8 @@ static char *CMP_LE_PH(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("CMP.LE.PH %s, %s", rs, rt);
}
@@ -3686,9 +3690,9 @@ static char *CMP_LE_S(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.LE.S %s, %s, %s", fd, fs, ft);
}
@@ -3710,9 +3714,9 @@ static char *CMP_LT_D(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.LT.D %s, %s, %s", fd, fs, ft);
}
@@ -3732,8 +3736,8 @@ static char *CMP_LT_PH(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("CMP.LT.PH %s, %s", rs, rt);
}
@@ -3755,9 +3759,9 @@ static char *CMP_LT_S(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.LT.S %s, %s, %s", fd, fs, ft);
}
@@ -3779,9 +3783,9 @@ static char *CMP_NE_D(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.NE.D %s, %s, %s", fd, fs, ft);
}
@@ -3803,9 +3807,9 @@ static char *CMP_NE_S(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.NE.S %s, %s, %s", fd, fs, ft);
}
@@ -3827,9 +3831,9 @@ static char *CMP_OR_D(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.OR.D %s, %s, %s", fd, fs, ft);
}
@@ -3851,9 +3855,9 @@ static char *CMP_OR_S(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.OR.S %s, %s, %s", fd, fs, ft);
}
@@ -3875,9 +3879,9 @@ static char *CMP_SAF_D(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.SAF.D %s, %s, %s", fd, fs, ft);
}
@@ -3899,9 +3903,9 @@ static char *CMP_SAF_S(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.SAF.S %s, %s, %s", fd, fs, ft);
}
@@ -3923,9 +3927,9 @@ static char *CMP_SEQ_D(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.SEQ.D %s, %s, %s", fd, fs, ft);
}
@@ -3947,9 +3951,9 @@ static char *CMP_SEQ_S(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.SEQ.S %s, %s, %s", fd, fs, ft);
}
@@ -3971,9 +3975,9 @@ static char *CMP_SLE_D(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.SLE.D %s, %s, %s", fd, fs, ft);
}
@@ -3995,9 +3999,9 @@ static char *CMP_SLE_S(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.SLE.S %s, %s, %s", fd, fs, ft);
}
@@ -4019,9 +4023,9 @@ static char *CMP_SLT_D(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.SLT.D %s, %s, %s", fd, fs, ft);
}
@@ -4043,9 +4047,9 @@ static char *CMP_SLT_S(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.SLT.S %s, %s, %s", fd, fs, ft);
}
@@ -4067,9 +4071,9 @@ static char *CMP_SNE_D(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.SNE.D %s, %s, %s", fd, fs, ft);
}
@@ -4091,9 +4095,9 @@ static char *CMP_SNE_S(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.SNE.S %s, %s, %s", fd, fs, ft);
}
@@ -4115,9 +4119,9 @@ static char *CMP_SOR_D(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.SOR.D %s, %s, %s", fd, fs, ft);
}
@@ -4139,9 +4143,9 @@ static char *CMP_SOR_S(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.SOR.S %s, %s, %s", fd, fs, ft);
}
@@ -4163,9 +4167,9 @@ static char *CMP_SUEQ_D(uint64 instruction, Dis_info
*info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.SUEQ.D %s, %s, %s", fd, fs, ft);
}
@@ -4187,9 +4191,9 @@ static char *CMP_SUEQ_S(uint64 instruction, Dis_info
*info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.SUEQ.S %s, %s, %s", fd, fs, ft);
}
@@ -4211,9 +4215,9 @@ static char *CMP_SULE_D(uint64 instruction, Dis_info
*info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.SULE.D %s, %s, %s", fd, fs, ft);
}
@@ -4235,9 +4239,9 @@ static char *CMP_SULE_S(uint64 instruction, Dis_info
*info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.SULE.S %s, %s, %s", fd, fs, ft);
}
@@ -4259,9 +4263,9 @@ static char *CMP_SULT_D(uint64 instruction, Dis_info
*info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.SULT.D %s, %s, %s", fd, fs, ft);
}
@@ -4283,9 +4287,9 @@ static char *CMP_SULT_S(uint64 instruction, Dis_info
*info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.SULT.S %s, %s, %s", fd, fs, ft);
}
@@ -4307,9 +4311,9 @@ static char *CMP_SUN_D(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.SUN.D %s, %s, %s", fd, fs, ft);
}
@@ -4331,9 +4335,9 @@ static char *CMP_SUNE_D(uint64 instruction, Dis_info
*info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.SUNE.D %s, %s, %s", fd, fs, ft);
}
@@ -4355,9 +4359,9 @@ static char *CMP_SUNE_S(uint64 instruction, Dis_info
*info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.SUNE.S %s, %s, %s", fd, fs, ft);
}
@@ -4379,9 +4383,9 @@ static char *CMP_SUN_S(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.SUN.S %s, %s, %s", fd, fs, ft);
}
@@ -4403,9 +4407,9 @@ static char *CMP_UEQ_D(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.UEQ.D %s, %s, %s", fd, fs, ft);
}
@@ -4427,9 +4431,9 @@ static char *CMP_UEQ_S(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.UEQ.S %s, %s, %s", fd, fs, ft);
}
@@ -4451,9 +4455,9 @@ static char *CMP_ULE_D(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.ULE.D %s, %s, %s", fd, fs, ft);
}
@@ -4475,9 +4479,9 @@ static char *CMP_ULE_S(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.ULE.S %s, %s, %s", fd, fs, ft);
}
@@ -4499,9 +4503,9 @@ static char *CMP_ULT_D(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.ULT.D %s, %s, %s", fd, fs, ft);
}
@@ -4523,9 +4527,9 @@ static char *CMP_ULT_S(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.ULT.S %s, %s, %s", fd, fs, ft);
}
@@ -4547,9 +4551,9 @@ static char *CMP_UN_D(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.UN.D %s, %s, %s", fd, fs, ft);
}
@@ -4571,9 +4575,9 @@ static char *CMP_UNE_D(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.UNE.D %s, %s, %s", fd, fs, ft);
}
@@ -4595,9 +4599,9 @@ static char *CMP_UNE_S(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.UNE.S %s, %s, %s", fd, fs, ft);
}
@@ -4619,9 +4623,9 @@ static char *CMP_UN_S(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("CMP.UN.S %s, %s, %s", fd, fs, ft);
}
@@ -4644,9 +4648,9 @@ static char *CMPGDU_EQ_QB(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("CMPGDU.EQ.QB %s, %s, %s", rd, rs, rt);
}
@@ -4669,9 +4673,9 @@ static char *CMPGDU_LE_QB(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("CMPGDU.LE.QB %s, %s, %s", rd, rs, rt);
}
@@ -4694,9 +4698,9 @@ static char *CMPGDU_LT_QB(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("CMPGDU.LT.QB %s, %s, %s", rd, rs, rt);
}
@@ -4719,9 +4723,9 @@ static char *CMPGU_EQ_QB(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("CMPGU.EQ.QB %s, %s, %s", rd, rs, rt);
}
@@ -4744,9 +4748,9 @@ static char *CMPGU_LE_QB(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("CMPGU.LE.QB %s, %s, %s", rd, rs, rt);
}
@@ -4769,9 +4773,9 @@ static char *CMPGU_LT_QB(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("CMPGU.LT.QB %s, %s, %s", rd, rs, rt);
}
@@ -4792,8 +4796,8 @@ static char *CMPU_EQ_QB(uint64 instruction, Dis_info
*info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("CMPU.EQ.QB %s, %s", rs, rt);
}
@@ -4814,8 +4818,8 @@ static char *CMPU_LE_QB(uint64 instruction, Dis_info
*info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("CMPU.LE.QB %s, %s", rs, rt);
}
@@ -4836,8 +4840,8 @@ static char *CMPU_LT_QB(uint64 instruction, Dis_info
*info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("CMPU.LT.QB %s, %s", rs, rt);
}
@@ -4877,7 +4881,7 @@ static char *CTC1(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 cs_value = extract_cs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("CTC1 %s, CP%" PRIu64, rt, cs_value);
}
@@ -4898,7 +4902,7 @@ static char *CTC2(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 cs_value = extract_cs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("CTC2 %s, CP%" PRIu64, rt, cs_value);
}
@@ -4919,8 +4923,8 @@ static char *CVT_D_L(uint64 instruction, Dis_info *info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("CVT.D.L %s, %s", ft, fs);
}
@@ -4941,8 +4945,8 @@ static char *CVT_D_S(uint64 instruction, Dis_info *info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("CVT.D.S %s, %s", ft, fs);
}
@@ -4963,8 +4967,8 @@ static char *CVT_D_W(uint64 instruction, Dis_info *info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("CVT.D.W %s, %s", ft, fs);
}
@@ -4985,8 +4989,8 @@ static char *CVT_L_D(uint64 instruction, Dis_info *info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("CVT.L.D %s, %s", ft, fs);
}
@@ -5007,8 +5011,8 @@ static char *CVT_L_S(uint64 instruction, Dis_info *info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("CVT.L.S %s, %s", ft, fs);
}
@@ -5029,8 +5033,8 @@ static char *CVT_S_D(uint64 instruction, Dis_info *info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("CVT.S.D %s, %s", ft, fs);
}
@@ -5051,8 +5055,8 @@ static char *CVT_S_L(uint64 instruction, Dis_info *info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("CVT.S.L %s, %s", ft, fs);
}
@@ -5073,8 +5077,8 @@ static char *CVT_S_PL(uint64 instruction, Dis_info *info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("CVT.S.PL %s, %s", ft, fs);
}
@@ -5095,8 +5099,8 @@ static char *CVT_S_PU(uint64 instruction, Dis_info *info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("CVT.S.PU %s, %s", ft, fs);
}
@@ -5117,8 +5121,8 @@ static char *CVT_S_W(uint64 instruction, Dis_info *info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("CVT.S.W %s, %s", ft, fs);
}
@@ -5139,8 +5143,8 @@ static char *CVT_W_D(uint64 instruction, Dis_info *info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("CVT.W.D %s, %s", ft, fs);
}
@@ -5161,8 +5165,8 @@ static char *CVT_W_S(uint64 instruction, Dis_info *info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("CVT.W.S %s, %s", ft, fs);
}
@@ -5183,7 +5187,7 @@ static char *DADDIU_48_(uint64 instruction, Dis_info
*info)
uint64 rt_value = extract_rt_41_40_39_38_37(instruction);
int64 s_value = extract_s__se31_15_to_0_31_to_16(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("DADDIU %s, %s", rt, s_value);
}
@@ -5205,8 +5209,8 @@ static char *DADDIU_NEG_(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
int64 u = neg_copy(u_value);
return img_format("DADDIU %s, %s, %" PRId64, rt, rs, u);
@@ -5229,8 +5233,8 @@ static char *DADDIU_U12_(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("DADDIU %s, %s, 0x%" PRIx64, rt, rs, u_value);
}
@@ -5252,9 +5256,9 @@ static char *DADD(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("DADD %s, %s, %s", rd, rs, rt);
}
@@ -5276,9 +5280,9 @@ static char *DADDU(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("DADDU %s, %s, %s", rd, rs, rt);
}
@@ -5299,8 +5303,8 @@ static char *DCLO(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("DCLO %s, %s", rt, rs);
}
@@ -5321,8 +5325,8 @@ static char *DCLZ(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("DCLZ %s, %s", rt, rs);
}
@@ -5344,9 +5348,9 @@ static char *DDIV(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("DDIV %s, %s, %s", rd, rs, rt);
}
@@ -5368,9 +5372,9 @@ static char *DDIVU(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("DDIVU %s, %s, %s", rd, rs, rt);
}
@@ -5411,8 +5415,8 @@ static char *DEXTM(uint64 instruction, Dis_info *info)
uint64 msbd_value = extract_msbt_10_9_8_7_6(instruction);
uint64 lsb_value = extract_lsb_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
uint64 msbd = encode_msbd_from_size(msbd_value);
return img_format("DEXTM %s, %s, 0x%" PRIx64 ", 0x%" PRIx64,
@@ -5437,8 +5441,8 @@ static char *DEXT(uint64 instruction, Dis_info *info)
uint64 msbd_value = extract_msbt_10_9_8_7_6(instruction);
uint64 lsb_value = extract_lsb_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
uint64 msbd = encode_msbd_from_size(msbd_value);
return img_format("DEXT %s, %s, 0x%" PRIx64 ", 0x%" PRIx64,
@@ -5463,8 +5467,8 @@ static char *DEXTU(uint64 instruction, Dis_info *info)
uint64 msbd_value = extract_msbt_10_9_8_7_6(instruction);
uint64 lsb_value = extract_lsb_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
uint64 msbd = encode_msbd_from_size(msbd_value);
return img_format("DEXTU %s, %s, 0x%" PRIx64 ", 0x%" PRIx64,
@@ -5489,8 +5493,8 @@ static char *DINSM(uint64 instruction, Dis_info *info)
uint64 msbd_value = extract_msbt_10_9_8_7_6(instruction);
uint64 lsb_value = extract_lsb_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
/* !!!!!!!!!! - no conversion function */
return img_format("DINSM %s, %s, 0x%" PRIx64 ", 0x%" PRIx64,
@@ -5516,8 +5520,8 @@ static char *DINS(uint64 instruction, Dis_info *info)
uint64 msbd_value = extract_msbt_10_9_8_7_6(instruction);
uint64 lsb_value = extract_lsb_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
/* !!!!!!!!!! - no conversion function */
return img_format("DINS %s, %s, 0x%" PRIx64 ", 0x%" PRIx64,
@@ -5543,8 +5547,8 @@ static char *DINSU(uint64 instruction, Dis_info *info)
uint64 msbd_value = extract_msbt_10_9_8_7_6(instruction);
uint64 lsb_value = extract_lsb_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
/* !!!!!!!!!! - no conversion function */
return img_format("DINSU %s, %s, 0x%" PRIx64 ", 0x%" PRIx64,
@@ -5567,7 +5571,7 @@ static char *DI(uint64 instruction, Dis_info *info)
{
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("DI %s", rt);
}
@@ -5589,9 +5593,9 @@ static char *DIV(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("DIV %s, %s, %s", rd, rs, rt);
}
@@ -5613,9 +5617,9 @@ static char *DIV_D(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("DIV.D %s, %s, %s", fd, fs, ft);
}
@@ -5637,9 +5641,9 @@ static char *DIV_S(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("DIV.S %s, %s, %s", fd, fs, ft);
}
@@ -5661,9 +5665,9 @@ static char *DIVU(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("DIVU %s, %s, %s", rd, rs, rt);
}
@@ -5686,9 +5690,9 @@ static char *DLSA(uint64 instruction, Dis_info *info)
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
uint64 u2_value = extract_u2_10_9(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("DLSA %s, %s, %s, 0x%" PRIx64, rd, rs, rt, u2_value);
}
@@ -5709,7 +5713,7 @@ static char *DLUI_48_(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_41_40_39_38_37(instruction);
uint64 u_value = extract_u_31_to_0__s32(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("DLUI %s, 0x%" PRIx64, rt, u_value);
}
@@ -5731,7 +5735,7 @@ static char *DMFC0(uint64 instruction, Dis_info *info)
uint64 c0s_value = extract_c0s_20_19_18_17_16(instruction);
uint64 sel_value = extract_sel_15_14_13_12_11(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("DMFC0 %s, CP%" PRIu64 ", 0x%" PRIx64,
rt, c0s_value, sel_value);
@@ -5753,8 +5757,8 @@ static char *DMFC1(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
- const char *fs = FPR(fs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("DMFC1 %s, %s", rt, fs);
}
@@ -5775,7 +5779,7 @@ static char *DMFC2(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 cs_value = extract_cs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("DMFC2 %s, CP%" PRIu64, rt, cs_value);
}
@@ -5797,7 +5801,7 @@ static char *DMFGC0(uint64 instruction, Dis_info *info)
uint64 c0s_value = extract_c0s_20_19_18_17_16(instruction);
uint64 sel_value = extract_sel_15_14_13_12_11(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("DMFGC0 %s, CP%" PRIu64 ", 0x%" PRIx64,
rt, c0s_value, sel_value);
@@ -5820,9 +5824,9 @@ static char *DMOD(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("DMOD %s, %s, %s", rd, rs, rt);
}
@@ -5844,9 +5848,9 @@ static char *DMODU(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("DMODU %s, %s, %s", rd, rs, rt);
}
@@ -5868,7 +5872,7 @@ static char *DMTC0(uint64 instruction, Dis_info *info)
uint64 c0s_value = extract_c0s_20_19_18_17_16(instruction);
uint64 sel_value = extract_sel_15_14_13_12_11(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("DMTC0 %s, CP%" PRIu64 ", 0x%" PRIx64,
rt, c0s_value, sel_value);
@@ -5890,8 +5894,8 @@ static char *DMTC1(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
- const char *fs = FPR(fs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("DMTC1 %s, %s", rt, fs);
}
@@ -5912,7 +5916,7 @@ static char *DMTC2(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 cs_value = extract_cs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("DMTC2 %s, CP%" PRIu64, rt, cs_value);
}
@@ -5934,7 +5938,7 @@ static char *DMTGC0(uint64 instruction, Dis_info *info)
uint64 c0s_value = extract_c0s_20_19_18_17_16(instruction);
uint64 sel_value = extract_sel_15_14_13_12_11(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("DMTGC0 %s, CP%" PRIu64 ", 0x%" PRIx64,
rt, c0s_value, sel_value);
@@ -5955,7 +5959,7 @@ static char *DMT(uint64 instruction, Dis_info *info)
{
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("DMT %s", rt);
}
@@ -5977,9 +5981,9 @@ static char *DMUH(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("DMUH %s, %s, %s", rd, rs, rt);
}
@@ -6001,9 +6005,9 @@ static char *DMUHU(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("DMUHU %s, %s, %s", rd, rs, rt);
}
@@ -6025,9 +6029,9 @@ static char *DMUL(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("DMUL %s, %s, %s", rd, rs, rt);
}
@@ -6049,9 +6053,9 @@ static char *DMULU(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("DMULU %s, %s, %s", rd, rs, rt);
}
@@ -6074,9 +6078,9 @@ static char *DPA_W_PH(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *ac = AC(ac_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *ac = AC(ac_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("DPA.W.PH %s, %s, %s", ac, rs, rt);
}
@@ -6098,9 +6102,9 @@ static char *DPAQ_SA_L_W(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *ac = AC(ac_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *ac = AC(ac_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("DPAQ_SA.L.W %s, %s, %s", ac, rs, rt);
}
@@ -6122,9 +6126,9 @@ static char *DPAQ_S_W_PH(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *ac = AC(ac_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *ac = AC(ac_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("DPAQ_S.W.PH %s, %s, %s", ac, rs, rt);
}
@@ -6146,9 +6150,9 @@ static char *DPAQX_SA_W_PH(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *ac = AC(ac_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *ac = AC(ac_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("DPAQX_SA.W.PH %s, %s, %s", ac, rs, rt);
}
@@ -6170,9 +6174,9 @@ static char *DPAQX_S_W_PH(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *ac = AC(ac_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *ac = AC(ac_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("DPAQX_S.W.PH %s, %s, %s", ac, rs, rt);
}
@@ -6194,9 +6198,9 @@ static char *DPAU_H_QBL(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *ac = AC(ac_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *ac = AC(ac_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("DPAU.H.QBL %s, %s, %s", ac, rs, rt);
}
@@ -6218,9 +6222,9 @@ static char *DPAU_H_QBR(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *ac = AC(ac_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *ac = AC(ac_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("DPAU.H.QBR %s, %s, %s", ac, rs, rt);
}
@@ -6242,9 +6246,9 @@ static char *DPAX_W_PH(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *ac = AC(ac_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *ac = AC(ac_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("DPAX.W.PH %s, %s, %s", ac, rs, rt);
}
@@ -6266,9 +6270,9 @@ static char *DPS_W_PH(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *ac = AC(ac_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *ac = AC(ac_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("DPS.W.PH %s, %s, %s", ac, rs, rt);
}
@@ -6290,9 +6294,9 @@ static char *DPSQ_SA_L_W(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *ac = AC(ac_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *ac = AC(ac_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("DPSQ_SA.L.W %s, %s, %s", ac, rs, rt);
}
@@ -6314,9 +6318,9 @@ static char *DPSQ_S_W_PH(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *ac = AC(ac_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *ac = AC(ac_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("DPSQ_S.W.PH %s, %s, %s", ac, rs, rt);
}
@@ -6338,9 +6342,9 @@ static char *DPSQX_SA_W_PH(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *ac = AC(ac_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *ac = AC(ac_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("DPSQX_SA.W.PH %s, %s, %s", ac, rs, rt);
}
@@ -6362,9 +6366,9 @@ static char *DPSQX_S_W_PH(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *ac = AC(ac_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *ac = AC(ac_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("DPSQX_S.W.PH %s, %s, %s", ac, rs, rt);
}
@@ -6386,9 +6390,9 @@ static char *DPSU_H_QBL(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *ac = AC(ac_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *ac = AC(ac_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("DPSU.H.QBL %s, %s, %s", ac, rs, rt);
}
@@ -6410,9 +6414,9 @@ static char *DPSU_H_QBR(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *ac = AC(ac_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *ac = AC(ac_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("DPSU.H.QBR %s, %s, %s", ac, rs, rt);
}
@@ -6434,9 +6438,9 @@ static char *DPSX_W_PH(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *ac = AC(ac_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *ac = AC(ac_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("DPSX.W.PH %s, %s, %s", ac, rs, rt);
}
@@ -6458,8 +6462,8 @@ static char *DROTR(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 shift_value = extract_shift_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("DROTR %s, %s, 0x%" PRIx64, rt, rs, shift_value);
}
@@ -6481,8 +6485,8 @@ static char *DROTR32(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 shift_value = extract_shift_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("DROTR32 %s, %s, 0x%" PRIx64, rt, rs, shift_value);
}
@@ -6504,9 +6508,9 @@ static char *DROTRV(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("DROTRV %s, %s, %s", rd, rs, rt);
}
@@ -6529,8 +6533,8 @@ static char *DROTX(uint64 instruction, Dis_info *info)
uint64 shiftx_value = extract_shiftx_11_10_9_8_7_6(instruction);
uint64 shift_value = extract_shift_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("DROTX %s, %s, 0x%" PRIx64 ", 0x%" PRIx64,
rt, rs, shift_value, shiftx_value);
@@ -6553,8 +6557,8 @@ static char *DSLL(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 shift_value = extract_shift_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("DSLL %s, %s, 0x%" PRIx64, rt, rs, shift_value);
}
@@ -6576,8 +6580,8 @@ static char *DSLL32(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 shift_value = extract_shift_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("DSLL32 %s, %s, 0x%" PRIx64, rt, rs, shift_value);
}
@@ -6599,9 +6603,9 @@ static char *DSLLV(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("DSLLV %s, %s, %s", rd, rs, rt);
}
@@ -6623,8 +6627,8 @@ static char *DSRA(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 shift_value = extract_shift_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("DSRA %s, %s, 0x%" PRIx64, rt, rs, shift_value);
}
@@ -6646,8 +6650,8 @@ static char *DSRA32(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 shift_value = extract_shift_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("DSRA32 %s, %s, 0x%" PRIx64, rt, rs, shift_value);
}
@@ -6669,9 +6673,9 @@ static char *DSRAV(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("DSRAV %s, %s, %s", rd, rs, rt);
}
@@ -6693,8 +6697,8 @@ static char *DSRL(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 shift_value = extract_shift_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("DSRL %s, %s, 0x%" PRIx64, rt, rs, shift_value);
}
@@ -6716,8 +6720,8 @@ static char *DSRL32(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 shift_value = extract_shift_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("DSRL32 %s, %s, 0x%" PRIx64, rt, rs, shift_value);
}
@@ -6739,9 +6743,9 @@ static char *DSRLV(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("DSRLV %s, %s, %s", rd, rs, rt);
}
@@ -6763,9 +6767,9 @@ static char *DSUB(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("DSUB %s, %s, %s", rd, rs, rt);
}
@@ -6787,9 +6791,9 @@ static char *DSUBU(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("DSUBU %s, %s, %s", rd, rs, rt);
}
@@ -6809,7 +6813,7 @@ static char *DVPE(uint64 instruction, Dis_info *info)
{
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("DVPE %s", rt);
}
@@ -6829,7 +6833,7 @@ static char *DVP(uint64 instruction, Dis_info *info)
{
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("DVP %s", rt);
}
@@ -6867,7 +6871,7 @@ static char *EI(uint64 instruction, Dis_info *info)
{
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("EI %s", rt);
}
@@ -6887,7 +6891,7 @@ static char *EMT(uint64 instruction, Dis_info *info)
{
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("EMT %s", rt);
}
@@ -6943,7 +6947,7 @@ static char *EVP(uint64 instruction, Dis_info *info)
{
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("EVP %s", rt);
}
@@ -6963,7 +6967,7 @@ static char *EVPE(uint64 instruction, Dis_info *info)
{
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("EVPE %s", rt);
}
@@ -6986,8 +6990,8 @@ static char *EXT(uint64 instruction, Dis_info *info)
uint64 msbd_value = extract_msbt_10_9_8_7_6(instruction);
uint64 lsb_value = extract_lsb_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
uint64 msbd = encode_msbd_from_size(msbd_value);
return img_format("EXT %s, %s, 0x%" PRIx64 ", 0x%" PRIx64,
@@ -7012,9 +7016,9 @@ static char *EXTD(uint64 instruction, Dis_info *info)
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
uint64 shift_value = extract_shift_10_9_8_7_6(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("EXTD %s, %s, %s, 0x%" PRIx64, rd, rs, rt, shift_value);
}
@@ -7037,9 +7041,9 @@ static char *EXTD32(uint64 instruction, Dis_info *info)
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
uint64 shift_value = extract_shift_10_9_8_7_6(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("EXTD32 %s, %s, %s, 0x%" PRIx64, rd, rs, rt,
shift_value);
}
@@ -7061,8 +7065,8 @@ static char *EXTPDP(uint64 instruction, Dis_info *info)
uint64 size_value = extract_size_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *rt = GPR(rt_value);
- const char *ac = AC(ac_value);
+ const char *rt = GPR(rt_value, info);
+ const char *ac = AC(ac_value, info);
return img_format("EXTPDP %s, %s, 0x%" PRIx64, rt, ac, size_value);
}
@@ -7084,9 +7088,9 @@ static char *EXTPDPV(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *rt = GPR(rt_value);
- const char *ac = AC(ac_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *ac = AC(ac_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("EXTPDPV %s, %s, %s", rt, ac, rs);
}
@@ -7108,8 +7112,8 @@ static char *EXTP(uint64 instruction, Dis_info *info)
uint64 size_value = extract_size_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *rt = GPR(rt_value);
- const char *ac = AC(ac_value);
+ const char *rt = GPR(rt_value, info);
+ const char *ac = AC(ac_value, info);
return img_format("EXTP %s, %s, 0x%" PRIx64, rt, ac, size_value);
}
@@ -7131,9 +7135,9 @@ static char *EXTPV(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *rt = GPR(rt_value);
- const char *ac = AC(ac_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *ac = AC(ac_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("EXTPV %s, %s, %s", rt, ac, rs);
}
@@ -7156,8 +7160,8 @@ static char *EXTR_RS_W(uint64 instruction, Dis_info *info)
uint64 shift_value = extract_shift_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *rt = GPR(rt_value);
- const char *ac = AC(ac_value);
+ const char *rt = GPR(rt_value, info);
+ const char *ac = AC(ac_value, info);
return img_format("EXTR_RS.W %s, %s, 0x%" PRIx64, rt, ac, shift_value);
}
@@ -7180,8 +7184,8 @@ static char *EXTR_R_W(uint64 instruction, Dis_info *info)
uint64 shift_value = extract_shift_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *rt = GPR(rt_value);
- const char *ac = AC(ac_value);
+ const char *rt = GPR(rt_value, info);
+ const char *ac = AC(ac_value, info);
return img_format("EXTR_R.W %s, %s, 0x%" PRIx64, rt, ac, shift_value);
}
@@ -7204,8 +7208,8 @@ static char *EXTR_S_H(uint64 instruction, Dis_info *info)
uint64 shift_value = extract_shift_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *rt = GPR(rt_value);
- const char *ac = AC(ac_value);
+ const char *rt = GPR(rt_value, info);
+ const char *ac = AC(ac_value, info);
return img_format("EXTR_S.H %s, %s, 0x%" PRIx64, rt, ac, shift_value);
}
@@ -7228,8 +7232,8 @@ static char *EXTR_W(uint64 instruction, Dis_info *info)
uint64 shift_value = extract_shift_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *rt = GPR(rt_value);
- const char *ac = AC(ac_value);
+ const char *rt = GPR(rt_value, info);
+ const char *ac = AC(ac_value, info);
return img_format("EXTR.W %s, %s, 0x%" PRIx64, rt, ac, shift_value);
}
@@ -7252,9 +7256,9 @@ static char *EXTRV_RS_W(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *rt = GPR(rt_value);
- const char *ac = AC(ac_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *ac = AC(ac_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("EXTRV_RS.W %s, %s, %s", rt, ac, rs);
}
@@ -7277,9 +7281,9 @@ static char *EXTRV_R_W(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *rt = GPR(rt_value);
- const char *ac = AC(ac_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *ac = AC(ac_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("EXTRV_R.W %s, %s, %s", rt, ac, rs);
}
@@ -7302,9 +7306,9 @@ static char *EXTRV_S_H(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *rt = GPR(rt_value);
- const char *ac = AC(ac_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *ac = AC(ac_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("EXTRV_S.H %s, %s, %s", rt, ac, rs);
}
@@ -7327,9 +7331,9 @@ static char *EXTRV_W(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *rt = GPR(rt_value);
- const char *ac = AC(ac_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *ac = AC(ac_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("EXTRV.W %s, %s, %s", rt, ac, rs);
}
@@ -7353,9 +7357,9 @@ static char *EXTW(uint64 instruction, Dis_info *info)
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
uint64 shift_value = extract_shift_10_9_8_7_6(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("EXTW %s, %s, %s, 0x%" PRIx64, rd, rs, rt, shift_value);
}
@@ -7376,8 +7380,8 @@ static char *FLOOR_L_D(uint64 instruction, Dis_info *info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("FLOOR.L.D %s, %s", ft, fs);
}
@@ -7398,8 +7402,8 @@ static char *FLOOR_L_S(uint64 instruction, Dis_info *info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("FLOOR.L.S %s, %s", ft, fs);
}
@@ -7420,8 +7424,8 @@ static char *FLOOR_W_D(uint64 instruction, Dis_info *info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("FLOOR.W.D %s, %s", ft, fs);
}
@@ -7442,8 +7446,8 @@ static char *FLOOR_W_S(uint64 instruction, Dis_info *info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("FLOOR.W.S %s, %s", ft, fs);
}
@@ -7465,9 +7469,9 @@ static char *FORK(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("FORK %s, %s, %s", rd, rs, rt);
}
@@ -7528,8 +7532,8 @@ static char *INS(uint64 instruction, Dis_info *info)
uint64 msbd_value = extract_msbt_10_9_8_7_6(instruction);
uint64 lsb_value = extract_lsb_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
/* !!!!!!!!!! - no conversion function */
return img_format("INS %s, %s, 0x%" PRIx64 ", 0x%" PRIx64,
@@ -7552,8 +7556,8 @@ static char *INSV(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("INSV %s, %s", rt, rs);
}
@@ -7591,7 +7595,7 @@ static char *JALRC_16_(uint64 instruction, Dis_info *info)
{
uint64 rt_value = extract_rt_9_8_7_6_5(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("JALRC $%d, %s", 31, rt);
}
@@ -7612,8 +7616,8 @@ static char *JALRC_32_(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("JALRC %s, %s", rt, rs);
}
@@ -7634,8 +7638,8 @@ static char *JALRC_HB(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("JALRC.HB %s, %s", rt, rs);
}
@@ -7655,7 +7659,7 @@ static char *JRC(uint64 instruction, Dis_info *info)
{
uint64 rt_value = extract_rt_9_8_7_6_5(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("JRC %s", rt);
}
@@ -7677,8 +7681,8 @@ static char *LB_16_(uint64 instruction, Dis_info *info)
uint64 rs3_value = extract_rs3_6_5_4(instruction);
uint64 u_value = extract_u_1_0(instruction);
- const char *rt3 = GPR(decode_gpr_gpr3(rt3_value));
- const char *rs3 = GPR(decode_gpr_gpr3(rs3_value));
+ const char *rt3 = GPR(decode_gpr_gpr3(rt3_value, info), info);
+ const char *rs3 = GPR(decode_gpr_gpr3(rs3_value, info), info);
return img_format("LB %s, 0x%" PRIx64 "(%s)", rt3, u_value, rs3);
}
@@ -7699,7 +7703,7 @@ static char *LB_GP_(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 u_value = extract_u_17_to_0(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("LB %s, 0x%" PRIx64 "($%d)", rt, u_value, 28);
}
@@ -7721,8 +7725,8 @@ static char *LB_S9_(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("LB %s, %" PRId64 "(%s)", rt, s_value, rs);
}
@@ -7744,8 +7748,8 @@ static char *LB_U12_(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("LB %s, 0x%" PRIx64 "(%s)", rt, u_value, rs);
}
@@ -7767,8 +7771,8 @@ static char *LBE(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("LBE %s, %" PRId64 "(%s)", rt, s_value, rs);
}
@@ -7790,8 +7794,8 @@ static char *LBU_16_(uint64 instruction, Dis_info *info)
uint64 rs3_value = extract_rs3_6_5_4(instruction);
uint64 u_value = extract_u_1_0(instruction);
- const char *rt3 = GPR(decode_gpr_gpr3(rt3_value));
- const char *rs3 = GPR(decode_gpr_gpr3(rs3_value));
+ const char *rt3 = GPR(decode_gpr_gpr3(rt3_value, info), info);
+ const char *rs3 = GPR(decode_gpr_gpr3(rs3_value, info), info);
return img_format("LBU %s, 0x%" PRIx64 "(%s)", rt3, u_value, rs3);
}
@@ -7812,7 +7816,7 @@ static char *LBU_GP_(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 u_value = extract_u_17_to_0(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("LBU %s, 0x%" PRIx64 "($%d)", rt, u_value, 28);
}
@@ -7834,8 +7838,8 @@ static char *LBU_S9_(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("LBU %s, %" PRId64 "(%s)", rt, s_value, rs);
}
@@ -7857,8 +7861,8 @@ static char *LBU_U12_(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("LBU %s, 0x%" PRIx64 "(%s)", rt, u_value, rs);
}
@@ -7880,8 +7884,8 @@ static char *LBUE(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("LBUE %s, %" PRId64 "(%s)", rt, s_value, rs);
}
@@ -7903,9 +7907,9 @@ static char *LBUX(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("LBUX %s, %s(%s)", rd, rs, rt);
}
@@ -7927,9 +7931,9 @@ static char *LBX(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("LBX %s, %s(%s)", rd, rs, rt);
}
@@ -7950,7 +7954,7 @@ static char *LD_GP_(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 u_value = extract_u_20_to_3__s3(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("LD %s, 0x%" PRIx64 "($%d)", rt, u_value, 28);
}
@@ -7972,8 +7976,8 @@ static char *LD_S9_(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("LD %s, %" PRId64 "(%s)", rt, s_value, rs);
}
@@ -7995,8 +7999,8 @@ static char *LD_U12_(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("LD %s, 0x%" PRIx64 "(%s)", rt, u_value, rs);
}
@@ -8017,7 +8021,7 @@ static char *LDC1_GP_(uint64 instruction, Dis_info *info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 u_value = extract_u_17_to_2__s2(instruction);
- const char *ft = FPR(ft_value);
+ const char *ft = FPR(ft_value, info);
return img_format("LDC1 %s, 0x%" PRIx64 "($%d)", ft, u_value, 28);
}
@@ -8039,8 +8043,8 @@ static char *LDC1_S9_(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
- const char *ft = FPR(ft_value);
- const char *rs = GPR(rs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("LDC1 %s, %" PRId64 "(%s)", ft, s_value, rs);
}
@@ -8062,8 +8066,8 @@ static char *LDC1_U12_(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction);
- const char *ft = FPR(ft_value);
- const char *rs = GPR(rs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("LDC1 %s, 0x%" PRIx64 "(%s)", ft, u_value, rs);
}
@@ -8085,9 +8089,9 @@ static char *LDC1XS(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ft_value = extract_ft_15_14_13_12_11(instruction);
- const char *ft = FPR(ft_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *ft = FPR(ft_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("LDC1XS %s, %s(%s)", ft, rs, rt);
}
@@ -8109,9 +8113,9 @@ static char *LDC1X(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ft_value = extract_ft_15_14_13_12_11(instruction);
- const char *ft = FPR(ft_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *ft = FPR(ft_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("LDC1X %s, %s(%s)", ft, rs, rt);
}
@@ -8133,7 +8137,7 @@ static char *LDC2(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
- const char *rs = GPR(rs_value);
+ const char *rs = GPR(rs_value, info);
return img_format("LDC2 CP%" PRIu64 ", %" PRId64 "(%s)",
ct_value, s_value, rs);
@@ -8157,8 +8161,8 @@ static char *LDM(uint64 instruction, Dis_info *info)
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
uint64 count3_value = extract_count3_14_13_12(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
uint64 count3 = encode_count3_from_count(count3_value);
return img_format("LDM %s, %" PRId64 "(%s), 0x%" PRIx64,
@@ -8181,7 +8185,7 @@ static char *LDPC_48_(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_41_40_39_38_37(instruction);
int64 s_value = extract_s__se31_15_to_0_31_to_16(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
g_autofree char *s = ADDRESS(s_value, 6, info);
return img_format("LDPC %s, %s", rt, s);
@@ -8204,9 +8208,9 @@ static char *LDX(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("LDX %s, %s(%s)", rd, rs, rt);
}
@@ -8228,9 +8232,9 @@ static char *LDXS(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("LDXS %s, %s(%s)", rd, rs, rt);
}
@@ -8252,8 +8256,8 @@ static char *LH_16_(uint64 instruction, Dis_info *info)
uint64 rs3_value = extract_rs3_6_5_4(instruction);
uint64 u_value = extract_u_2_1__s1(instruction);
- const char *rt3 = GPR(decode_gpr_gpr3(rt3_value));
- const char *rs3 = GPR(decode_gpr_gpr3(rs3_value));
+ const char *rt3 = GPR(decode_gpr_gpr3(rt3_value, info), info);
+ const char *rs3 = GPR(decode_gpr_gpr3(rs3_value, info), info);
return img_format("LH %s, 0x%" PRIx64 "(%s)", rt3, u_value, rs3);
}
@@ -8274,7 +8278,7 @@ static char *LH_GP_(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 u_value = extract_u_17_to_1__s1(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("LH %s, 0x%" PRIx64 "($%d)", rt, u_value, 28);
}
@@ -8296,8 +8300,8 @@ static char *LH_S9_(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("LH %s, %" PRId64 "(%s)", rt, s_value, rs);
}
@@ -8319,8 +8323,8 @@ static char *LH_U12_(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("LH %s, 0x%" PRIx64 "(%s)", rt, u_value, rs);
}
@@ -8342,8 +8346,8 @@ static char *LHE(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("LHE %s, %" PRId64 "(%s)", rt, s_value, rs);
}
@@ -8365,8 +8369,8 @@ static char *LHU_16_(uint64 instruction, Dis_info *info)
uint64 rs3_value = extract_rs3_6_5_4(instruction);
uint64 u_value = extract_u_2_1__s1(instruction);
- const char *rt3 = GPR(decode_gpr_gpr3(rt3_value));
- const char *rs3 = GPR(decode_gpr_gpr3(rs3_value));
+ const char *rt3 = GPR(decode_gpr_gpr3(rt3_value, info), info);
+ const char *rs3 = GPR(decode_gpr_gpr3(rs3_value, info), info);
return img_format("LHU %s, 0x%" PRIx64 "(%s)", rt3, u_value, rs3);
}
@@ -8387,7 +8391,7 @@ static char *LHU_GP_(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 u_value = extract_u_17_to_1__s1(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("LHU %s, 0x%" PRIx64 "($%d)", rt, u_value, 28);
}
@@ -8409,8 +8413,8 @@ static char *LHU_S9_(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("LHU %s, %" PRId64 "(%s)", rt, s_value, rs);
}
@@ -8432,8 +8436,8 @@ static char *LHU_U12_(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("LHU %s, 0x%" PRIx64 "(%s)", rt, u_value, rs);
}
@@ -8455,8 +8459,8 @@ static char *LHUE(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("LHUE %s, %" PRId64 "(%s)", rt, s_value, rs);
}
@@ -8478,9 +8482,9 @@ static char *LHUX(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("LHUX %s, %s(%s)", rd, rs, rt);
}
@@ -8502,9 +8506,9 @@ static char *LHUXS(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("LHUXS %s, %s(%s)", rd, rs, rt);
}
@@ -8526,9 +8530,9 @@ static char *LHXS(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("LHXS %s, %s(%s)", rd, rs, rt);
}
@@ -8550,9 +8554,9 @@ static char *LHX(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("LHX %s, %s(%s)", rd, rs, rt);
}
@@ -8573,7 +8577,7 @@ static char *LI_16_(uint64 instruction, Dis_info *info)
uint64 rt3_value = extract_rt3_9_8_7(instruction);
uint64 eu_value = extract_eu_6_5_4_3_2_1_0(instruction);
- const char *rt3 = GPR(decode_gpr_gpr3(rt3_value));
+ const char *rt3 = GPR(decode_gpr_gpr3(rt3_value, info), info);
int64 eu = encode_eu_from_s_li16(eu_value);
return img_format("LI %s, %" PRId64, rt3, eu);
@@ -8595,7 +8599,7 @@ static char *LI_48_(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_41_40_39_38_37(instruction);
int64 s_value = extract_s__se31_15_to_0_31_to_16(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("LI %s, %" PRId64, rt, s_value);
}
@@ -8617,8 +8621,8 @@ static char *LL(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_s2(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("LL %s, %" PRId64 "(%s)", rt, s_value, rs);
}
@@ -8640,8 +8644,8 @@ static char *LLD(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_s3(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("LLD %s, %" PRId64 "(%s)", rt, s_value, rs);
}
@@ -8663,9 +8667,9 @@ static char *LLDP(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ru_value = extract_ru_7_6_5_4_3(instruction);
- const char *rt = GPR(rt_value);
- const char *ru = GPR(ru_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *ru = GPR(ru_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("LLDP %s, %s, (%s)", rt, ru, rs);
}
@@ -8687,8 +8691,8 @@ static char *LLE(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_s2(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("LLE %s, %" PRId64 "(%s)", rt, s_value, rs);
}
@@ -8710,9 +8714,9 @@ static char *LLWP(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ru_value = extract_ru_7_6_5_4_3(instruction);
- const char *rt = GPR(rt_value);
- const char *ru = GPR(ru_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *ru = GPR(ru_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("LLWP %s, %s, (%s)", rt, ru, rs);
}
@@ -8734,9 +8738,9 @@ static char *LLWPE(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ru_value = extract_ru_7_6_5_4_3(instruction);
- const char *rt = GPR(rt_value);
- const char *ru = GPR(ru_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *ru = GPR(ru_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("LLWPE %s, %s, (%s)", rt, ru, rs);
}
@@ -8759,9 +8763,9 @@ static char *LSA(uint64 instruction, Dis_info *info)
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
uint64 u2_value = extract_u2_10_9(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("LSA %s, %s, %s, 0x%" PRIx64, rd, rs, rt, u2_value);
}
@@ -8782,7 +8786,7 @@ static char *LUI(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
int64 s_value = extract_s__se31_0_11_to_2_20_to_12_s12(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("LUI %s, %%hi(%" PRId64 ")", rt, s_value);
}
@@ -8804,8 +8808,8 @@ static char *LW_16_(uint64 instruction, Dis_info *info)
uint64 rs3_value = extract_rs3_6_5_4(instruction);
uint64 u_value = extract_u_3_2_1_0__s2(instruction);
- const char *rt3 = GPR(decode_gpr_gpr3(rt3_value));
- const char *rs3 = GPR(decode_gpr_gpr3(rs3_value));
+ const char *rt3 = GPR(decode_gpr_gpr3(rt3_value, info), info);
+ const char *rs3 = GPR(decode_gpr_gpr3(rs3_value, info), info);
return img_format("LW %s, 0x%" PRIx64 "(%s)", rt3, u_value, rs3);
}
@@ -8827,8 +8831,8 @@ static char *LW_4X4_(uint64 instruction, Dis_info *info)
uint64 rs4_value = extract_rs4_4_2_1_0(instruction);
uint64 u_value = extract_u_3_8__s2(instruction);
- const char *rt4 = GPR(decode_gpr_gpr4(rt4_value));
- const char *rs4 = GPR(decode_gpr_gpr4(rs4_value));
+ const char *rt4 = GPR(decode_gpr_gpr4(rt4_value, info), info);
+ const char *rs4 = GPR(decode_gpr_gpr4(rs4_value, info), info);
return img_format("LW %s, 0x%" PRIx64 "(%s)", rt4, u_value, rs4);
}
@@ -8849,7 +8853,7 @@ static char *LW_GP_(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 u_value = extract_u_20_to_2__s2(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("LW %s, 0x%" PRIx64 "($%d)", rt, u_value, 28);
}
@@ -8870,7 +8874,7 @@ static char *LW_GP16_(uint64 instruction, Dis_info *info)
uint64 rt3_value = extract_rt3_9_8_7(instruction);
uint64 u_value = extract_u_6_5_4_3_2_1_0__s2(instruction);
- const char *rt3 = GPR(decode_gpr_gpr3(rt3_value));
+ const char *rt3 = GPR(decode_gpr_gpr3(rt3_value, info), info);
return img_format("LW %s, 0x%" PRIx64 "($%d)", rt3, u_value, 28);
}
@@ -8892,8 +8896,8 @@ static char *LW_S9_(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("LW %s, %" PRId64 "(%s)", rt, s_value, rs);
}
@@ -8914,7 +8918,7 @@ static char *LW_SP_(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_9_8_7_6_5(instruction);
uint64 u_value = extract_u_4_3_2_1_0__s2(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("LW %s, 0x%" PRIx64 "($%d)", rt, u_value, 29);
}
@@ -8936,8 +8940,8 @@ static char *LW_U12_(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("LW %s, 0x%" PRIx64 "(%s)", rt, u_value, rs);
}
@@ -8958,7 +8962,7 @@ static char *LWC1_GP_(uint64 instruction, Dis_info *info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 u_value = extract_u_17_to_2__s2(instruction);
- const char *ft = FPR(ft_value);
+ const char *ft = FPR(ft_value, info);
return img_format("LWC1 %s, 0x%" PRIx64 "($%d)", ft, u_value, 28);
}
@@ -8980,8 +8984,8 @@ static char *LWC1_S9_(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
- const char *ft = FPR(ft_value);
- const char *rs = GPR(rs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("LWC1 %s, %" PRId64 "(%s)", ft, s_value, rs);
}
@@ -9003,8 +9007,8 @@ static char *LWC1_U12_(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction);
- const char *ft = FPR(ft_value);
- const char *rs = GPR(rs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("LWC1 %s, 0x%" PRIx64 "(%s)", ft, u_value, rs);
}
@@ -9026,9 +9030,9 @@ static char *LWC1X(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ft_value = extract_ft_15_14_13_12_11(instruction);
- const char *ft = FPR(ft_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *ft = FPR(ft_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("LWC1X %s, %s(%s)", ft, rs, rt);
}
@@ -9050,9 +9054,9 @@ static char *LWC1XS(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ft_value = extract_ft_15_14_13_12_11(instruction);
- const char *ft = FPR(ft_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *ft = FPR(ft_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("LWC1XS %s, %s(%s)", ft, rs, rt);
}
@@ -9074,7 +9078,7 @@ static char *LWC2(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
- const char *rs = GPR(rs_value);
+ const char *rs = GPR(rs_value, info);
return img_format("LWC2 CP%" PRIu64 ", %" PRId64 "(%s)",
ct_value, s_value, rs);
@@ -9097,8 +9101,8 @@ static char *LWE(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("LWE %s, %" PRId64 "(%s)", rt, s_value, rs);
}
@@ -9121,8 +9125,8 @@ static char *LWM(uint64 instruction, Dis_info *info)
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
uint64 count3_value = extract_count3_14_13_12(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
uint64 count3 = encode_count3_from_count(count3_value);
return img_format("LWM %s, %" PRId64 "(%s), 0x%" PRIx64,
@@ -9145,7 +9149,7 @@ static char *LWPC_48_(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_41_40_39_38_37(instruction);
int64 s_value = extract_s__se31_15_to_0_31_to_16(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
g_autofree char *s = ADDRESS(s_value, 6, info);
return img_format("LWPC %s, %s", rt, s);
@@ -9167,7 +9171,7 @@ static char *LWU_GP_(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 u_value = extract_u_17_to_2__s2(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("LWU %s, 0x%" PRIx64 "($%d)", rt, u_value, 28);
}
@@ -9189,8 +9193,8 @@ static char *LWU_S9_(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("LWU %s, %" PRId64 "(%s)", rt, s_value, rs);
}
@@ -9212,8 +9216,8 @@ static char *LWU_U12_(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("LWU %s, 0x%" PRIx64 "(%s)", rt, u_value, rs);
}
@@ -9235,9 +9239,9 @@ static char *LWUX(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("LWUX %s, %s(%s)", rd, rs, rt);
}
@@ -9259,9 +9263,9 @@ static char *LWUXS(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("LWUXS %s, %s(%s)", rd, rs, rt);
}
@@ -9283,9 +9287,9 @@ static char *LWX(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("LWX %s, %s(%s)", rd, rs, rt);
}
@@ -9307,9 +9311,9 @@ static char *LWXS_16_(uint64 instruction, Dis_info *info)
uint64 rs3_value = extract_rs3_6_5_4(instruction);
uint64 rd3_value = extract_rd3_3_2_1(instruction);
- const char *rd3 = GPR(decode_gpr_gpr3(rd3_value));
- const char *rs3 = GPR(decode_gpr_gpr3(rs3_value));
- uint64 rt3 = decode_gpr_gpr3(rt3_value);
+ const char *rd3 = GPR(decode_gpr_gpr3(rd3_value, info), info);
+ const char *rs3 = GPR(decode_gpr_gpr3(rs3_value, info), info);
+ uint64 rt3 = decode_gpr_gpr3(rt3_value, info);
return img_format("LWXS %s, %s(0x%" PRIx64 ")", rd3, rs3, rt3);
}
@@ -9331,9 +9335,9 @@ static char *LWXS_32_(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("LWXS %s, %s(%s)", rd, rs, rt);
}
@@ -9356,9 +9360,9 @@ static char *MADD_DSP_(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *ac = AC(ac_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *ac = AC(ac_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("MADD %s, %s, %s", ac, rs, rt);
}
@@ -9380,9 +9384,9 @@ static char *MADDF_D(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("MADDF.D %s, %s, %s", fd, fs, ft);
}
@@ -9404,9 +9408,9 @@ static char *MADDF_S(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("MADDF.S %s, %s, %s", fd, fs, ft);
}
@@ -9429,9 +9433,9 @@ static char *MADDU_DSP_(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *ac = AC(ac_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *ac = AC(ac_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("MADDU %s, %s, %s", ac, rs, rt);
}
@@ -9454,9 +9458,9 @@ static char *MAQ_S_W_PHL(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *ac = AC(ac_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *ac = AC(ac_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("MAQ_S.W.PHL %s, %s, %s", ac, rs, rt);
}
@@ -9479,9 +9483,9 @@ static char *MAQ_S_W_PHR(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *ac = AC(ac_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *ac = AC(ac_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("MAQ_S.W.PHR %s, %s, %s", ac, rs, rt);
}
@@ -9504,9 +9508,9 @@ static char *MAQ_SA_W_PHL(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *ac = AC(ac_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *ac = AC(ac_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("MAQ_SA.W.PHL %s, %s, %s", ac, rs, rt);
}
@@ -9529,9 +9533,9 @@ static char *MAQ_SA_W_PHR(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *ac = AC(ac_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *ac = AC(ac_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("MAQ_SA.W.PHR %s, %s, %s", ac, rs, rt);
}
@@ -9553,9 +9557,9 @@ static char *MAX_D(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("MAX.D %s, %s, %s", fd, fs, ft);
}
@@ -9577,9 +9581,9 @@ static char *MAX_S(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("MAX.S %s, %s, %s", fd, fs, ft);
}
@@ -9601,9 +9605,9 @@ static char *MAXA_D(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("MAXA.D %s, %s, %s", fd, fs, ft);
}
@@ -9625,9 +9629,9 @@ static char *MAXA_S(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("MAXA.S %s, %s, %s", fd, fs, ft);
}
@@ -9649,7 +9653,7 @@ static char *MFC0(uint64 instruction, Dis_info *info)
uint64 c0s_value = extract_c0s_20_19_18_17_16(instruction);
uint64 sel_value = extract_sel_15_14_13_12_11(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("MFC0 %s, CP%" PRIu64 ", 0x%" PRIx64,
rt, c0s_value, sel_value);
@@ -9671,8 +9675,8 @@ static char *MFC1(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
- const char *fs = FPR(fs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("MFC1 %s, %s", rt, fs);
}
@@ -9693,7 +9697,7 @@ static char *MFC2(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 cs_value = extract_cs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("MFC2 %s, CP%" PRIu64, rt, cs_value);
}
@@ -9715,7 +9719,7 @@ static char *MFGC0(uint64 instruction, Dis_info *info)
uint64 c0s_value = extract_c0s_20_19_18_17_16(instruction);
uint64 sel_value = extract_sel_15_14_13_12_11(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("MFGC0 %s, CP%" PRIu64 ", 0x%" PRIx64,
rt, c0s_value, sel_value);
@@ -9738,7 +9742,7 @@ static char *MFHC0(uint64 instruction, Dis_info *info)
uint64 c0s_value = extract_c0s_20_19_18_17_16(instruction);
uint64 sel_value = extract_sel_15_14_13_12_11(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("MFHC0 %s, CP%" PRIu64 ", 0x%" PRIx64,
rt, c0s_value, sel_value);
@@ -9760,8 +9764,8 @@ static char *MFHC1(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
- const char *fs = FPR(fs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("MFHC1 %s, %s", rt, fs);
}
@@ -9782,7 +9786,7 @@ static char *MFHC2(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 cs_value = extract_cs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("MFHC2 %s, CP%" PRIu64, rt, cs_value);
}
@@ -9804,7 +9808,7 @@ static char *MFHGC0(uint64 instruction, Dis_info *info)
uint64 c0s_value = extract_c0s_20_19_18_17_16(instruction);
uint64 sel_value = extract_sel_15_14_13_12_11(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("MFHGC0 %s, CP%" PRIu64 ", 0x%" PRIx64,
rt, c0s_value, sel_value);
@@ -9825,8 +9829,8 @@ static char *MFHI_DSP_(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *rt = GPR(rt_value);
- const char *ac = AC(ac_value);
+ const char *rt = GPR(rt_value, info);
+ const char *ac = AC(ac_value, info);
return img_format("MFHI %s, %s", rt, ac);
}
@@ -9849,7 +9853,7 @@ static char *MFHTR(uint64 instruction, Dis_info *info)
uint64 sel_value = extract_sel_15_14_13_12_11(instruction);
uint64 u_value = extract_u_10(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("MFHTR %s, 0x%" PRIx64 ", 0x%" PRIx64 ", 0x%" PRIx64,
rt, c0s_value, u_value, sel_value);
@@ -9870,8 +9874,8 @@ static char *MFLO_DSP_(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *rt = GPR(rt_value);
- const char *ac = AC(ac_value);
+ const char *rt = GPR(rt_value, info);
+ const char *ac = AC(ac_value, info);
return img_format("MFLO %s, %s", rt, ac);
}
@@ -9894,7 +9898,7 @@ static char *MFTR(uint64 instruction, Dis_info *info)
uint64 sel_value = extract_sel_15_14_13_12_11(instruction);
uint64 u_value = extract_u_10(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("MFTR %s, 0x%" PRIx64 ", 0x%" PRIx64 ", 0x%" PRIx64,
rt, c0s_value, u_value, sel_value);
@@ -9917,9 +9921,9 @@ static char *MIN_D(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("MIN.D %s, %s, %s", fd, fs, ft);
}
@@ -9941,9 +9945,9 @@ static char *MIN_S(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("MIN.S %s, %s, %s", fd, fs, ft);
}
@@ -9965,9 +9969,9 @@ static char *MINA_D(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("MINA.D %s, %s, %s", fd, fs, ft);
}
@@ -9989,9 +9993,9 @@ static char *MINA_S(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("MINA.S %s, %s, %s", fd, fs, ft);
}
@@ -10013,9 +10017,9 @@ static char *MOD(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("MOD %s, %s, %s", rd, rs, rt);
}
@@ -10037,9 +10041,9 @@ static char *MODSUB(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("MODSUB %s, %s, %s", rd, rs, rt);
}
@@ -10061,9 +10065,9 @@ static char *MODU(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("MODU %s, %s, %s", rd, rs, rt);
}
@@ -10084,8 +10088,8 @@ static char *MOV_D(uint64 instruction, Dis_info *info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("MOV.D %s, %s", ft, fs);
}
@@ -10106,8 +10110,8 @@ static char *MOV_S(uint64 instruction, Dis_info *info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("MOV.S %s, %s", ft, fs);
}
@@ -10129,8 +10133,8 @@ static char *MOVE_BALC(uint64 instruction, Dis_info
*info)
uint64 rd1_value = extract_rdl_25_24(instruction);
int64 s_value = extract_s__se21_0_20_to_1_s1(instruction);
- const char *rd1 = GPR(decode_gpr_gpr1(rd1_value));
- const char *rtz4 = GPR(decode_gpr_gpr4_zero(rtz4_value));
+ const char *rd1 = GPR(decode_gpr_gpr1(rd1_value, info), info);
+ const char *rtz4 = GPR(decode_gpr_gpr4_zero(rtz4_value, info), info);
g_autofree char *s = ADDRESS(s_value, 4, info);
return img_format("MOVE.BALC %s, %s, %s", rd1, rtz4, s);
@@ -10153,11 +10157,11 @@ static char *MOVEP(uint64 instruction, Dis_info *info)
uint64 rd2_value = extract_rd2_3_8(instruction);
uint64 rsz4_value = extract_rsz4_4_2_1_0(instruction);
- const char *rd2 = GPR(decode_gpr_gpr2_reg1(rd2_value));
- const char *re2 = GPR(decode_gpr_gpr2_reg2(rd2_value));
+ const char *rd2 = GPR(decode_gpr_gpr2_reg1(rd2_value, info), info);
+ const char *re2 = GPR(decode_gpr_gpr2_reg2(rd2_value, info), info);
/* !!!!!!!!!! - no conversion function */
- const char *rsz4 = GPR(decode_gpr_gpr4_zero(rsz4_value));
- const char *rtz4 = GPR(decode_gpr_gpr4_zero(rtz4_value));
+ const char *rsz4 = GPR(decode_gpr_gpr4_zero(rsz4_value, info), info);
+ const char *rtz4 = GPR(decode_gpr_gpr4_zero(rtz4_value, info), info);
return img_format("MOVEP %s, %s, %s, %s", rd2, re2, rsz4, rtz4);
/* hand edited */
@@ -10180,10 +10184,10 @@ static char *MOVEP_REV_(uint64 instruction, Dis_info
*info)
uint64 rd2_value = extract_rd2_3_8(instruction);
uint64 rs4_value = extract_rs4_4_2_1_0(instruction);
- const char *rs4 = GPR(decode_gpr_gpr4(rs4_value));
- const char *rt4 = GPR(decode_gpr_gpr4(rt4_value));
- const char *rd2 = GPR(decode_gpr_gpr2_reg1(rd2_value));
- const char *rs2 = GPR(decode_gpr_gpr2_reg2(rd2_value));
+ const char *rs4 = GPR(decode_gpr_gpr4(rs4_value, info), info);
+ const char *rt4 = GPR(decode_gpr_gpr4(rt4_value, info), info);
+ const char *rd2 = GPR(decode_gpr_gpr2_reg1(rd2_value, info), info);
+ const char *rs2 = GPR(decode_gpr_gpr2_reg2(rd2_value, info), info);
/* !!!!!!!!!! - no conversion function */
return img_format("MOVEP %s, %s, %s, %s", rs4, rt4, rd2, rs2);
@@ -10206,8 +10210,8 @@ static char *MOVE(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_9_8_7_6_5(instruction);
uint64 rs_value = extract_rs_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("MOVE %s, %s", rt, rs);
}
@@ -10229,9 +10233,9 @@ static char *MOVN(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("MOVN %s, %s, %s", rd, rs, rt);
}
@@ -10253,9 +10257,9 @@ static char *MOVZ(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("MOVZ %s, %s, %s", rd, rs, rt);
}
@@ -10277,9 +10281,9 @@ static char *MSUB_DSP_(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *ac = AC(ac_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *ac = AC(ac_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("MSUB %s, %s, %s", ac, rs, rt);
}
@@ -10301,9 +10305,9 @@ static char *MSUBF_D(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("MSUBF.D %s, %s, %s", fd, fs, ft);
}
@@ -10325,9 +10329,9 @@ static char *MSUBF_S(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("MSUBF.S %s, %s, %s", fd, fs, ft);
}
@@ -10349,9 +10353,9 @@ static char *MSUBU_DSP_(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *ac = AC(ac_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *ac = AC(ac_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("MSUBU %s, %s, %s", ac, rs, rt);
}
@@ -10373,7 +10377,7 @@ static char *MTC0(uint64 instruction, Dis_info *info)
uint64 c0s_value = extract_c0s_20_19_18_17_16(instruction);
uint64 sel_value = extract_sel_15_14_13_12_11(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("MTC0 %s, CP%" PRIu64 ", 0x%" PRIx64,
rt, c0s_value, sel_value);
@@ -10395,8 +10399,8 @@ static char *MTC1(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
- const char *fs = FPR(fs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("MTC1 %s, %s", rt, fs);
}
@@ -10417,7 +10421,7 @@ static char *MTC2(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 cs_value = extract_cs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("MTC2 %s, CP%" PRIu64, rt, cs_value);
}
@@ -10439,7 +10443,7 @@ static char *MTGC0(uint64 instruction, Dis_info *info)
uint64 c0s_value = extract_c0s_20_19_18_17_16(instruction);
uint64 sel_value = extract_sel_15_14_13_12_11(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("MTGC0 %s, CP%" PRIu64 ", 0x%" PRIx64,
rt, c0s_value, sel_value);
@@ -10462,7 +10466,7 @@ static char *MTHC0(uint64 instruction, Dis_info *info)
uint64 c0s_value = extract_c0s_20_19_18_17_16(instruction);
uint64 sel_value = extract_sel_15_14_13_12_11(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("MTHC0 %s, CP%" PRIu64 ", 0x%" PRIx64,
rt, c0s_value, sel_value);
@@ -10484,8 +10488,8 @@ static char *MTHC1(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
- const char *fs = FPR(fs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("MTHC1 %s, %s", rt, fs);
}
@@ -10506,7 +10510,7 @@ static char *MTHC2(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 cs_value = extract_cs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("MTHC2 %s, CP%" PRIu64, rt, cs_value);
}
@@ -10528,7 +10532,7 @@ static char *MTHGC0(uint64 instruction, Dis_info *info)
uint64 c0s_value = extract_c0s_20_19_18_17_16(instruction);
uint64 sel_value = extract_sel_15_14_13_12_11(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("MTHGC0 %s, CP%" PRIu64 ", 0x%" PRIx64,
rt, c0s_value, sel_value);
@@ -10549,8 +10553,8 @@ static char *MTHI_DSP_(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *rs = GPR(rs_value);
- const char *ac = AC(ac_value);
+ const char *rs = GPR(rs_value, info);
+ const char *ac = AC(ac_value, info);
return img_format("MTHI %s, %s", rs, ac);
}
@@ -10570,8 +10574,8 @@ static char *MTHLIP(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *rs = GPR(rs_value);
- const char *ac = AC(ac_value);
+ const char *rs = GPR(rs_value, info);
+ const char *ac = AC(ac_value, info);
return img_format("MTHLIP %s, %s", rs, ac);
}
@@ -10594,7 +10598,7 @@ static char *MTHTR(uint64 instruction, Dis_info *info)
uint64 sel_value = extract_sel_15_14_13_12_11(instruction);
uint64 u_value = extract_u_10(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("MTHTR %s, 0x%" PRIx64 ", 0x%" PRIx64 ", 0x%" PRIx64,
rt, c0s_value, u_value, sel_value);
@@ -10615,8 +10619,8 @@ static char *MTLO_DSP_(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *rs = GPR(rs_value);
- const char *ac = AC(ac_value);
+ const char *rs = GPR(rs_value, info);
+ const char *ac = AC(ac_value, info);
return img_format("MTLO %s, %s", rs, ac);
}
@@ -10639,7 +10643,7 @@ static char *MTTR(uint64 instruction, Dis_info *info)
uint64 sel_value = extract_sel_15_14_13_12_11(instruction);
uint64 u_value = extract_u_10(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("MTTR %s, 0x%" PRIx64 ", 0x%" PRIx64 ", 0x%" PRIx64,
rt, c0s_value, u_value, sel_value);
@@ -10662,9 +10666,9 @@ static char *MUH(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("MUH %s, %s, %s", rd, rs, rt);
}
@@ -10686,9 +10690,9 @@ static char *MUHU(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("MUHU %s, %s, %s", rd, rs, rt);
}
@@ -10710,9 +10714,9 @@ static char *MUL_32_(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("MUL %s, %s, %s", rd, rs, rt);
}
@@ -10733,8 +10737,8 @@ static char *MUL_4X4_(uint64 instruction, Dis_info
*info)
uint64 rt4_value = extract_rt4_9_7_6_5(instruction);
uint64 rs4_value = extract_rs4_4_2_1_0(instruction);
- const char *rs4 = GPR(decode_gpr_gpr4(rs4_value));
- const char *rt4 = GPR(decode_gpr_gpr4(rt4_value));
+ const char *rs4 = GPR(decode_gpr_gpr4(rs4_value, info), info);
+ const char *rt4 = GPR(decode_gpr_gpr4(rt4_value, info), info);
return img_format("MUL %s, %s", rs4, rt4);
}
@@ -10756,9 +10760,9 @@ static char *MUL_D(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("MUL.D %s, %s, %s", fd, fs, ft);
}
@@ -10781,9 +10785,9 @@ static char *MUL_PH(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("MUL.PH %s, %s, %s", rd, rs, rt);
}
@@ -10806,9 +10810,9 @@ static char *MUL_S_PH(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("MUL_S.PH %s, %s, %s", rd, rs, rt);
}
@@ -10830,9 +10834,9 @@ static char *MUL_S(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("MUL.S %s, %s, %s", fd, fs, ft);
}
@@ -10855,9 +10859,9 @@ static char *MULEQ_S_W_PHL(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("MULEQ_S.W.PHL %s, %s, %s", rd, rs, rt);
}
@@ -10880,9 +10884,9 @@ static char *MULEQ_S_W_PHR(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("MULEQ_S.W.PHR %s, %s, %s", rd, rs, rt);
}
@@ -10905,9 +10909,9 @@ static char *MULEU_S_PH_QBL(uint64 instruction,
Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("MULEU_S.PH.QBL %s, %s, %s", rd, rs, rt);
}
@@ -10930,9 +10934,9 @@ static char *MULEU_S_PH_QBR(uint64 instruction,
Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("MULEU_S.PH.QBR %s, %s, %s", rd, rs, rt);
}
@@ -10955,9 +10959,9 @@ static char *MULQ_RS_PH(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("MULQ_RS.PH %s, %s, %s", rd, rs, rt);
}
@@ -10980,9 +10984,9 @@ static char *MULQ_RS_W(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("MULQ_RS.W %s, %s, %s", rd, rs, rt);
}
@@ -11005,9 +11009,9 @@ static char *MULQ_S_PH(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("MULQ_S.PH %s, %s, %s", rd, rs, rt);
}
@@ -11030,9 +11034,9 @@ static char *MULQ_S_W(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("MULQ_S.W %s, %s, %s", rd, rs, rt);
}
@@ -11055,9 +11059,9 @@ static char *MULSA_W_PH(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *ac = AC(ac_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *ac = AC(ac_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("MULSA.W.PH %s, %s, %s", ac, rs, rt);
}
@@ -11080,9 +11084,9 @@ static char *MULSAQ_S_W_PH(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *ac = AC(ac_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *ac = AC(ac_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("MULSAQ_S.W.PH %s, %s, %s", ac, rs, rt);
}
@@ -11104,9 +11108,9 @@ static char *MULT_DSP_(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *ac = AC(ac_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *ac = AC(ac_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("MULT %s, %s, %s", ac, rs, rt);
}
@@ -11128,9 +11132,9 @@ static char *MULTU_DSP_(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *ac = AC(ac_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *ac = AC(ac_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("MULTU %s, %s, %s", ac, rs, rt);
}
@@ -11152,9 +11156,9 @@ static char *MULU(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("MULU %s, %s, %s", rd, rs, rt);
}
@@ -11175,8 +11179,8 @@ static char *NEG_D(uint64 instruction, Dis_info *info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("NEG.D %s, %s", ft, fs);
}
@@ -11197,8 +11201,8 @@ static char *NEG_S(uint64 instruction, Dis_info *info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("NEG.S %s, %s", ft, fs);
}
@@ -11256,9 +11260,9 @@ static char *NOR(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("NOR %s, %s, %s", rd, rs, rt);
}
@@ -11279,8 +11283,8 @@ static char *NOT_16_(uint64 instruction, Dis_info *info)
uint64 rt3_value = extract_rt3_9_8_7(instruction);
uint64 rs3_value = extract_rs3_6_5_4(instruction);
- const char *rt3 = GPR(decode_gpr_gpr3(rt3_value));
- const char *rs3 = GPR(decode_gpr_gpr3(rs3_value));
+ const char *rt3 = GPR(decode_gpr_gpr3(rt3_value, info), info);
+ const char *rs3 = GPR(decode_gpr_gpr3(rs3_value, info), info);
return img_format("NOT %s, %s", rt3, rs3);
}
@@ -11301,8 +11305,8 @@ static char *OR_16_(uint64 instruction, Dis_info *info)
uint64 rt3_value = extract_rt3_9_8_7(instruction);
uint64 rs3_value = extract_rs3_6_5_4(instruction);
- const char *rs3 = GPR(decode_gpr_gpr3(rs3_value));
- const char *rt3 = GPR(decode_gpr_gpr3(rt3_value));
+ const char *rs3 = GPR(decode_gpr_gpr3(rs3_value, info), info);
+ const char *rt3 = GPR(decode_gpr_gpr3(rt3_value, info), info);
return img_format("OR %s, %s", rs3, rt3);
}
@@ -11324,9 +11328,9 @@ static char *OR_32_(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("OR %s, %s, %s", rd, rs, rt);
}
@@ -11348,8 +11352,8 @@ static char *ORI(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("ORI %s, %s, 0x%" PRIx64, rt, rs, u_value);
}
@@ -11372,9 +11376,9 @@ static char *PACKRL_PH(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("PACKRL.PH %s, %s, %s", rd, rs, rt);
}
@@ -11415,9 +11419,9 @@ static char *PICK_PH(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("PICK.PH %s, %s, %s", rd, rs, rt);
}
@@ -11440,9 +11444,9 @@ static char *PICK_QB(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("PICK.QB %s, %s, %s", rd, rs, rt);
}
@@ -11464,8 +11468,8 @@ static char *PRECEQ_W_PHL(uint64 instruction, Dis_info
*info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("PRECEQ.W.PHL %s, %s", rt, rs);
}
@@ -11487,8 +11491,8 @@ static char *PRECEQ_W_PHR(uint64 instruction, Dis_info
*info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("PRECEQ.W.PHR %s, %s", rt, rs);
}
@@ -11510,8 +11514,8 @@ static char *PRECEQU_PH_QBLA(uint64 instruction,
Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("PRECEQU.PH.QBLA %s, %s", rt, rs);
}
@@ -11533,8 +11537,8 @@ static char *PRECEQU_PH_QBL(uint64 instruction,
Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("PRECEQU.PH.QBL %s, %s", rt, rs);
}
@@ -11556,8 +11560,8 @@ static char *PRECEQU_PH_QBRA(uint64 instruction,
Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("PRECEQU.PH.QBRA %s, %s", rt, rs);
}
@@ -11579,8 +11583,8 @@ static char *PRECEQU_PH_QBR(uint64 instruction,
Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("PRECEQU.PH.QBR %s, %s", rt, rs);
}
@@ -11603,8 +11607,8 @@ static char *PRECEU_PH_QBLA(uint64 instruction,
Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("PRECEU.PH.QBLA %s, %s", rt, rs);
}
@@ -11626,8 +11630,8 @@ static char *PRECEU_PH_QBL(uint64 instruction, Dis_info
*info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("PRECEU.PH.QBL %s, %s", rt, rs);
}
@@ -11650,8 +11654,8 @@ static char *PRECEU_PH_QBRA(uint64 instruction,
Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("PRECEU.PH.QBRA %s, %s", rt, rs);
}
@@ -11673,8 +11677,8 @@ static char *PRECEU_PH_QBR(uint64 instruction, Dis_info
*info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("PRECEU.PH.QBR %s, %s", rt, rs);
}
@@ -11697,9 +11701,9 @@ static char *PRECR_QB_PH(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("PRECR.QB.PH %s, %s, %s", rd, rs, rt);
}
@@ -11722,8 +11726,8 @@ static char *PRECR_SRA_PH_W(uint64 instruction,
Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 sa_value = extract_sa_15_14_13_12_11(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("PRECR_SRA.PH.W %s, %s, 0x%" PRIx64, rt, rs, sa_value);
}
@@ -11746,8 +11750,8 @@ static char *PRECR_SRA_R_PH_W(uint64 instruction,
Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 sa_value = extract_sa_15_14_13_12_11(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("PRECR_SRA_R.PH.W %s, %s, 0x%" PRIx64, rt, rs, sa_value);
}
@@ -11770,9 +11774,9 @@ static char *PRECRQ_PH_W(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("PRECRQ.PH.W %s, %s, %s", rd, rs, rt);
}
@@ -11795,9 +11799,9 @@ static char *PRECRQ_QB_PH(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("PRECRQ.QB.PH %s, %s, %s", rd, rs, rt);
}
@@ -11820,9 +11824,9 @@ static char *PRECRQ_RS_PH_W(uint64 instruction,
Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("PRECRQ_RS.PH.W %s, %s, %s", rd, rs, rt);
}
@@ -11845,9 +11849,9 @@ static char *PRECRQU_S_QB_PH(uint64 instruction,
Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("PRECRQU_S.QB.PH %s, %s, %s", rd, rs, rt);
}
@@ -11869,7 +11873,7 @@ static char *PREF_S9_(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
- const char *rs = GPR(rs_value);
+ const char *rs = GPR(rs_value, info);
return img_format("PREF 0x%" PRIx64 ", %s(%s)",
hint_value, s_value, rs);
@@ -11892,7 +11896,7 @@ static char *PREF_U12_(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction);
- const char *rs = GPR(rs_value);
+ const char *rs = GPR(rs_value, info);
return img_format("PREF 0x%" PRIx64 ", 0x%" PRIx64 "(%s)",
hint_value, u_value, rs);
@@ -11915,7 +11919,7 @@ static char *PREFE(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
- const char *rs = GPR(rs_value);
+ const char *rs = GPR(rs_value, info);
return img_format("PREFE 0x%" PRIx64 ", %s(%s)", hint_value, s_value, rs);
}
@@ -11937,8 +11941,8 @@ static char *PREPEND(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 sa_value = extract_sa_15_14_13_12_11(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("PREPEND %s, %s, 0x%" PRIx64, rt, rs, sa_value);
}
@@ -11958,8 +11962,8 @@ static char *RADDU_W_QB(uint64 instruction, Dis_info
*info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("RADDU.W.QB %s, %s", rt, rs);
}
@@ -11979,7 +11983,7 @@ static char *RDDSP(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 mask_value = extract_mask_20_19_18_17_16_15_14(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("RDDSP %s, 0x%" PRIx64, rt, mask_value);
}
@@ -12001,7 +12005,7 @@ static char *RDHWR(uint64 instruction, Dis_info *info)
uint64 hs_value = extract_hs_20_19_18_17_16(instruction);
uint64 sel_value = extract_sel_13_12_11(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("RDHWR %s, CP%" PRIu64 ", 0x%" PRIx64,
rt, hs_value, sel_value);
@@ -12023,8 +12027,8 @@ static char *RDPGPR(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("RDPGPR %s, %s", rt, rs);
}
@@ -12045,8 +12049,8 @@ static char *RECIP_D(uint64 instruction, Dis_info *info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("RECIP.D %s, %s", ft, fs);
}
@@ -12067,8 +12071,8 @@ static char *RECIP_S(uint64 instruction, Dis_info *info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("RECIP.S %s, %s", ft, fs);
}
@@ -12089,7 +12093,7 @@ static char *REPL_PH(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
int64 s_value = extract_s__se9_20_19_18_17_16_15_14_13_12_11(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("REPL.PH %s, %s", rt, s_value);
}
@@ -12110,7 +12114,7 @@ static char *REPL_QB(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 u_value = extract_u_20_19_18_17_16_15_14_13(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("REPL.QB %s, 0x%" PRIx64, rt, u_value);
}
@@ -12131,8 +12135,8 @@ static char *REPLV_PH(uint64 instruction, Dis_info
*info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("REPLV.PH %s, %s", rt, rs);
}
@@ -12152,8 +12156,8 @@ static char *REPLV_QB(uint64 instruction, Dis_info
*info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("REPLV.QB %s, %s", rt, rs);
}
@@ -12177,7 +12181,7 @@ static char *RESTORE_32_(uint64 instruction, Dis_info
*info)
uint64 gp_value = extract_gp_2(instruction);
g_autofree char *save_restore_str = save_restore_list(
- rt_value, count_value, gp_value);
+ rt_value, count_value, gp_value, info);
return img_format("RESTORE 0x%" PRIx64 "%s", u_value, save_restore_str);
}
@@ -12199,7 +12203,7 @@ static char *RESTORE_JRC_16_(uint64 instruction,
Dis_info *info)
uint64 count_value = extract_count_3_2_1_0(instruction);
g_autofree char *save_restore_str = save_restore_list(
- encode_rt1_from_rt(rt1_value), count_value, 0);
+ encode_rt1_from_rt(rt1_value), count_value, 0, info);
return img_format("RESTORE.JRC 0x%" PRIx64 "%s", u_value,
save_restore_str);
}
@@ -12222,7 +12226,7 @@ static char *RESTORE_JRC_32_(uint64 instruction,
Dis_info *info)
uint64 gp_value = extract_gp_2(instruction);
g_autofree char *save_restore_str = save_restore_list(
- rt_value, count_value, gp_value);
+ rt_value, count_value, gp_value, info);
return img_format("RESTORE.JRC 0x%" PRIx64 "%s", u_value,
save_restore_str);
}
@@ -12263,8 +12267,8 @@ static char *RINT_D(uint64 instruction, Dis_info *info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("RINT.D %s, %s", ft, fs);
}
@@ -12285,8 +12289,8 @@ static char *RINT_S(uint64 instruction, Dis_info *info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("RINT.S %s, %s", ft, fs);
}
@@ -12308,8 +12312,8 @@ static char *ROTR(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 shift_value = extract_shift_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("ROTR %s, %s, 0x%" PRIx64, rt, rs, shift_value);
}
@@ -12331,9 +12335,9 @@ static char *ROTRV(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("ROTRV %s, %s, %s", rd, rs, rt);
}
@@ -12357,8 +12361,8 @@ static char *ROTX(uint64 instruction, Dis_info *info)
uint64 stripe_value = extract_stripe_6(instruction);
uint64 shift_value = extract_shift_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("ROTX %s, %s, 0x%" PRIx64 ", 0x%" PRIx64 ", 0x%" PRIx64,
rt, rs, shift_value, shiftx_value, stripe_value);
@@ -12380,8 +12384,8 @@ static char *ROUND_L_D(uint64 instruction, Dis_info
*info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("ROUND.L.D %s, %s", ft, fs);
}
@@ -12402,8 +12406,8 @@ static char *ROUND_L_S(uint64 instruction, Dis_info
*info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("ROUND.L.S %s, %s", ft, fs);
}
@@ -12424,8 +12428,8 @@ static char *ROUND_W_D(uint64 instruction, Dis_info
*info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("ROUND.W.D %s, %s", ft, fs);
}
@@ -12446,8 +12450,8 @@ static char *ROUND_W_S(uint64 instruction, Dis_info
*info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("ROUND.W.S %s, %s", ft, fs);
}
@@ -12468,8 +12472,8 @@ static char *RSQRT_D(uint64 instruction, Dis_info *info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("RSQRT.D %s, %s", ft, fs);
}
@@ -12490,8 +12494,8 @@ static char *RSQRT_S(uint64 instruction, Dis_info *info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("RSQRT.S %s, %s", ft, fs);
}
@@ -12514,7 +12518,7 @@ static char *SAVE_16_(uint64 instruction, Dis_info
*info)
uint64 count_value = extract_count_3_2_1_0(instruction);
g_autofree char *save_restore_str = save_restore_list(
- encode_rt1_from_rt(rt1_value), count_value, 0);
+ encode_rt1_from_rt(rt1_value), count_value, 0, info);
return img_format("SAVE 0x%" PRIx64 "%s", u_value, save_restore_str);
}
@@ -12537,7 +12541,7 @@ static char *SAVE_32_(uint64 instruction, Dis_info
*info)
uint64 gp_value = extract_gp_2(instruction);
g_autofree char *save_restore_str = save_restore_list(
- rt_value, count_value, gp_value);
+ rt_value, count_value, gp_value, info);
return img_format("SAVE 0x%" PRIx64 "%s", u_value, save_restore_str);
}
@@ -12578,8 +12582,8 @@ static char *SB_16_(uint64 instruction, Dis_info *info)
uint64 rs3_value = extract_rs3_6_5_4(instruction);
uint64 u_value = extract_u_1_0(instruction);
- const char *rtz3 = GPR(decode_gpr_gpr3_src_store(rtz3_value));
- const char *rs3 = GPR(decode_gpr_gpr3(rs3_value));
+ const char *rtz3 = GPR(decode_gpr_gpr3_src_store(rtz3_value, info), info);
+ const char *rs3 = GPR(decode_gpr_gpr3(rs3_value, info), info);
return img_format("SB %s, 0x%" PRIx64 "(%s)", rtz3, u_value, rs3);
}
@@ -12600,7 +12604,7 @@ static char *SB_GP_(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 u_value = extract_u_17_to_0(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("SB %s, 0x%" PRIx64 "($%d)", rt, u_value, 28);
}
@@ -12622,8 +12626,8 @@ static char *SB_S9_(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SB %s, %s(%s)", rt, s_value, rs);
}
@@ -12645,8 +12649,8 @@ static char *SB_U12_(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SB %s, 0x%" PRIx64 "(%s)", rt, u_value, rs);
}
@@ -12668,8 +12672,8 @@ static char *SBE(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SBE %s, %s(%s)", rt, s_value, rs);
}
@@ -12691,9 +12695,9 @@ static char *SBX(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("SBX %s, %s(%s)", rd, rs, rt);
}
@@ -12715,8 +12719,8 @@ static char *SC(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_s2(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SC %s, %s(%s)", rt, s_value, rs);
}
@@ -12738,8 +12742,8 @@ static char *SCD(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_s3(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SCD %s, %s(%s)", rt, s_value, rs);
}
@@ -12761,9 +12765,9 @@ static char *SCDP(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ru_value = extract_ru_7_6_5_4_3(instruction);
- const char *rt = GPR(rt_value);
- const char *ru = GPR(ru_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *ru = GPR(ru_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SCDP %s, %s, (%s)", rt, ru, rs);
}
@@ -12785,8 +12789,8 @@ static char *SCE(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_s2(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SCE %s, %s(%s)", rt, s_value, rs);
}
@@ -12808,9 +12812,9 @@ static char *SCWP(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ru_value = extract_ru_7_6_5_4_3(instruction);
- const char *rt = GPR(rt_value);
- const char *ru = GPR(ru_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *ru = GPR(ru_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SCWP %s, %s, (%s)", rt, ru, rs);
}
@@ -12832,9 +12836,9 @@ static char *SCWPE(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ru_value = extract_ru_7_6_5_4_3(instruction);
- const char *rt = GPR(rt_value);
- const char *ru = GPR(ru_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *ru = GPR(ru_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SCWPE %s, %s, (%s)", rt, ru, rs);
}
@@ -12855,7 +12859,7 @@ static char *SD_GP_(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 u_value = extract_u_20_to_3__s3(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("SD %s, 0x%" PRIx64 "($%d)", rt, u_value, 28);
}
@@ -12877,8 +12881,8 @@ static char *SD_S9_(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SD %s, %s(%s)", rt, s_value, rs);
}
@@ -12900,8 +12904,8 @@ static char *SD_U12_(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SD %s, 0x%" PRIx64 "(%s)", rt, u_value, rs);
}
@@ -12960,7 +12964,7 @@ static char *SDC1_GP_(uint64 instruction, Dis_info
*info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 u_value = extract_u_17_to_2__s2(instruction);
- const char *ft = FPR(ft_value);
+ const char *ft = FPR(ft_value, info);
return img_format("SDC1 %s, 0x%" PRIx64 "($%d)", ft, u_value, 28);
}
@@ -12982,8 +12986,8 @@ static char *SDC1_S9_(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
- const char *ft = FPR(ft_value);
- const char *rs = GPR(rs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SDC1 %s, %s(%s)", ft, s_value, rs);
}
@@ -13005,8 +13009,8 @@ static char *SDC1_U12_(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction);
- const char *ft = FPR(ft_value);
- const char *rs = GPR(rs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SDC1 %s, 0x%" PRIx64 "(%s)", ft, u_value, rs);
}
@@ -13028,9 +13032,9 @@ static char *SDC1X(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ft_value = extract_ft_15_14_13_12_11(instruction);
- const char *ft = FPR(ft_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *ft = FPR(ft_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("SDC1X %s, %s(%s)", ft, rs, rt);
}
@@ -13052,9 +13056,9 @@ static char *SDC1XS(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ft_value = extract_ft_15_14_13_12_11(instruction);
- const char *ft = FPR(ft_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *ft = FPR(ft_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("SDC1XS %s, %s(%s)", ft, rs, rt);
}
@@ -13076,7 +13080,7 @@ static char *SDC2(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
- const char *rs = GPR(rs_value);
+ const char *rs = GPR(rs_value, info);
return img_format("SDC2 CP%" PRIu64 ", %s(%s)", cs_value, s_value, rs);
}
@@ -13099,8 +13103,8 @@ static char *SDM(uint64 instruction, Dis_info *info)
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
uint64 count3_value = extract_count3_14_13_12(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
uint64 count3 = encode_count3_from_count(count3_value);
return img_format("SDM %s, %s(%s), 0x%" PRIx64, rt, s_value, rs, count3);
@@ -13122,7 +13126,7 @@ static char *SDPC_48_(uint64 instruction, Dis_info
*info)
uint64 rt_value = extract_rt_41_40_39_38_37(instruction);
int64 s_value = extract_s__se31_15_to_0_31_to_16(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
g_autofree char *s = ADDRESS(s_value, 6, info);
return img_format("SDPC %s, %s", rt, s);
@@ -13145,9 +13149,9 @@ static char *SDXS(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("SDXS %s, %s(%s)", rd, rs, rt);
}
@@ -13169,9 +13173,9 @@ static char *SDX(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("SDX %s, %s(%s)", rd, rs, rt);
}
@@ -13192,8 +13196,8 @@ static char *SEB(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SEB %s, %s", rt, rs);
}
@@ -13214,8 +13218,8 @@ static char *SEH(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SEH %s, %s", rt, rs);
}
@@ -13237,9 +13241,9 @@ static char *SEL_D(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("SEL.D %s, %s, %s", fd, fs, ft);
}
@@ -13261,9 +13265,9 @@ static char *SEL_S(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("SEL.S %s, %s, %s", fd, fs, ft);
}
@@ -13285,9 +13289,9 @@ static char *SELEQZ_D(uint64 instruction, Dis_info
*info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("SELEQZ.D %s, %s, %s", fd, fs, ft);
}
@@ -13309,9 +13313,9 @@ static char *SELEQZ_S(uint64 instruction, Dis_info
*info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("SELEQZ.S %s, %s, %s", fd, fs, ft);
}
@@ -13333,9 +13337,9 @@ static char *SELNEZ_D(uint64 instruction, Dis_info
*info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("SELNEZ.D %s, %s, %s", fd, fs, ft);
}
@@ -13357,9 +13361,9 @@ static char *SELNEZ_S(uint64 instruction, Dis_info
*info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("SELNEZ.S %s, %s, %s", fd, fs, ft);
}
@@ -13381,8 +13385,8 @@ static char *SEQI(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SEQI %s, %s, 0x%" PRIx64, rt, rs, u_value);
}
@@ -13404,8 +13408,8 @@ static char *SH_16_(uint64 instruction, Dis_info *info)
uint64 rs3_value = extract_rs3_6_5_4(instruction);
uint64 u_value = extract_u_2_1__s1(instruction);
- const char *rtz3 = GPR(decode_gpr_gpr3_src_store(rtz3_value));
- const char *rs3 = GPR(decode_gpr_gpr3(rs3_value));
+ const char *rtz3 = GPR(decode_gpr_gpr3_src_store(rtz3_value, info), info);
+ const char *rs3 = GPR(decode_gpr_gpr3(rs3_value, info), info);
return img_format("SH %s, 0x%" PRIx64 "(%s)", rtz3, u_value, rs3);
}
@@ -13426,7 +13430,7 @@ static char *SH_GP_(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 u_value = extract_u_17_to_1__s1(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("SH %s, 0x%" PRIx64 "($%d)", rt, u_value, 28);
}
@@ -13448,8 +13452,8 @@ static char *SH_S9_(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SH %s, %" PRId64 "(%s)", rt, s_value, rs);
}
@@ -13471,8 +13475,8 @@ static char *SH_U12_(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SH %s, 0x%" PRIx64 "(%s)", rt, u_value, rs);
}
@@ -13494,8 +13498,8 @@ static char *SHE(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SHE %s, %" PRId64 "(%s)", rt, s_value, rs);
}
@@ -13516,7 +13520,7 @@ static char *SHILO(uint64 instruction, Dis_info *info)
int64 shift_value = extract_shift__se5_21_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *ac = AC(ac_value);
+ const char *ac = AC(ac_value, info);
return img_format("SHILO %s, 0x%" PRIx64, ac, shift_value);
}
@@ -13537,8 +13541,8 @@ static char *SHILOV(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ac_value = extract_ac_15_14(instruction);
- const char *rs = GPR(rs_value);
- const char *ac = AC(ac_value);
+ const char *rs = GPR(rs_value, info);
+ const char *ac = AC(ac_value, info);
return img_format("SHILOV %s, %s", ac, rs);
}
@@ -13560,8 +13564,8 @@ static char *SHLL_PH(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 sa_value = extract_sa_15_14_13_12(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SHLL.PH %s, %s, 0x%" PRIx64, rt, rs, sa_value);
}
@@ -13583,8 +13587,8 @@ static char *SHLL_QB(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 sa_value = extract_sa_15_14_13(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SHLL.QB %s, %s, 0x%" PRIx64, rt, rs, sa_value);
}
@@ -13607,8 +13611,8 @@ static char *SHLL_S_PH(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 sa_value = extract_sa_15_14_13_12(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SHLL_S.PH %s, %s, 0x%" PRIx64, rt, rs, sa_value);
}
@@ -13630,8 +13634,8 @@ static char *SHLL_S_W(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 sa_value = extract_sa_15_14_13_12_11(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SHLL_S.W %s, %s, 0x%" PRIx64, rt, rs, sa_value);
}
@@ -13654,9 +13658,9 @@ static char *SHLLV_PH(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SHLLV.PH %s, %s, %s", rd, rt, rs);
}
@@ -13678,9 +13682,9 @@ static char *SHLLV_QB(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SHLLV.QB %s, %s, %s", rd, rt, rs);
}
@@ -13703,9 +13707,9 @@ static char *SHLLV_S_PH(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SHLLV_S.PH %s, %s, %s", rd, rt, rs);
}
@@ -13727,9 +13731,9 @@ static char *SHLLV_S_W(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SHLLV_S.W %s, %s, %s", rd, rt, rs);
}
@@ -13751,8 +13755,8 @@ static char *SHRA_PH(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 sa_value = extract_sa_15_14_13_12(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SHRA.PH %s, %s, 0x%" PRIx64, rt, rs, sa_value);
}
@@ -13774,8 +13778,8 @@ static char *SHRA_QB(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 sa_value = extract_sa_15_14_13(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SHRA.QB %s, %s, 0x%" PRIx64, rt, rs, sa_value);
}
@@ -13797,8 +13801,8 @@ static char *SHRA_R_PH(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 sa_value = extract_sa_15_14_13_12(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SHRA_R.PH %s, %s, 0x%" PRIx64, rt, rs, sa_value);
}
@@ -13820,8 +13824,8 @@ static char *SHRA_R_QB(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 sa_value = extract_sa_15_14_13(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SHRA_R.QB %s, %s, 0x%" PRIx64, rt, rs, sa_value);
}
@@ -13843,8 +13847,8 @@ static char *SHRA_R_W(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 sa_value = extract_sa_15_14_13_12_11(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SHRA_R.W %s, %s, 0x%" PRIx64, rt, rs, sa_value);
}
@@ -13866,9 +13870,9 @@ static char *SHRAV_PH(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SHRAV.PH %s, %s, %s", rd, rt, rs);
}
@@ -13890,9 +13894,9 @@ static char *SHRAV_QB(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SHRAV.QB %s, %s, %s", rd, rt, rs);
}
@@ -13914,9 +13918,9 @@ static char *SHRAV_R_PH(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SHRAV_R.PH %s, %s, %s", rd, rt, rs);
}
@@ -13938,9 +13942,9 @@ static char *SHRAV_R_QB(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SHRAV_R.QB %s, %s, %s", rd, rt, rs);
}
@@ -13962,9 +13966,9 @@ static char *SHRAV_R_W(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SHRAV_R.W %s, %s, %s", rd, rt, rs);
}
@@ -13986,8 +13990,8 @@ static char *SHRL_PH(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 sa_value = extract_sa_15_14_13_12(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SHRL.PH %s, %s, 0x%" PRIx64, rt, rs, sa_value);
}
@@ -14009,8 +14013,8 @@ static char *SHRL_QB(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 sa_value = extract_sa_15_14_13(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SHRL.QB %s, %s, 0x%" PRIx64, rt, rs, sa_value);
}
@@ -14033,9 +14037,9 @@ static char *SHRLV_PH(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SHRLV.PH %s, %s, %s", rd, rt, rs);
}
@@ -14057,9 +14061,9 @@ static char *SHRLV_QB(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SHRLV.QB %s, %s, %s", rd, rt, rs);
}
@@ -14081,9 +14085,9 @@ static char *SHX(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("SHX %s, %s(%s)", rd, rs, rt);
}
@@ -14105,9 +14109,9 @@ static char *SHXS(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("SHXS %s, %s(%s)", rd, rs, rt);
}
@@ -14148,8 +14152,8 @@ static char *SLL_16_(uint64 instruction, Dis_info *info)
uint64 rs3_value = extract_rs3_6_5_4(instruction);
uint64 shift3_value = extract_shift3_2_1_0(instruction);
- const char *rt3 = GPR(decode_gpr_gpr3(rt3_value));
- const char *rs3 = GPR(decode_gpr_gpr3(rs3_value));
+ const char *rt3 = GPR(decode_gpr_gpr3(rt3_value, info), info);
+ const char *rs3 = GPR(decode_gpr_gpr3(rs3_value, info), info);
uint64 shift3 = encode_shift3_from_shift(shift3_value);
return img_format("SLL %s, %s, 0x%" PRIx64, rt3, rs3, shift3);
@@ -14172,8 +14176,8 @@ static char *SLL_32_(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 shift_value = extract_shift_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SLL %s, %s, 0x%" PRIx64, rt, rs, shift_value);
}
@@ -14195,9 +14199,9 @@ static char *SLLV(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("SLLV %s, %s, %s", rd, rs, rt);
}
@@ -14219,9 +14223,9 @@ static char *SLT(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("SLT %s, %s, %s", rd, rs, rt);
}
@@ -14243,8 +14247,8 @@ static char *SLTI(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SLTI %s, %s, 0x%" PRIx64, rt, rs, u_value);
}
@@ -14266,8 +14270,8 @@ static char *SLTIU(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SLTIU %s, %s, 0x%" PRIx64, rt, rs, u_value);
}
@@ -14289,9 +14293,9 @@ static char *SLTU(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("SLTU %s, %s, %s", rd, rs, rt);
}
@@ -14313,9 +14317,9 @@ static char *SOV(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("SOV %s, %s, %s", rd, rs, rt);
}
@@ -14355,8 +14359,8 @@ static char *SQRT_D(uint64 instruction, Dis_info *info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("SQRT.D %s, %s", ft, fs);
}
@@ -14377,8 +14381,8 @@ static char *SQRT_S(uint64 instruction, Dis_info *info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("SQRT.S %s, %s", ft, fs);
}
@@ -14400,8 +14404,8 @@ static char *SRA(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 shift_value = extract_shift_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SRA %s, %s, 0x%" PRIx64, rt, rs, shift_value);
}
@@ -14423,9 +14427,9 @@ static char *SRAV(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("SRAV %s, %s, %s", rd, rs, rt);
}
@@ -14447,8 +14451,8 @@ static char *SRL_16_(uint64 instruction, Dis_info *info)
uint64 rs3_value = extract_rs3_6_5_4(instruction);
uint64 shift3_value = extract_shift3_2_1_0(instruction);
- const char *rt3 = GPR(decode_gpr_gpr3(rt3_value));
- const char *rs3 = GPR(decode_gpr_gpr3(rs3_value));
+ const char *rt3 = GPR(decode_gpr_gpr3(rt3_value, info), info);
+ const char *rs3 = GPR(decode_gpr_gpr3(rs3_value, info), info);
uint64 shift3 = encode_shift3_from_shift(shift3_value);
return img_format("SRL %s, %s, 0x%" PRIx64, rt3, rs3, shift3);
@@ -14471,8 +14475,8 @@ static char *SRL_32_(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 shift_value = extract_shift_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SRL %s, %s, 0x%" PRIx64, rt, rs, shift_value);
}
@@ -14494,9 +14498,9 @@ static char *SRLV(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("SRLV %s, %s, %s", rd, rs, rt);
}
@@ -14518,9 +14522,9 @@ static char *SUB(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("SUB %s, %s, %s", rd, rs, rt);
}
@@ -14542,9 +14546,9 @@ static char *SUB_D(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("SUB.D %s, %s, %s", fd, fs, ft);
}
@@ -14566,9 +14570,9 @@ static char *SUB_S(uint64 instruction, Dis_info *info)
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
uint64 fd_value = extract_fd_15_14_13_12_11(instruction);
- const char *fd = FPR(fd_value);
- const char *fs = FPR(fs_value);
- const char *ft = FPR(ft_value);
+ const char *fd = FPR(fd_value, info);
+ const char *fs = FPR(fs_value, info);
+ const char *ft = FPR(ft_value, info);
return img_format("SUB.S %s, %s, %s", fd, fs, ft);
}
@@ -14590,9 +14594,9 @@ static char *SUBQ_PH(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("SUBQ.PH %s, %s, %s", rd, rs, rt);
}
@@ -14615,9 +14619,9 @@ static char *SUBQ_S_PH(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("SUBQ_S.PH %s, %s, %s", rd, rs, rt);
}
@@ -14640,9 +14644,9 @@ static char *SUBQ_S_W(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("SUBQ_S.W %s, %s, %s", rd, rs, rt);
}
@@ -14665,9 +14669,9 @@ static char *SUBQH_PH(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("SUBQH.PH %s, %s, %s", rd, rs, rt);
}
@@ -14690,9 +14694,9 @@ static char *SUBQH_R_PH(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("SUBQH_R.PH %s, %s, %s", rd, rs, rt);
}
@@ -14715,9 +14719,9 @@ static char *SUBQH_R_W(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("SUBQH_R.W %s, %s, %s", rd, rs, rt);
}
@@ -14740,9 +14744,9 @@ static char *SUBQH_W(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("SUBQH.W %s, %s, %s", rd, rs, rt);
}
@@ -14764,9 +14768,9 @@ static char *SUBU_16_(uint64 instruction, Dis_info
*info)
uint64 rs3_value = extract_rs3_6_5_4(instruction);
uint64 rd3_value = extract_rd3_3_2_1(instruction);
- const char *rd3 = GPR(decode_gpr_gpr3(rd3_value));
- const char *rs3 = GPR(decode_gpr_gpr3(rs3_value));
- const char *rt3 = GPR(decode_gpr_gpr3(rt3_value));
+ const char *rd3 = GPR(decode_gpr_gpr3(rd3_value, info), info);
+ const char *rs3 = GPR(decode_gpr_gpr3(rs3_value, info), info);
+ const char *rt3 = GPR(decode_gpr_gpr3(rt3_value, info), info);
return img_format("SUBU %s, %s, %s", rd3, rs3, rt3);
}
@@ -14788,9 +14792,9 @@ static char *SUBU_32_(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("SUBU %s, %s, %s", rd, rs, rt);
}
@@ -14812,9 +14816,9 @@ static char *SUBU_PH(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("SUBU.PH %s, %s, %s", rd, rs, rt);
}
@@ -14836,9 +14840,9 @@ static char *SUBU_QB(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("SUBU.QB %s, %s, %s", rd, rs, rt);
}
@@ -14861,9 +14865,9 @@ static char *SUBU_S_PH(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("SUBU_S.PH %s, %s, %s", rd, rs, rt);
}
@@ -14886,9 +14890,9 @@ static char *SUBU_S_QB(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("SUBU_S.QB %s, %s, %s", rd, rs, rt);
}
@@ -14911,9 +14915,9 @@ static char *SUBUH_QB(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("SUBUH.QB %s, %s, %s", rd, rs, rt);
}
@@ -14936,9 +14940,9 @@ static char *SUBUH_R_QB(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("SUBUH_R.QB %s, %s, %s", rd, rs, rt);
}
@@ -14960,8 +14964,8 @@ static char *SW_16_(uint64 instruction, Dis_info *info)
uint64 rs3_value = extract_rs3_6_5_4(instruction);
uint64 u_value = extract_u_3_2_1_0__s2(instruction);
- const char *rtz3 = GPR(decode_gpr_gpr3_src_store(rtz3_value));
- const char *rs3 = GPR(decode_gpr_gpr3(rs3_value));
+ const char *rtz3 = GPR(decode_gpr_gpr3_src_store(rtz3_value, info), info);
+ const char *rs3 = GPR(decode_gpr_gpr3(rs3_value, info), info);
return img_format("SW %s, 0x%" PRIx64 "(%s)", rtz3, u_value, rs3);
}
@@ -14983,8 +14987,8 @@ static char *SW_4X4_(uint64 instruction, Dis_info *info)
uint64 rs4_value = extract_rs4_4_2_1_0(instruction);
uint64 u_value = extract_u_3_8__s2(instruction);
- const char *rtz4 = GPR(decode_gpr_gpr4_zero(rtz4_value));
- const char *rs4 = GPR(decode_gpr_gpr4(rs4_value));
+ const char *rtz4 = GPR(decode_gpr_gpr4_zero(rtz4_value, info), info);
+ const char *rs4 = GPR(decode_gpr_gpr4(rs4_value, info), info);
return img_format("SW %s, 0x%" PRIx64 "(%s)", rtz4, u_value, rs4);
}
@@ -15005,7 +15009,7 @@ static char *SW_GP16_(uint64 instruction, Dis_info
*info)
uint64 u_value = extract_u_6_5_4_3_2_1_0__s2(instruction);
uint64 rtz3_value = extract_rtz3_9_8_7(instruction);
- const char *rtz3 = GPR(decode_gpr_gpr3_src_store(rtz3_value));
+ const char *rtz3 = GPR(decode_gpr_gpr3_src_store(rtz3_value, info), info);
return img_format("SW %s, 0x%" PRIx64 "($%d)", rtz3, u_value, 28);
}
@@ -15026,7 +15030,7 @@ static char *SW_GP_(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 u_value = extract_u_20_to_2__s2(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("SW %s, 0x%" PRIx64 "($%d)", rt, u_value, 28);
}
@@ -15048,8 +15052,8 @@ static char *SW_S9_(uint64 instruction, Dis_info *info)
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SW %s, %" PRId64 "(%s)", rt, s_value, rs);
}
@@ -15070,7 +15074,7 @@ static char *SW_SP_(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_9_8_7_6_5(instruction);
uint64 u_value = extract_u_4_3_2_1_0__s2(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("SW %s, 0x%" PRIx64 "($%d)", rt, u_value, 29);
}
@@ -15092,8 +15096,8 @@ static char *SW_U12_(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SW %s, 0x%" PRIx64 "(%s)", rt, u_value, rs);
}
@@ -15114,7 +15118,7 @@ static char *SWC1_GP_(uint64 instruction, Dis_info
*info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 u_value = extract_u_17_to_2__s2(instruction);
- const char *ft = FPR(ft_value);
+ const char *ft = FPR(ft_value, info);
return img_format("SWC1 %s, 0x%" PRIx64 "($%d)", ft, u_value, 28);
}
@@ -15136,8 +15140,8 @@ static char *SWC1_S9_(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
- const char *ft = FPR(ft_value);
- const char *rs = GPR(rs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SWC1 %s, %" PRId64 "(%s)", ft, s_value, rs);
}
@@ -15159,8 +15163,8 @@ static char *SWC1_U12_(uint64 instruction, Dis_info
*info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction);
- const char *ft = FPR(ft_value);
- const char *rs = GPR(rs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SWC1 %s, 0x%" PRIx64 "(%s)", ft, u_value, rs);
}
@@ -15182,9 +15186,9 @@ static char *SWC1X(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ft_value = extract_ft_15_14_13_12_11(instruction);
- const char *ft = FPR(ft_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *ft = FPR(ft_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("SWC1X %s, %s(%s)", ft, rs, rt);
}
@@ -15206,9 +15210,9 @@ static char *SWC1XS(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 ft_value = extract_ft_15_14_13_12_11(instruction);
- const char *ft = FPR(ft_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *ft = FPR(ft_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("SWC1XS %s, %s(%s)", ft, rs, rt);
}
@@ -15230,7 +15234,7 @@ static char *SWC2(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
- const char *rs = GPR(rs_value);
+ const char *rs = GPR(rs_value, info);
return img_format("SWC2 CP%" PRIu64 ", %" PRId64 "(%s)",
cs_value, s_value, rs);
@@ -15253,8 +15257,8 @@ static char *SWE(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("SWE %s, %" PRId64 "(%s)", rt, s_value, rs);
}
@@ -15277,8 +15281,8 @@ static char *SWM(uint64 instruction, Dis_info *info)
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
uint64 count3_value = extract_count3_14_13_12(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
uint64 count3 = encode_count3_from_count(count3_value);
return img_format("SWM %s, %" PRId64 "(%s), 0x%" PRIx64,
@@ -15301,7 +15305,7 @@ static char *SWPC_48_(uint64 instruction, Dis_info
*info)
uint64 rt_value = extract_rt_41_40_39_38_37(instruction);
int64 s_value = extract_s__se31_15_to_0_31_to_16(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
g_autofree char *s = ADDRESS(s_value, 6, info);
return img_format("SWPC %s, %s", rt, s);
@@ -15324,9 +15328,9 @@ static char *SWX(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("SWX %s, %s(%s)", rd, rs, rt);
}
@@ -15348,9 +15352,9 @@ static char *SWXS(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("SWXS %s, %s(%s)", rd, rs, rt);
}
@@ -15390,7 +15394,7 @@ static char *SYNCI(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
- const char *rs = GPR(rs_value);
+ const char *rs = GPR(rs_value, info);
return img_format("SYNCI %" PRId64 "(%s)", s_value, rs);
}
@@ -15411,7 +15415,7 @@ static char *SYNCIE(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
- const char *rs = GPR(rs_value);
+ const char *rs = GPR(rs_value, info);
return img_format("SYNCIE %" PRId64 "(%s)", s_value, rs);
}
@@ -15468,8 +15472,8 @@ static char *TEQ(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("TEQ %s, %s", rs, rt);
}
@@ -15706,8 +15710,8 @@ static char *TNE(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("TNE %s, %s", rs, rt);
}
@@ -15728,8 +15732,8 @@ static char *TRUNC_L_D(uint64 instruction, Dis_info
*info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("TRUNC.L.D %s, %s", ft, fs);
}
@@ -15750,8 +15754,8 @@ static char *TRUNC_L_S(uint64 instruction, Dis_info
*info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("TRUNC.L.S %s, %s", ft, fs);
}
@@ -15772,8 +15776,8 @@ static char *TRUNC_W_D(uint64 instruction, Dis_info
*info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("TRUNC.W.D %s, %s", ft, fs);
}
@@ -15794,8 +15798,8 @@ static char *TRUNC_W_S(uint64 instruction, Dis_info
*info)
uint64 ft_value = extract_ft_25_24_23_22_21(instruction);
uint64 fs_value = extract_fs_20_19_18_17_16(instruction);
- const char *ft = FPR(ft_value);
- const char *fs = FPR(fs_value);
+ const char *ft = FPR(ft_value, info);
+ const char *fs = FPR(fs_value, info);
return img_format("TRUNC.W.S %s, %s", ft, fs);
}
@@ -15818,8 +15822,8 @@ static char *UALDM(uint64 instruction, Dis_info *info)
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
uint64 count3_value = extract_count3_14_13_12(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
uint64 count3 = encode_count3_from_count(count3_value);
return img_format("UALDM %s, %" PRId64 "(%s), 0x%" PRIx64,
@@ -15843,8 +15847,8 @@ static char *UALH(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("UALH %s, %" PRId64 "(%s)", rt, s_value, rs);
}
@@ -15867,8 +15871,8 @@ static char *UALWM(uint64 instruction, Dis_info *info)
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
uint64 count3_value = extract_count3_14_13_12(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
uint64 count3 = encode_count3_from_count(count3_value);
return img_format("UALWM %s, %" PRId64 "(%s), 0x%" PRIx64,
@@ -15893,8 +15897,8 @@ static char *UASDM(uint64 instruction, Dis_info *info)
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
uint64 count3_value = extract_count3_14_13_12(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
uint64 count3 = encode_count3_from_count(count3_value);
return img_format("UASDM %s, %" PRId64 "(%s), 0x%" PRIx64,
@@ -15918,8 +15922,8 @@ static char *UASH(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("UASH %s, %" PRId64 "(%s)", rt, s_value, rs);
}
@@ -15942,8 +15946,8 @@ static char *UASWM(uint64 instruction, Dis_info *info)
int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction);
uint64 count3_value = extract_count3_14_13_12(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
uint64 count3 = encode_count3_from_count(count3_value);
return img_format("UASWM %s, %" PRId64 "(%s), 0x%" PRIx64,
@@ -16002,7 +16006,7 @@ static char *WRDSP(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 mask_value = extract_mask_20_19_18_17_16_15_14(instruction);
- const char *rt = GPR(rt_value);
+ const char *rt = GPR(rt_value, info);
return img_format("WRDSP %s, 0x%" PRIx64, rt, mask_value);
}
@@ -16023,8 +16027,8 @@ static char *WRPGPR(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("WRPGPR %s, %s", rt, rs);
}
@@ -16045,8 +16049,8 @@ static char *XOR_16_(uint64 instruction, Dis_info *info)
uint64 rt3_value = extract_rt3_9_8_7(instruction);
uint64 rs3_value = extract_rs3_6_5_4(instruction);
- const char *rs3 = GPR(decode_gpr_gpr3(rs3_value));
- const char *rt3 = GPR(decode_gpr_gpr3(rt3_value));
+ const char *rs3 = GPR(decode_gpr_gpr3(rs3_value, info), info);
+ const char *rt3 = GPR(decode_gpr_gpr3(rt3_value, info), info);
return img_format("XOR %s, %s", rs3, rt3);
}
@@ -16068,9 +16072,9 @@ static char *XOR_32_(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 rd_value = extract_rd_15_14_13_12_11(instruction);
- const char *rd = GPR(rd_value);
- const char *rs = GPR(rs_value);
- const char *rt = GPR(rt_value);
+ const char *rd = GPR(rd_value, info);
+ const char *rs = GPR(rs_value, info);
+ const char *rt = GPR(rt_value, info);
return img_format("XOR %s, %s, %s", rd, rs, rt);
}
@@ -16092,8 +16096,8 @@ static char *XORI(uint64 instruction, Dis_info *info)
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("XORI %s, %s, 0x%" PRIx64, rt, rs, u_value);
}
@@ -16113,8 +16117,8 @@ static char *YIELD(uint64 instruction, Dis_info *info)
uint64 rt_value = extract_rt_25_24_23_22_21(instruction);
uint64 rs_value = extract_rs_20_19_18_17_16(instruction);
- const char *rt = GPR(rt_value);
- const char *rs = GPR(rs_value);
+ const char *rt = GPR(rt_value, info);
+ const char *rs = GPR(rs_value, info);
return img_format("YIELD %s, %s", rt, rs);
}
@@ -21949,6 +21953,8 @@ int print_insn_nanomips(bfd_vma memaddr, struct
disassemble_info *info)
Dis_info disassm_info;
disassm_info.m_pc = memaddr;
+ disassm_info.fprintf_func = info->fprintf_func;
+ disassm_info.stream = info->stream;
status = (*info->read_memory_func)(memaddr, buffer, 2, info);
if (status != 0) {
--
2.25.1
- Re: [PATCH v3 15/24] disas/nanomips: Replace std::string type, (continued)
- [PATCH v3 16/24] disas/nanomips: Remove IMMEDIATE functions, Milica Lazarevic, 2022/09/12
- [PATCH v3 17/24] disas/nanomips: Remove CPR function, Milica Lazarevic, 2022/09/12
- [PATCH v3 18/24] disas/nanomips: Prevent memory leaking, Milica Lazarevic, 2022/09/12
- [PATCH v3 19/24] disas/nanomips: Remove function overloading, Milica Lazarevic, 2022/09/12
- [PATCH v3 22/24] disas/nanomips: Replace Cpp enums for C enums, Milica Lazarevic, 2022/09/12
- [PATCH v3 20/24] disas/nanomips: Expand Dis_info struct,
Milica Lazarevic <=
- [PATCH v3 21/24] disas/nanomips: Replace exception handling, Milica Lazarevic, 2022/09/12
- [PATCH v3 23/24] disas/nanomips: Remove argument passing by ref, Milica Lazarevic, 2022/09/12
- [PATCH v3 24/24] disas/nanomips: Rename nanomips.cpp to nanomips.c, Milica Lazarevic, 2022/09/12