diff options
Diffstat (limited to 'disas')
-rw-r--r-- | disas/nanomips.cpp | 4776 |
1 files changed, 2337 insertions, 2439 deletions
diff --git a/disas/nanomips.cpp b/disas/nanomips.cpp index 170f5c5c17..e4e122f3cf 100644 --- a/disas/nanomips.cpp +++ b/disas/nanomips.cpp @@ -30,13 +30,11 @@ #include "qemu/osdep.h" #include "disas/dis-asm.h" -#include <cstring> +#include <string.h> #include <stdexcept> #include <stdio.h> #include <stdarg.h> -#include <string> - typedef int64_t int64; typedef uint64_t uint64; typedef uint32_t uint32; @@ -77,7 +75,7 @@ typedef struct Dis_info { } Dis_info; typedef bool (*conditional_function)(uint64 instruction); -typedef std::string (*disassembly_function)(uint64 instruction, +typedef char * (*disassembly_function)(uint64 instruction, Dis_info *info); typedef struct Pool { @@ -95,122 +93,20 @@ typedef struct Pool { #define IMGASSERTONCE(test) -std::string img_format(const char *format, ...) +static char *img_format(const char *format, ...) { - char buffer[256]; + char *buffer; va_list args; va_start(args, format); - int err = vsprintf(buffer, format, args); - if (err < 0) { - perror(buffer); - } + buffer = g_strdup_vprintf(format, args); va_end(args); return buffer; } -std::string img_format(const char *format, - std::string s) -{ - char buffer[256]; - - sprintf(buffer, format, s.c_str()); - - return buffer; -} - -std::string img_format(const char *format, - std::string s1, - std::string s2) -{ - char buffer[256]; - - sprintf(buffer, format, s1.c_str(), s2.c_str()); - - return buffer; -} - -std::string img_format(const char *format, - std::string s1, - std::string s2, - std::string s3) -{ - char buffer[256]; - - sprintf(buffer, format, s1.c_str(), s2.c_str(), s3.c_str()); - - return buffer; -} - -std::string img_format(const char *format, - std::string s1, - std::string s2, - std::string s3, - std::string s4) -{ - char buffer[256]; - - sprintf(buffer, format, s1.c_str(), s2.c_str(), s3.c_str(), - s4.c_str()); - - return buffer; -} - -std::string img_format(const char *format, - std::string s1, - std::string s2, - std::string s3, - std::string s4, - std::string s5) -{ - char buffer[256]; - - sprintf(buffer, format, s1.c_str(), s2.c_str(), s3.c_str(), - s4.c_str(), s5.c_str()); - - return buffer; -} - -std::string img_format(const char *format, - uint64 d, - std::string s2) -{ - char buffer[256]; - - sprintf(buffer, format, d, s2.c_str()); - - return buffer; -} - -std::string img_format(const char *format, - std::string s1, - uint64 d, - std::string s2) -{ - char buffer[256]; - sprintf(buffer, format, s1.c_str(), d, s2.c_str()); - - return buffer; -} - -std::string img_format(const char *format, - std::string s1, - std::string s2, - uint64 d) +static char *to_string(img_address a) { - char buffer[256]; - - sprintf(buffer, format, s1.c_str(), s2.c_str(), d); - - return buffer; -} - - -std::string to_string(img_address a) -{ - char buffer[256]; - sprintf(buffer, "0x%" PRIx64, a); - return buffer; + return g_strdup_printf("0x%" PRIx64, a); } @@ -554,7 +450,7 @@ static uint64 encode_rt1_from_rt(uint64 d) } -static std::string GPR(uint64 reg) +static const char *GPR(uint64 reg) { static const char *gpr_reg[32] = { "zero", "at", "v0", "v1", "a0", "a1", "a2", "a3", @@ -572,21 +468,25 @@ static std::string GPR(uint64 reg) } -static std::string save_restore_list(uint64 rt, uint64 count, uint64 gp) +static char *save_restore_list(uint64 rt, uint64 count, uint64 gp) { - std::string str; + char *reg_list[34]; + reg_list[0] = (char *)""; + assert(count <= 32); for (uint64 counter = 0; counter != count; counter++) { bool use_gp = gp && (counter == count - 1); uint64 this_rt = use_gp ? 28 : ((rt & 0x10) | (rt + counter)) & 0x1f; - str += img_format(",%s", GPR(this_rt)); + /* glib usage below requires casting away const */ + reg_list[counter + 1] = (char *)GPR(this_rt); } + reg_list[count + 1] = NULL; - return str; + return g_strjoinv(",", reg_list); } -static std::string FPR(uint64 reg) +static const char *FPR(uint64 reg) { static const char *fpr_reg[32] = { "f0", "f1", "f2", "f3", "f4", "f5", "f6", "f7", @@ -604,7 +504,7 @@ static std::string FPR(uint64 reg) } -static std::string AC(uint64 reg) +static const char *AC(uint64 reg) { static const char *ac_reg[4] = { "ac0", "ac1", "ac2", "ac3" @@ -619,26 +519,26 @@ static std::string AC(uint64 reg) } -static std::string IMMEDIATE(uint64 value) +static char *IMMEDIATE(uint64 value) { return img_format("0x%" PRIx64, value); } -static std::string IMMEDIATE(int64 value) +static char *IMMEDIATE(int64 value) { return img_format("%" PRId64, value); } -static std::string CPR(uint64 reg) +static char *CPR(uint64 reg) { /* needs more work */ return img_format("CP%" PRIu64, reg); } -static std::string ADDRESS(uint64 value, int instruction_size, Dis_info *info) +static char *ADDRESS(uint64 value, int instruction_size, Dis_info *info) { /* token for string replace */ img_address address = info->m_pc + value + instruction_size; @@ -673,7 +573,7 @@ static uint64 extract_op_code_value(const uint16 *data, int size) * instruction size - negative is error * disassembly string - on error will constain error string */ -static int Disassemble(const uint16 *data, std::string & dis, +static int Disassemble(const uint16 *data, char **dis, TABLE_ENTRY_TYPE & type, const Pool *table, int table_size, Dis_info *info) { @@ -699,20 +599,21 @@ static int Disassemble(const uint16 *data, std::string & dis, (table[i].type == return_instruction)) { disassembly_function dis_fn = table[i].disassembly; if (dis_fn == 0) { - dis = "disassembler failure - bad table entry"; + *dis = g_strdup( + "disassembler failure - bad table entry"); return -6; } type = table[i].type; - dis = dis_fn(op_code, info); + *dis = dis_fn(op_code, info); return table[i].instructions_size; } else { - dis = "reserved instruction"; + *dis = g_strdup("reserved instruction"); return -2; } } catch (std::runtime_error & e) { - dis = e.what(); + *dis = g_strdup(e.what()); return -3; /* runtime error */ } } @@ -721,11 +622,11 @@ static int Disassemble(const uint16 *data, std::string & dis, } catch (std::exception & e) { - dis = e.what(); + *dis = g_strdup(e.what()); return -4; /* runtime error */ } - dis = "failed to disassemble"; + *dis = g_strdup("failed to disassemble"); return -1; /* failed to disassemble */ } @@ -1658,13 +1559,13 @@ static bool SLTU_cond(uint64 instruction) * fs ----- * fd ----- */ -static std::string ABS_D(uint64 instruction, Dis_info *info) +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); - std::string fs = FPR(fs_value); - std::string fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *fd = FPR(fd_value); return img_format("ABS.D %s, %s", fd, fs); } @@ -1680,13 +1581,13 @@ static std::string ABS_D(uint64 instruction, Dis_info *info) * fd ----- * fs ----- */ -static std::string ABS_S(uint64 instruction, Dis_info *info) +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); - std::string fs = FPR(fs_value); - std::string fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *fd = FPR(fd_value); return img_format("ABS.S %s, %s", fd, fs); } @@ -1702,13 +1603,13 @@ static std::string ABS_S(uint64 instruction, Dis_info *info) * rt ----- * rs ----- */ -static std::string ABSQ_S_PH(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("ABSQ_S.PH %s, %s", rt, rs); } @@ -1724,13 +1625,13 @@ static std::string ABSQ_S_PH(uint64 instruction, Dis_info *info) * rt ----- * rs ----- */ -static std::string ABSQ_S_QB(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("ABSQ_S.QB %s, %s", rt, rs); } @@ -1746,13 +1647,13 @@ static std::string ABSQ_S_QB(uint64 instruction, Dis_info *info) * rt ----- * rs ----- */ -static std::string ABSQ_S_W(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("ABSQ_S.W %s, %s", rt, rs); } @@ -1767,15 +1668,15 @@ static std::string ABSQ_S_W(uint64 instruction, Dis_info *info) * rt ----- * rs ----- */ -static std::string ACLR(uint64 instruction, Dis_info *info) +static char *ACLR(uint64 instruction, Dis_info *info) { uint64 bit_value = extract_bit_23_22_21(instruction); 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); - std::string bit = IMMEDIATE(bit_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + char *bit = IMMEDIATE(bit_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("ACLR %s, %s(%s)", bit, s, rs); } @@ -1790,15 +1691,15 @@ static std::string ACLR(uint64 instruction, Dis_info *info) * rt ----- * rs ----- */ -static std::string ADD(uint64 instruction, Dis_info *info) +static char *ADD(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("ADD %s, %s, %s", rd, rs, rt); } @@ -1815,15 +1716,15 @@ static std::string ADD(uint64 instruction, Dis_info *info) * fs ----- * fd ----- */ -static std::string ADD_D(uint64 instruction, Dis_info *info) +static char *ADD_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); - std::string fd = FPR(fd_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); + const char *fd = FPR(fd_value); return img_format("ADD.D %s, %s, %s", fd, fs, ft); } @@ -1840,15 +1741,15 @@ static std::string ADD_D(uint64 instruction, Dis_info *info) * fs ----- * fd ----- */ -static std::string ADD_S(uint64 instruction, Dis_info *info) +static char *ADD_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); - std::string fd = FPR(fd_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); + const char *fd = FPR(fd_value); return img_format("ADD.S %s, %s, %s", fd, fs, ft); } @@ -1863,15 +1764,15 @@ static std::string ADD_S(uint64 instruction, Dis_info *info) * rt ----- * rs ----- */ -static std::string ADDIU_32_(uint64 instruction, Dis_info *info) +static char *ADDIU_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); uint64 u_value = extract_u_15_to_0(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string u = IMMEDIATE(u_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *u = IMMEDIATE(u_value); return img_format("ADDIU %s, %s, %s", rt, rs, u); } @@ -1886,13 +1787,13 @@ static std::string ADDIU_32_(uint64 instruction, Dis_info *info) * rt ----- * rs ----- */ -static std::string ADDIU_48_(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); return img_format("ADDIU %s, %s", rt, s); } @@ -1907,13 +1808,13 @@ static std::string ADDIU_48_(uint64 instruction, Dis_info *info) * rt ----- * rs ----- */ -static std::string ADDIU_GP48_(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); return img_format("ADDIU %s, $%d, %s", rt, 28, s); } @@ -1928,13 +1829,13 @@ static std::string ADDIU_GP48_(uint64 instruction, Dis_info *info) * rt ----- * rs ----- */ -static std::string ADDIU_GP_B_(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string u = IMMEDIATE(u_value); + const char *rt = GPR(rt_value); + char *u = IMMEDIATE(u_value); return img_format("ADDIU %s, $%d, %s", rt, 28, u); } @@ -1949,13 +1850,13 @@ static std::string ADDIU_GP_B_(uint64 instruction, Dis_info *info) * rt ----- * rs ----- */ -static std::string ADDIU_GP_W_(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string u = IMMEDIATE(u_value); + const char *rt = GPR(rt_value); + char *u = IMMEDIATE(u_value); return img_format("ADDIU %s, $%d, %s", rt, 28, u); } @@ -1970,15 +1871,15 @@ static std::string ADDIU_GP_W_(uint64 instruction, Dis_info *info) * rt ----- * rs ----- */ -static std::string ADDIU_NEG_(uint64 instruction, Dis_info *info) +static char *ADDIU_NEG_(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); uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string u = IMMEDIATE(neg_copy(u_value)); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *u = IMMEDIATE(neg_copy(u_value)); return img_format("ADDIU %s, %s, %s", rt, rs, u); } @@ -1993,13 +1894,13 @@ static std::string ADDIU_NEG_(uint64 instruction, Dis_info *info) * rt ----- * rs ----- */ -static std::string ADDIU_R1_SP_(uint64 instruction, Dis_info *info) +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); - std::string rt3 = GPR(decode_gpr_gpr3(rt3_value)); - std::string u = IMMEDIATE(u_value); + const char *rt3 = GPR(decode_gpr_gpr3(rt3_value)); + char *u = IMMEDIATE(u_value); return img_format("ADDIU %s, $%d, %s", rt3, 29, u); } @@ -2014,15 +1915,15 @@ static std::string ADDIU_R1_SP_(uint64 instruction, Dis_info *info) * rt ----- * rs ----- */ -static std::string ADDIU_R2_(uint64 instruction, Dis_info *info) +static char *ADDIU_R2_(uint64 instruction, Dis_info *info) { uint64 rt3_value = extract_rt3_9_8_7(instruction); uint64 rs3_value = extract_rs3_6_5_4(instruction); uint64 u_value = extract_u_2_1_0__s2(instruction); - std::string rt3 = GPR(decode_gpr_gpr3(rt3_value)); - std::string rs3 = GPR(decode_gpr_gpr3(rs3_value)); - std::string u = IMMEDIATE(u_value); + const char *rt3 = GPR(decode_gpr_gpr3(rt3_value)); + const char *rs3 = GPR(decode_gpr_gpr3(rs3_value)); + char *u = IMMEDIATE(u_value); return img_format("ADDIU %s, %s, %s", rt3, rs3, u); } @@ -2036,13 +1937,13 @@ static std::string ADDIU_R2_(uint64 instruction, Dis_info *info) * rt ----- * s - --- */ -static std::string ADDIU_RS5_(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); return img_format("ADDIU %s, %s", rt, s); } @@ -2058,13 +1959,13 @@ static std::string ADDIU_RS5_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string ADDIUPC_32_(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string s = ADDRESS(s_value, 4, info); + const char *rt = GPR(rt_value); + char *s = ADDRESS(s_value, 4, info); return img_format("ADDIUPC %s, %s", rt, s); } @@ -2080,13 +1981,13 @@ static std::string ADDIUPC_32_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string ADDIUPC_48_(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string s = ADDRESS(s_value, 6, info); + const char *rt = GPR(rt_value); + char *s = ADDRESS(s_value, 6, info); return img_format("ADDIUPC %s, %s", rt, s); } @@ -2102,15 +2003,15 @@ static std::string ADDIUPC_48_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string ADDQ_PH(uint64 instruction, Dis_info *info) +static char *ADDQ_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("ADDQ.PH %s, %s, %s", rd, rs, rt); } @@ -2127,15 +2028,15 @@ static std::string ADDQ_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string ADDQ_S_PH(uint64 instruction, Dis_info *info) +static char *ADDQ_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("ADDQ_S.PH %s, %s, %s", rd, rs, rt); } @@ -2151,15 +2052,15 @@ static std::string ADDQ_S_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string ADDQ_S_W(uint64 instruction, Dis_info *info) +static char *ADDQ_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("ADDQ_S.W %s, %s, %s", rd, rs, rt); } @@ -2176,15 +2077,15 @@ static std::string ADDQ_S_W(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string ADDQH_PH(uint64 instruction, Dis_info *info) +static char *ADDQH_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("ADDQH.PH %s, %s, %s", rd, rs, rt); } @@ -2201,15 +2102,15 @@ static std::string ADDQH_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string ADDQH_R_PH(uint64 instruction, Dis_info *info) +static char *ADDQH_R_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("ADDQH_R.PH %s, %s, %s", rd, rs, rt); } @@ -2226,15 +2127,15 @@ static std::string ADDQH_R_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string ADDQH_R_W(uint64 instruction, Dis_info *info) +static char *ADDQH_R_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("ADDQH_R.W %s, %s, %s", rd, rs, rt); } @@ -2251,15 +2152,15 @@ static std::string ADDQH_R_W(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string ADDQH_W(uint64 instruction, Dis_info *info) +static char *ADDQH_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("ADDQH.W %s, %s, %s", rd, rs, rt); } @@ -2275,15 +2176,15 @@ static std::string ADDQH_W(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string ADDSC(uint64 instruction, Dis_info *info) +static char *ADDSC(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("ADDSC %s, %s, %s", rd, rs, rt); } @@ -2298,15 +2199,15 @@ static std::string ADDSC(uint64 instruction, Dis_info *info) * rs3 --- * rd3 --- */ -static std::string ADDU_16_(uint64 instruction, Dis_info *info) +static char *ADDU_16_(uint64 instruction, Dis_info *info) { uint64 rt3_value = extract_rt3_9_8_7(instruction); uint64 rs3_value = extract_rs3_6_5_4(instruction); uint64 rd3_value = extract_rd3_3_2_1(instruction); - std::string rt3 = GPR(decode_gpr_gpr3(rt3_value)); - std::string rs3 = GPR(decode_gpr_gpr3(rs3_value)); - std::string rd3 = GPR(decode_gpr_gpr3(rd3_value)); + 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)); return img_format("ADDU %s, %s, %s", rd3, rs3, rt3); } @@ -2322,15 +2223,15 @@ static std::string ADDU_16_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string ADDU_32_(uint64 instruction, Dis_info *info) +static char *ADDU_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("ADDU %s, %s, %s", rd, rs, rt); } @@ -2346,13 +2247,13 @@ static std::string ADDU_32_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string ADDU_4X4_(uint64 instruction, Dis_info *info) +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); - std::string rs4 = GPR(decode_gpr_gpr4(rs4_value)); - std::string 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)); return img_format("ADDU %s, %s", rs4, rt4); } @@ -2368,15 +2269,15 @@ static std::string ADDU_4X4_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string ADDU_PH(uint64 instruction, Dis_info *info) +static char *ADDU_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("ADDU.PH %s, %s, %s", rd, rs, rt); } @@ -2392,15 +2293,15 @@ static std::string ADDU_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string ADDU_QB(uint64 instruction, Dis_info *info) +static char *ADDU_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("ADDU.QB %s, %s, %s", rd, rs, rt); } @@ -2417,15 +2318,15 @@ static std::string ADDU_QB(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string ADDU_S_PH(uint64 instruction, Dis_info *info) +static char *ADDU_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("ADDU_S.PH %s, %s, %s", rd, rs, rt); } @@ -2441,15 +2342,15 @@ static std::string ADDU_S_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string ADDU_S_QB(uint64 instruction, Dis_info *info) +static char *ADDU_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("ADDU_S.QB %s, %s, %s", rd, rs, rt); } @@ -2466,15 +2367,15 @@ static std::string ADDU_S_QB(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string ADDUH_QB(uint64 instruction, Dis_info *info) +static char *ADDUH_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("ADDUH.QB %s, %s, %s", rd, rs, rt); } @@ -2491,15 +2392,15 @@ static std::string ADDUH_QB(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string ADDUH_R_QB(uint64 instruction, Dis_info *info) +static char *ADDUH_R_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("ADDUH_R.QB %s, %s, %s", rd, rs, rt); } @@ -2514,15 +2415,15 @@ static std::string ADDUH_R_QB(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string ADDWC(uint64 instruction, Dis_info *info) +static char *ADDWC(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("ADDWC %s, %s, %s", rd, rs, rt); } @@ -2538,13 +2439,13 @@ static std::string ADDWC(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string ALUIPC(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string s = ADDRESS(s_value, 4, info); + const char *rt = GPR(rt_value); + char *s = ADDRESS(s_value, 4, info); return img_format("ALUIPC %s, %%pcrel_hi(%s)", rt, s); } @@ -2559,13 +2460,13 @@ static std::string ALUIPC(uint64 instruction, Dis_info *info) * rs3 --- * eu ---- */ -static std::string AND_16_(uint64 instruction, Dis_info *info) +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); - std::string rt3 = GPR(decode_gpr_gpr3(rt3_value)); - std::string 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)); return img_format("AND %s, %s", rs3, rt3); } @@ -2581,15 +2482,15 @@ static std::string AND_16_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string AND_32_(uint64 instruction, Dis_info *info) +static char *AND_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("AND %s, %s, %s", rd, rs, rt); } @@ -2604,15 +2505,15 @@ static std::string AND_32_(uint64 instruction, Dis_info *info) * rs3 --- * eu ---- */ -static std::string ANDI_16_(uint64 instruction, Dis_info *info) +static char *ANDI_16_(uint64 instruction, Dis_info *info) { uint64 rt3_value = extract_rt3_9_8_7(instruction); uint64 rs3_value = extract_rs3_6_5_4(instruction); uint64 eu_value = extract_eu_3_2_1_0(instruction); - std::string rt3 = GPR(decode_gpr_gpr3(rt3_value)); - std::string rs3 = GPR(decode_gpr_gpr3(rs3_value)); - std::string eu = IMMEDIATE(encode_eu_from_u_andi16(eu_value)); + const char *rt3 = GPR(decode_gpr_gpr3(rt3_value)); + const char *rs3 = GPR(decode_gpr_gpr3(rs3_value)); + char *eu = IMMEDIATE(encode_eu_from_u_andi16(eu_value)); return img_format("ANDI %s, %s, %s", rt3, rs3, eu); } @@ -2628,15 +2529,15 @@ static std::string ANDI_16_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string ANDI_32_(uint64 instruction, Dis_info *info) +static char *ANDI_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); uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string u = IMMEDIATE(u_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *u = IMMEDIATE(u_value); return img_format("ANDI %s, %s, %s", rt, rs, u); } @@ -2652,15 +2553,15 @@ static std::string ANDI_32_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string APPEND(uint64 instruction, Dis_info *info) +static char *APPEND(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); uint64 sa_value = extract_sa_15_14_13_12_11(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string sa = IMMEDIATE(sa_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *sa = IMMEDIATE(sa_value); return img_format("APPEND %s, %s, %s", rt, rs, sa); } @@ -2676,15 +2577,15 @@ static std::string APPEND(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string ASET(uint64 instruction, Dis_info *info) +static char *ASET(uint64 instruction, Dis_info *info) { uint64 bit_value = extract_bit_23_22_21(instruction); 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); - std::string bit = IMMEDIATE(bit_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + char *bit = IMMEDIATE(bit_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("ASET %s, %s(%s)", bit, s, rs); } @@ -2700,11 +2601,11 @@ static std::string ASET(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string BALC_16_(uint64 instruction, Dis_info *info) +static char *BALC_16_(uint64 instruction, Dis_info *info) { int64 s_value = extract_s__se10_0_9_8_7_6_5_4_3_2_1_s1(instruction); - std::string s = ADDRESS(s_value, 2, info); + char *s = ADDRESS(s_value, 2, info); return img_format("BALC %s", s); } @@ -2720,11 +2621,11 @@ static std::string BALC_16_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string BALC_32_(uint64 instruction, Dis_info *info) +static char *BALC_32_(uint64 instruction, Dis_info *info) { int64 s_value = extract_s__se25_0_24_to_1_s1(instruction); - std::string s = ADDRESS(s_value, 4, info); + char *s = ADDRESS(s_value, 4, info); return img_format("BALC %s", s); } @@ -2740,13 +2641,13 @@ static std::string BALC_32_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string BALRSC(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("BALRSC %s, %s", rt, rs); } @@ -2762,15 +2663,15 @@ static std::string BALRSC(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string BBEQZC(uint64 instruction, Dis_info *info) +static char *BBEQZC(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); 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); - std::string rt = GPR(rt_value); - std::string bit = IMMEDIATE(bit_value); - std::string s = ADDRESS(s_value, 4, info); + const char *rt = GPR(rt_value); + char *bit = IMMEDIATE(bit_value); + char *s = ADDRESS(s_value, 4, info); return img_format("BBEQZC %s, %s, %s", rt, bit, s); } @@ -2786,15 +2687,15 @@ static std::string BBEQZC(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string BBNEZC(uint64 instruction, Dis_info *info) +static char *BBNEZC(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); 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); - std::string rt = GPR(rt_value); - std::string bit = IMMEDIATE(bit_value); - std::string s = ADDRESS(s_value, 4, info); + const char *rt = GPR(rt_value); + char *bit = IMMEDIATE(bit_value); + char *s = ADDRESS(s_value, 4, info); return img_format("BBNEZC %s, %s, %s", rt, bit, s); } @@ -2810,11 +2711,11 @@ static std::string BBNEZC(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string BC_16_(uint64 instruction, Dis_info *info) +static char *BC_16_(uint64 instruction, Dis_info *info) { int64 s_value = extract_s__se10_0_9_8_7_6_5_4_3_2_1_s1(instruction); - std::string s = ADDRESS(s_value, 2, info); + char *s = ADDRESS(s_value, 2, info); return img_format("BC %s", s); } @@ -2830,11 +2731,11 @@ static std::string BC_16_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string BC_32_(uint64 instruction, Dis_info *info) +static char *BC_32_(uint64 instruction, Dis_info *info) { int64 s_value = extract_s__se25_0_24_to_1_s1(instruction); - std::string s = ADDRESS(s_value, 4, info); + char *s = ADDRESS(s_value, 4, info); return img_format("BC %s", s); } @@ -2850,13 +2751,13 @@ static std::string BC_32_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string BC1EQZC(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string s = ADDRESS(s_value, 4, info); + const char *ft = FPR(ft_value); + char *s = ADDRESS(s_value, 4, info); return img_format("BC1EQZC %s, %s", ft, s); } @@ -2872,13 +2773,13 @@ static std::string BC1EQZC(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string BC1NEZC(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string s = ADDRESS(s_value, 4, info); + const char *ft = FPR(ft_value); + char *s = ADDRESS(s_value, 4, info); return img_format("BC1NEZC %s, %s", ft, s); } @@ -2894,13 +2795,13 @@ static std::string BC1NEZC(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string BC2EQZC(uint64 instruction, Dis_info *info) +static char *BC2EQZC(uint64 instruction, Dis_info *info) { uint64 ct_value = extract_ct_25_24_23_22_21(instruction); int64 s_value = extract_s__se14_0_13_to_1_s1(instruction); - std::string ct = CPR(ct_value); - std::string s = ADDRESS(s_value, 4, info); + char *ct = CPR(ct_value); + char *s = ADDRESS(s_value, 4, info); return img_format("BC2EQZC %s, %s", ct, s); } @@ -2916,13 +2817,13 @@ static std::string BC2EQZC(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string BC2NEZC(uint64 instruction, Dis_info *info) +static char *BC2NEZC(uint64 instruction, Dis_info *info) { uint64 ct_value = extract_ct_25_24_23_22_21(instruction); int64 s_value = extract_s__se14_0_13_to_1_s1(instruction); - std::string ct = CPR(ct_value); - std::string s = ADDRESS(s_value, 4, info); + char *ct = CPR(ct_value); + char *s = ADDRESS(s_value, 4, info); return img_format("BC2NEZC %s, %s", ct, s); } @@ -2938,15 +2839,15 @@ static std::string BC2NEZC(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string BEQC_16_(uint64 instruction, Dis_info *info) +static char *BEQC_16_(uint64 instruction, Dis_info *info) { uint64 rt3_value = extract_rt3_9_8_7(instruction); uint64 rs3_value = extract_rs3_6_5_4(instruction); uint64 u_value = extract_u_3_2_1_0__s1(instruction); - std::string rs3 = GPR(decode_gpr_gpr3(rs3_value)); - std::string rt3 = GPR(decode_gpr_gpr3(rt3_value)); - std::string u = ADDRESS(u_value, 2, info); + const char *rs3 = GPR(decode_gpr_gpr3(rs3_value)); + const char *rt3 = GPR(decode_gpr_gpr3(rt3_value)); + char *u = ADDRESS(u_value, 2, info); return img_format("BEQC %s, %s, %s", rs3, rt3, u); } @@ -2962,15 +2863,15 @@ static std::string BEQC_16_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string BEQC_32_(uint64 instruction, Dis_info *info) +static char *BEQC_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); int64 s_value = extract_s__se14_0_13_to_1_s1(instruction); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); - std::string s = ADDRESS(s_value, 4, info); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *s = ADDRESS(s_value, 4, info); return img_format("BEQC %s, %s, %s", rs, rt, s); } @@ -2986,15 +2887,15 @@ static std::string BEQC_32_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string BEQIC(uint64 instruction, Dis_info *info) +static char *BEQIC(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); 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); - std::string rt = GPR(rt_value); - std::string u = IMMEDIATE(u_value); - std::string s = ADDRESS(s_value, 4, info); + const char *rt = GPR(rt_value); + char *u = IMMEDIATE(u_value); + char *s = ADDRESS(s_value, 4, info); return img_format("BEQIC %s, %s, %s", rt, u, s); } @@ -3010,13 +2911,13 @@ static std::string BEQIC(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string BEQZC_16_(uint64 instruction, Dis_info *info) +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); - std::string rt3 = GPR(decode_gpr_gpr3(rt3_value)); - std::string s = ADDRESS(s_value, 2, info); + const char *rt3 = GPR(decode_gpr_gpr3(rt3_value)); + char *s = ADDRESS(s_value, 2, info); return img_format("BEQZC %s, %s", rt3, s); } @@ -3032,15 +2933,15 @@ static std::string BEQZC_16_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string BGEC(uint64 instruction, Dis_info *info) +static char *BGEC(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); int64 s_value = extract_s__se14_0_13_to_1_s1(instruction); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); - std::string s = ADDRESS(s_value, 4, info); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *s = ADDRESS(s_value, 4, info); return img_format("BGEC %s, %s, %s", rs, rt, s); } @@ -3056,15 +2957,15 @@ static std::string BGEC(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string BGEIC(uint64 instruction, Dis_info *info) +static char *BGEIC(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); 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); - std::string rt = GPR(rt_value); - std::string u = IMMEDIATE(u_value); - std::string s = ADDRESS(s_value, 4, info); + const char *rt = GPR(rt_value); + char *u = IMMEDIATE(u_value); + char *s = ADDRESS(s_value, 4, info); return img_format("BGEIC %s, %s, %s", rt, u, s); } @@ -3080,15 +2981,15 @@ static std::string BGEIC(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string BGEIUC(uint64 instruction, Dis_info *info) +static char *BGEIUC(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); 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); - std::string rt = GPR(rt_value); - std::string u = IMMEDIATE(u_value); - std::string s = ADDRESS(s_value, 4, info); + const char *rt = GPR(rt_value); + char *u = IMMEDIATE(u_value); + char *s = ADDRESS(s_value, 4, info); return img_format("BGEIUC %s, %s, %s", rt, u, s); } @@ -3104,15 +3005,15 @@ static std::string BGEIUC(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string BGEUC(uint64 instruction, Dis_info *info) +static char *BGEUC(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); int64 s_value = extract_s__se14_0_13_to_1_s1(instruction); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); - std::string s = ADDRESS(s_value, 4, info); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *s = ADDRESS(s_value, 4, info); return img_format("BGEUC %s, %s, %s", rs, rt, s); } @@ -3128,15 +3029,15 @@ static std::string BGEUC(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string BLTC(uint64 instruction, Dis_info *info) +static char *BLTC(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); int64 s_value = extract_s__se14_0_13_to_1_s1(instruction); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); - std::string s = ADDRESS(s_value, 4, info); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *s = ADDRESS(s_value, 4, info); return img_format("BLTC %s, %s, %s", rs, rt, s); } @@ -3152,15 +3053,15 @@ static std::string BLTC(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string BLTIC(uint64 instruction, Dis_info *info) +static char *BLTIC(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); 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); - std::string rt = GPR(rt_value); - std::string u = IMMEDIATE(u_value); - std::string s = ADDRESS(s_value, 4, info); + const char *rt = GPR(rt_value); + char *u = IMMEDIATE(u_value); + char *s = ADDRESS(s_value, 4, info); return img_format("BLTIC %s, %s, %s", rt, u, s); } @@ -3176,15 +3077,15 @@ static std::string BLTIC(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string BLTIUC(uint64 instruction, Dis_info *info) +static char *BLTIUC(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); 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); - std::string rt = GPR(rt_value); - std::string u = IMMEDIATE(u_value); - std::string s = ADDRESS(s_value, 4, info); + const char *rt = GPR(rt_value); + char *u = IMMEDIATE(u_value); + char *s = ADDRESS(s_value, 4, info); return img_format("BLTIUC %s, %s, %s", rt, u, s); } @@ -3200,15 +3101,15 @@ static std::string BLTIUC(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string BLTUC(uint64 instruction, Dis_info *info) +static char *BLTUC(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); int64 s_value = extract_s__se14_0_13_to_1_s1(instruction); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); - std::string s = ADDRESS(s_value, 4, info); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *s = ADDRESS(s_value, 4, info); return img_format("BLTUC %s, %s, %s", rs, rt, s); } @@ -3224,15 +3125,15 @@ static std::string BLTUC(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string BNEC_16_(uint64 instruction, Dis_info *info) +static char *BNEC_16_(uint64 instruction, Dis_info *info) { uint64 rt3_value = extract_rt3_9_8_7(instruction); uint64 rs3_value = extract_rs3_6_5_4(instruction); uint64 u_value = extract_u_3_2_1_0__s1(instruction); - std::string rs3 = GPR(decode_gpr_gpr3(rs3_value)); - std::string rt3 = GPR(decode_gpr_gpr3(rt3_value)); - std::string u = ADDRESS(u_value, 2, info); + const char *rs3 = GPR(decode_gpr_gpr3(rs3_value)); + const char *rt3 = GPR(decode_gpr_gpr3(rt3_value)); + char *u = ADDRESS(u_value, 2, info); return img_format("BNEC %s, %s, %s", rs3, rt3, u); } @@ -3248,15 +3149,15 @@ static std::string BNEC_16_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string BNEC_32_(uint64 instruction, Dis_info *info) +static char *BNEC_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); int64 s_value = extract_s__se14_0_13_to_1_s1(instruction); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); - std::string s = ADDRESS(s_value, 4, info); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *s = ADDRESS(s_value, 4, info); return img_format("BNEC %s, %s, %s", rs, rt, s); } @@ -3272,15 +3173,15 @@ static std::string BNEC_32_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string BNEIC(uint64 instruction, Dis_info *info) +static char *BNEIC(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); 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); - std::string rt = GPR(rt_value); - std::string u = IMMEDIATE(u_value); - std::string s = ADDRESS(s_value, 4, info); + const char *rt = GPR(rt_value); + char *u = IMMEDIATE(u_value); + char *s = ADDRESS(s_value, 4, info); return img_format("BNEIC %s, %s, %s", rt, u, s); } @@ -3296,13 +3197,13 @@ static std::string BNEIC(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string BNEZC_16_(uint64 instruction, Dis_info *info) +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); - std::string rt3 = GPR(decode_gpr_gpr3(rt3_value)); - std::string s = ADDRESS(s_value, 2, info); + const char *rt3 = GPR(decode_gpr_gpr3(rt3_value)); + char *s = ADDRESS(s_value, 2, info); return img_format("BNEZC %s, %s", rt3, s); } @@ -3318,11 +3219,11 @@ static std::string BNEZC_16_(uint64 instruction, Dis_info *info) * s[13:1] ------------- * s[14] - */ -static std::string BPOSGE32C(uint64 instruction, Dis_info *info) +static char *BPOSGE32C(uint64 instruction, Dis_info *info) { int64 s_value = extract_s__se14_0_13_to_1_s1(instruction); - std::string s = ADDRESS(s_value, 4, info); + char *s = ADDRESS(s_value, 4, info); return img_format("BPOSGE32C %s", s); } @@ -3338,11 +3239,11 @@ static std::string BPOSGE32C(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string BREAK_16_(uint64 instruction, Dis_info *info) +static char *BREAK_16_(uint64 instruction, Dis_info *info) { uint64 code_value = extract_code_2_1_0(instruction); - std::string code = IMMEDIATE(code_value); + char *code = IMMEDIATE(code_value); return img_format("BREAK %s", code); } @@ -3358,11 +3259,11 @@ static std::string BREAK_16_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string BREAK_32_(uint64 instruction, Dis_info *info) +static char *BREAK_32_(uint64 instruction, Dis_info *info) { uint64 code_value = extract_code_18_to_0(instruction); - std::string code = IMMEDIATE(code_value); + char *code = IMMEDIATE(code_value); return img_format("BREAK %s", code); } @@ -3378,11 +3279,11 @@ static std::string BREAK_32_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string BRSC(uint64 instruction, Dis_info *info) +static char *BRSC(uint64 instruction, Dis_info *info) { uint64 rs_value = extract_rs_20_19_18_17_16(instruction); - std::string rs = GPR(rs_value); + const char *rs = GPR(rs_value); return img_format("BRSC %s", rs); } @@ -3398,15 +3299,15 @@ static std::string BRSC(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CACHE(uint64 instruction, Dis_info *info) +static char *CACHE(uint64 instruction, Dis_info *info) { uint64 op_value = extract_op_25_24_23_22_21(instruction); 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); - std::string op = IMMEDIATE(op_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + char *op = IMMEDIATE(op_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("CACHE %s, %s(%s)", op, s, rs); } @@ -3422,15 +3323,15 @@ static std::string CACHE(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CACHEE(uint64 instruction, Dis_info *info) +static char *CACHEE(uint64 instruction, Dis_info *info) { uint64 op_value = extract_op_25_24_23_22_21(instruction); 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); - std::string op = IMMEDIATE(op_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + char *op = IMMEDIATE(op_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("CACHEE %s, %s(%s)", op, s, rs); } @@ -3446,13 +3347,13 @@ static std::string CACHEE(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CEIL_L_D(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("CEIL.L.D %s, %s", ft, fs); } @@ -3468,13 +3369,13 @@ static std::string CEIL_L_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CEIL_L_S(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("CEIL.L.S %s, %s", ft, fs); } @@ -3490,13 +3391,13 @@ static std::string CEIL_L_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CEIL_W_D(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("CEIL.W.D %s, %s", ft, fs); } @@ -3512,13 +3413,13 @@ static std::string CEIL_W_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CEIL_W_S(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("CEIL.W.S %s, %s", ft, fs); } @@ -3534,13 +3435,13 @@ static std::string CEIL_W_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CFC1(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string cs = CPR(cs_value); + const char *rt = GPR(rt_value); + char *cs = CPR(cs_value); return img_format("CFC1 %s, %s", rt, cs); } @@ -3556,13 +3457,13 @@ static std::string CFC1(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CFC2(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string cs = CPR(cs_value); + const char *rt = GPR(rt_value); + char *cs = CPR(cs_value); return img_format("CFC2 %s, %s", rt, cs); } @@ -3578,13 +3479,13 @@ static std::string CFC2(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CLASS_D(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("CLASS.D %s, %s", ft, fs); } @@ -3600,13 +3501,13 @@ static std::string CLASS_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CLASS_S(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("CLASS.S %s, %s", ft, fs); } @@ -3622,13 +3523,13 @@ static std::string CLASS_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CLO(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("CLO %s, %s", rt, rs); } @@ -3644,13 +3545,13 @@ static std::string CLO(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CLZ(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("CLZ %s, %s", rt, rs); } @@ -3666,15 +3567,15 @@ static std::string CLZ(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_AF_D(uint64 instruction, Dis_info *info) +static char *CMP_AF_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.AF.D %s, %s, %s", fd, fs, ft); } @@ -3690,15 +3591,15 @@ static std::string CMP_AF_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_AF_S(uint64 instruction, Dis_info *info) +static char *CMP_AF_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.AF.S %s, %s, %s", fd, fs, ft); } @@ -3714,15 +3615,15 @@ static std::string CMP_AF_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_EQ_D(uint64 instruction, Dis_info *info) +static char *CMP_EQ_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.EQ.D %s, %s, %s", fd, fs, ft); } @@ -3737,13 +3638,13 @@ static std::string CMP_EQ_D(uint64 instruction, Dis_info *info) * rt ----- * rs ----- */ -static std::string CMP_EQ_PH(uint64 instruction, Dis_info *info) +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); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("CMP.EQ.PH %s, %s", rs, rt); } @@ -3759,15 +3660,15 @@ static std::string CMP_EQ_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_EQ_S(uint64 instruction, Dis_info *info) +static char *CMP_EQ_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.EQ.S %s, %s, %s", fd, fs, ft); } @@ -3783,15 +3684,15 @@ static std::string CMP_EQ_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_LE_D(uint64 instruction, Dis_info *info) +static char *CMP_LE_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.LE.D %s, %s, %s", fd, fs, ft); } @@ -3806,13 +3707,13 @@ static std::string CMP_LE_D(uint64 instruction, Dis_info *info) * rt ----- * rs ----- */ -static std::string CMP_LE_PH(uint64 instruction, Dis_info *info) +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); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("CMP.LE.PH %s, %s", rs, rt); } @@ -3828,15 +3729,15 @@ static std::string CMP_LE_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_LE_S(uint64 instruction, Dis_info *info) +static char *CMP_LE_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.LE.S %s, %s, %s", fd, fs, ft); } @@ -3852,15 +3753,15 @@ static std::string CMP_LE_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_LT_D(uint64 instruction, Dis_info *info) +static char *CMP_LT_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.LT.D %s, %s, %s", fd, fs, ft); } @@ -3875,13 +3776,13 @@ static std::string CMP_LT_D(uint64 instruction, Dis_info *info) * rt ----- * rs ----- */ -static std::string CMP_LT_PH(uint64 instruction, Dis_info *info) +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); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("CMP.LT.PH %s, %s", rs, rt); } @@ -3897,15 +3798,15 @@ static std::string CMP_LT_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_LT_S(uint64 instruction, Dis_info *info) +static char *CMP_LT_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.LT.S %s, %s, %s", fd, fs, ft); } @@ -3921,15 +3822,15 @@ static std::string CMP_LT_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_NE_D(uint64 instruction, Dis_info *info) +static char *CMP_NE_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.NE.D %s, %s, %s", fd, fs, ft); } @@ -3945,15 +3846,15 @@ static std::string CMP_NE_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_NE_S(uint64 instruction, Dis_info *info) +static char *CMP_NE_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.NE.S %s, %s, %s", fd, fs, ft); } @@ -3969,15 +3870,15 @@ static std::string CMP_NE_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_OR_D(uint64 instruction, Dis_info *info) +static char *CMP_OR_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.OR.D %s, %s, %s", fd, fs, ft); } @@ -3993,15 +3894,15 @@ static std::string CMP_OR_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_OR_S(uint64 instruction, Dis_info *info) +static char *CMP_OR_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.OR.S %s, %s, %s", fd, fs, ft); } @@ -4017,15 +3918,15 @@ static std::string CMP_OR_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_SAF_D(uint64 instruction, Dis_info *info) +static char *CMP_SAF_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.SAF.D %s, %s, %s", fd, fs, ft); } @@ -4041,15 +3942,15 @@ static std::string CMP_SAF_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_SAF_S(uint64 instruction, Dis_info *info) +static char *CMP_SAF_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.SAF.S %s, %s, %s", fd, fs, ft); } @@ -4065,15 +3966,15 @@ static std::string CMP_SAF_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_SEQ_D(uint64 instruction, Dis_info *info) +static char *CMP_SEQ_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.SEQ.D %s, %s, %s", fd, fs, ft); } @@ -4089,15 +3990,15 @@ static std::string CMP_SEQ_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_SEQ_S(uint64 instruction, Dis_info *info) +static char *CMP_SEQ_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.SEQ.S %s, %s, %s", fd, fs, ft); } @@ -4113,15 +4014,15 @@ static std::string CMP_SEQ_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_SLE_D(uint64 instruction, Dis_info *info) +static char *CMP_SLE_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.SLE.D %s, %s, %s", fd, fs, ft); } @@ -4137,15 +4038,15 @@ static std::string CMP_SLE_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_SLE_S(uint64 instruction, Dis_info *info) +static char *CMP_SLE_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.SLE.S %s, %s, %s", fd, fs, ft); } @@ -4161,15 +4062,15 @@ static std::string CMP_SLE_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_SLT_D(uint64 instruction, Dis_info *info) +static char *CMP_SLT_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.SLT.D %s, %s, %s", fd, fs, ft); } @@ -4185,15 +4086,15 @@ static std::string CMP_SLT_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_SLT_S(uint64 instruction, Dis_info *info) +static char *CMP_SLT_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.SLT.S %s, %s, %s", fd, fs, ft); } @@ -4209,15 +4110,15 @@ static std::string CMP_SLT_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_SNE_D(uint64 instruction, Dis_info *info) +static char *CMP_SNE_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.SNE.D %s, %s, %s", fd, fs, ft); } @@ -4233,15 +4134,15 @@ static std::string CMP_SNE_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_SNE_S(uint64 instruction, Dis_info *info) +static char *CMP_SNE_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.SNE.S %s, %s, %s", fd, fs, ft); } @@ -4257,15 +4158,15 @@ static std::string CMP_SNE_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_SOR_D(uint64 instruction, Dis_info *info) +static char *CMP_SOR_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.SOR.D %s, %s, %s", fd, fs, ft); } @@ -4281,15 +4182,15 @@ static std::string CMP_SOR_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_SOR_S(uint64 instruction, Dis_info *info) +static char *CMP_SOR_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.SOR.S %s, %s, %s", fd, fs, ft); } @@ -4305,15 +4206,15 @@ static std::string CMP_SOR_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_SUEQ_D(uint64 instruction, Dis_info *info) +static char *CMP_SUEQ_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.SUEQ.D %s, %s, %s", fd, fs, ft); } @@ -4329,15 +4230,15 @@ static std::string CMP_SUEQ_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_SUEQ_S(uint64 instruction, Dis_info *info) +static char *CMP_SUEQ_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.SUEQ.S %s, %s, %s", fd, fs, ft); } @@ -4353,15 +4254,15 @@ static std::string CMP_SUEQ_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_SULE_D(uint64 instruction, Dis_info *info) +static char *CMP_SULE_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.SULE.D %s, %s, %s", fd, fs, ft); } @@ -4377,15 +4278,15 @@ static std::string CMP_SULE_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_SULE_S(uint64 instruction, Dis_info *info) +static char *CMP_SULE_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.SULE.S %s, %s, %s", fd, fs, ft); } @@ -4401,15 +4302,15 @@ static std::string CMP_SULE_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_SULT_D(uint64 instruction, Dis_info *info) +static char *CMP_SULT_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.SULT.D %s, %s, %s", fd, fs, ft); } @@ -4425,15 +4326,15 @@ static std::string CMP_SULT_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_SULT_S(uint64 instruction, Dis_info *info) +static char *CMP_SULT_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.SULT.S %s, %s, %s", fd, fs, ft); } @@ -4449,15 +4350,15 @@ static std::string CMP_SULT_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_SUN_D(uint64 instruction, Dis_info *info) +static char *CMP_SUN_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.SUN.D %s, %s, %s", fd, fs, ft); } @@ -4473,15 +4374,15 @@ static std::string CMP_SUN_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_SUNE_D(uint64 instruction, Dis_info *info) +static char *CMP_SUNE_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.SUNE.D %s, %s, %s", fd, fs, ft); } @@ -4497,15 +4398,15 @@ static std::string CMP_SUNE_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_SUNE_S(uint64 instruction, Dis_info *info) +static char *CMP_SUNE_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.SUNE.S %s, %s, %s", fd, fs, ft); } @@ -4521,15 +4422,15 @@ static std::string CMP_SUNE_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_SUN_S(uint64 instruction, Dis_info *info) +static char *CMP_SUN_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.SUN.S %s, %s, %s", fd, fs, ft); } @@ -4545,15 +4446,15 @@ static std::string CMP_SUN_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_UEQ_D(uint64 instruction, Dis_info *info) +static char *CMP_UEQ_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.UEQ.D %s, %s, %s", fd, fs, ft); } @@ -4569,15 +4470,15 @@ static std::string CMP_UEQ_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_UEQ_S(uint64 instruction, Dis_info *info) +static char *CMP_UEQ_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.UEQ.S %s, %s, %s", fd, fs, ft); } @@ -4593,15 +4494,15 @@ static std::string CMP_UEQ_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_ULE_D(uint64 instruction, Dis_info *info) +static char *CMP_ULE_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.ULE.D %s, %s, %s", fd, fs, ft); } @@ -4617,15 +4518,15 @@ static std::string CMP_ULE_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_ULE_S(uint64 instruction, Dis_info *info) +static char *CMP_ULE_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.ULE.S %s, %s, %s", fd, fs, ft); } @@ -4641,15 +4542,15 @@ static std::string CMP_ULE_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_ULT_D(uint64 instruction, Dis_info *info) +static char *CMP_ULT_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.ULT.D %s, %s, %s", fd, fs, ft); } @@ -4665,15 +4566,15 @@ static std::string CMP_ULT_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_ULT_S(uint64 instruction, Dis_info *info) +static char *CMP_ULT_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.ULT.S %s, %s, %s", fd, fs, ft); } @@ -4689,15 +4590,15 @@ static std::string CMP_ULT_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_UN_D(uint64 instruction, Dis_info *info) +static char *CMP_UN_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.UN.D %s, %s, %s", fd, fs, ft); } @@ -4713,15 +4614,15 @@ static std::string CMP_UN_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_UNE_D(uint64 instruction, Dis_info *info) +static char *CMP_UNE_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.UNE.D %s, %s, %s", fd, fs, ft); } @@ -4737,15 +4638,15 @@ static std::string CMP_UNE_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_UNE_S(uint64 instruction, Dis_info *info) +static char *CMP_UNE_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.UNE.S %s, %s, %s", fd, fs, ft); } @@ -4761,15 +4662,15 @@ static std::string CMP_UNE_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMP_UN_S(uint64 instruction, Dis_info *info) +static char *CMP_UN_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("CMP.UN.S %s, %s, %s", fd, fs, ft); } @@ -4786,15 +4687,15 @@ static std::string CMP_UN_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMPGDU_EQ_QB(uint64 instruction, Dis_info *info) +static char *CMPGDU_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("CMPGDU.EQ.QB %s, %s, %s", rd, rs, rt); } @@ -4811,15 +4712,15 @@ static std::string CMPGDU_EQ_QB(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMPGDU_LE_QB(uint64 instruction, Dis_info *info) +static char *CMPGDU_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("CMPGDU.LE.QB %s, %s, %s", rd, rs, rt); } @@ -4836,15 +4737,15 @@ static std::string CMPGDU_LE_QB(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMPGDU_LT_QB(uint64 instruction, Dis_info *info) +static char *CMPGDU_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("CMPGDU.LT.QB %s, %s, %s", rd, rs, rt); } @@ -4861,15 +4762,15 @@ static std::string CMPGDU_LT_QB(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMPGU_EQ_QB(uint64 instruction, Dis_info *info) +static char *CMPGU_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("CMPGU.EQ.QB %s, %s, %s", rd, rs, rt); } @@ -4886,15 +4787,15 @@ static std::string CMPGU_EQ_QB(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMPGU_LE_QB(uint64 instruction, Dis_info *info) +static char *CMPGU_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("CMPGU.LE.QB %s, %s, %s", rd, rs, rt); } @@ -4911,15 +4812,15 @@ static std::string CMPGU_LE_QB(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CMPGU_LT_QB(uint64 instruction, Dis_info *info) +static char *CMPGU_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("CMPGU.LT.QB %s, %s, %s", rd, rs, rt); } @@ -4935,13 +4836,13 @@ static std::string CMPGU_LT_QB(uint64 instruction, Dis_info *info) * rt ----- * rs ----- */ -static std::string CMPU_EQ_QB(uint64 instruction, Dis_info *info) +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); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("CMPU.EQ.QB %s, %s", rs, rt); } @@ -4957,13 +4858,13 @@ static std::string CMPU_EQ_QB(uint64 instruction, Dis_info *info) * rt ----- * rs ----- */ -static std::string CMPU_LE_QB(uint64 instruction, Dis_info *info) +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); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("CMPU.LE.QB %s, %s", rs, rt); } @@ -4979,13 +4880,13 @@ static std::string CMPU_LE_QB(uint64 instruction, Dis_info *info) * rt ----- * rs ----- */ -static std::string CMPU_LT_QB(uint64 instruction, Dis_info *info) +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); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("CMPU.LT.QB %s, %s", rs, rt); } @@ -5001,11 +4902,11 @@ static std::string CMPU_LT_QB(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string COP2_1(uint64 instruction, Dis_info *info) +static char *COP2_1(uint64 instruction, Dis_info *info) { uint64 cofun_value = extract_cofun_25_24_23(instruction); - std::string cofun = IMMEDIATE(cofun_value); + char *cofun = IMMEDIATE(cofun_value); return img_format("COP2_1 %s", cofun); } @@ -5021,13 +4922,13 @@ static std::string COP2_1(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CTC1(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string cs = CPR(cs_value); + const char *rt = GPR(rt_value); + char *cs = CPR(cs_value); return img_format("CTC1 %s, %s", rt, cs); } @@ -5043,13 +4944,13 @@ static std::string CTC1(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CTC2(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string cs = CPR(cs_value); + const char *rt = GPR(rt_value); + char *cs = CPR(cs_value); return img_format("CTC2 %s, %s", rt, cs); } @@ -5065,13 +4966,13 @@ static std::string CTC2(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CVT_D_L(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("CVT.D.L %s, %s", ft, fs); } @@ -5087,13 +4988,13 @@ static std::string CVT_D_L(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CVT_D_S(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("CVT.D.S %s, %s", ft, fs); } @@ -5109,13 +5010,13 @@ static std::string CVT_D_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CVT_D_W(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("CVT.D.W %s, %s", ft, fs); } @@ -5131,13 +5032,13 @@ static std::string CVT_D_W(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CVT_L_D(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("CVT.L.D %s, %s", ft, fs); } @@ -5153,13 +5054,13 @@ static std::string CVT_L_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CVT_L_S(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("CVT.L.S %s, %s", ft, fs); } @@ -5175,13 +5076,13 @@ static std::string CVT_L_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CVT_S_D(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("CVT.S.D %s, %s", ft, fs); } @@ -5197,13 +5098,13 @@ static std::string CVT_S_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CVT_S_L(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("CVT.S.L %s, %s", ft, fs); } @@ -5219,13 +5120,13 @@ static std::string CVT_S_L(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CVT_S_PL(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("CVT.S.PL %s, %s", ft, fs); } @@ -5241,13 +5142,13 @@ static std::string CVT_S_PL(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CVT_S_PU(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("CVT.S.PU %s, %s", ft, fs); } @@ -5263,13 +5164,13 @@ static std::string CVT_S_PU(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CVT_S_W(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("CVT.S.W %s, %s", ft, fs); } @@ -5285,13 +5186,13 @@ static std::string CVT_S_W(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CVT_W_D(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("CVT.W.D %s, %s", ft, fs); } @@ -5307,13 +5208,13 @@ static std::string CVT_W_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string CVT_W_S(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("CVT.W.S %s, %s", ft, fs); } @@ -5329,13 +5230,13 @@ static std::string CVT_W_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DADDIU_48_(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); return img_format("DADDIU %s, %s", rt, s); } @@ -5351,15 +5252,15 @@ static std::string DADDIU_48_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DADDIU_NEG_(uint64 instruction, Dis_info *info) +static char *DADDIU_NEG_(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); uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string u = IMMEDIATE(neg_copy(u_value)); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *u = IMMEDIATE(neg_copy(u_value)); return img_format("DADDIU %s, %s, %s", rt, rs, u); } @@ -5375,15 +5276,15 @@ static std::string DADDIU_NEG_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DADDIU_U12_(uint64 instruction, Dis_info *info) +static char *DADDIU_U12_(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); uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string u = IMMEDIATE(u_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *u = IMMEDIATE(u_value); return img_format("DADDIU %s, %s, %s", rt, rs, u); } @@ -5399,15 +5300,15 @@ static std::string DADDIU_U12_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DADD(uint64 instruction, Dis_info *info) +static char *DADD(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("DADD %s, %s, %s", rd, rs, rt); } @@ -5423,15 +5324,15 @@ static std::string DADD(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DADDU(uint64 instruction, Dis_info *info) +static char *DADDU(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("DADDU %s, %s, %s", rd, rs, rt); } @@ -5447,13 +5348,13 @@ static std::string DADDU(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DCLO(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("DCLO %s, %s", rt, rs); } @@ -5469,13 +5370,13 @@ static std::string DCLO(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DCLZ(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("DCLZ %s, %s", rt, rs); } @@ -5491,15 +5392,15 @@ static std::string DCLZ(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DDIV(uint64 instruction, Dis_info *info) +static char *DDIV(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("DDIV %s, %s, %s", rd, rs, rt); } @@ -5515,15 +5416,15 @@ static std::string DDIV(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DDIVU(uint64 instruction, Dis_info *info) +static char *DDIVU(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("DDIVU %s, %s, %s", rd, rs, rt); } @@ -5539,11 +5440,11 @@ static std::string DDIVU(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DERET(uint64 instruction, Dis_info *info) +static char *DERET(uint64 instruction, Dis_info *info) { (void)instruction; - return "DERET "; + return g_strdup("DERET "); } @@ -5557,17 +5458,17 @@ static std::string DERET(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DEXTM(uint64 instruction, Dis_info *info) +static char *DEXTM(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); uint64 msbd_value = extract_msbt_10_9_8_7_6(instruction); uint64 lsb_value = extract_lsb_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string lsb = IMMEDIATE(lsb_value); - std::string msbd = IMMEDIATE(encode_msbd_from_size(msbd_value)); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *lsb = IMMEDIATE(lsb_value); + char *msbd = IMMEDIATE(encode_msbd_from_size(msbd_value)); return img_format("DEXTM %s, %s, %s, %s", rt, rs, lsb, msbd); } @@ -5583,17 +5484,17 @@ static std::string DEXTM(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DEXT(uint64 instruction, Dis_info *info) +static char *DEXT(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); uint64 msbd_value = extract_msbt_10_9_8_7_6(instruction); uint64 lsb_value = extract_lsb_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string lsb = IMMEDIATE(lsb_value); - std::string msbd = IMMEDIATE(encode_msbd_from_size(msbd_value)); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *lsb = IMMEDIATE(lsb_value); + char *msbd = IMMEDIATE(encode_msbd_from_size(msbd_value)); return img_format("DEXT %s, %s, %s, %s", rt, rs, lsb, msbd); } @@ -5609,17 +5510,17 @@ static std::string DEXT(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DEXTU(uint64 instruction, Dis_info *info) +static char *DEXTU(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); uint64 msbd_value = extract_msbt_10_9_8_7_6(instruction); uint64 lsb_value = extract_lsb_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string lsb = IMMEDIATE(lsb_value); - std::string msbd = IMMEDIATE(encode_msbd_from_size(msbd_value)); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *lsb = IMMEDIATE(lsb_value); + char *msbd = IMMEDIATE(encode_msbd_from_size(msbd_value)); return img_format("DEXTU %s, %s, %s, %s", rt, rs, lsb, msbd); } @@ -5635,17 +5536,17 @@ static std::string DEXTU(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DINSM(uint64 instruction, Dis_info *info) +static char *DINSM(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); uint64 msbd_value = extract_msbt_10_9_8_7_6(instruction); uint64 lsb_value = extract_lsb_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string pos = IMMEDIATE(lsb_value); - std::string size = IMMEDIATE(msbd_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *pos = IMMEDIATE(lsb_value); + char *size = IMMEDIATE(msbd_value); /* !!!!!!!!!! - no conversion function */ return img_format("DINSM %s, %s, %s, %s", rt, rs, pos, size); @@ -5663,17 +5564,17 @@ static std::string DINSM(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DINS(uint64 instruction, Dis_info *info) +static char *DINS(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); uint64 msbd_value = extract_msbt_10_9_8_7_6(instruction); uint64 lsb_value = extract_lsb_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string pos = IMMEDIATE(lsb_value); - std::string size = IMMEDIATE(msbd_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *pos = IMMEDIATE(lsb_value); + char *size = IMMEDIATE(msbd_value); /* !!!!!!!!!! - no conversion function */ return img_format("DINS %s, %s, %s, %s", rt, rs, pos, size); @@ -5691,17 +5592,17 @@ static std::string DINS(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DINSU(uint64 instruction, Dis_info *info) +static char *DINSU(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); uint64 msbd_value = extract_msbt_10_9_8_7_6(instruction); uint64 lsb_value = extract_lsb_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string pos = IMMEDIATE(lsb_value); - std::string size = IMMEDIATE(msbd_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *pos = IMMEDIATE(lsb_value); + char *size = IMMEDIATE(msbd_value); /* !!!!!!!!!! - no conversion function */ return img_format("DINSU %s, %s, %s, %s", rt, rs, pos, size); @@ -5719,11 +5620,11 @@ static std::string DINSU(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DI(uint64 instruction, Dis_info *info) +static char *DI(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); - std::string rt = GPR(rt_value); + const char *rt = GPR(rt_value); return img_format("DI %s", rt); } @@ -5739,15 +5640,15 @@ static std::string DI(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DIV(uint64 instruction, Dis_info *info) +static char *DIV(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("DIV %s, %s, %s", rd, rs, rt); } @@ -5763,15 +5664,15 @@ static std::string DIV(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DIV_D(uint64 instruction, Dis_info *info) +static char *DIV_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("DIV.D %s, %s, %s", fd, fs, ft); } @@ -5787,15 +5688,15 @@ static std::string DIV_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DIV_S(uint64 instruction, Dis_info *info) +static char *DIV_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("DIV.S %s, %s, %s", fd, fs, ft); } @@ -5811,15 +5712,15 @@ static std::string DIV_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DIVU(uint64 instruction, Dis_info *info) +static char *DIVU(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("DIVU %s, %s, %s", rd, rs, rt); } @@ -5835,17 +5736,17 @@ static std::string DIVU(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DLSA(uint64 instruction, Dis_info *info) +static char *DLSA(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); uint64 u2_value = extract_u2_10_9(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); - std::string u2 = IMMEDIATE(u2_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *u2 = IMMEDIATE(u2_value); return img_format("DLSA %s, %s, %s, %s", rd, rs, rt, u2); } @@ -5861,13 +5762,13 @@ static std::string DLSA(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DLUI_48_(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string u = IMMEDIATE(u_value); + const char *rt = GPR(rt_value); + char *u = IMMEDIATE(u_value); return img_format("DLUI %s, %s", rt, u); } @@ -5883,15 +5784,15 @@ static std::string DLUI_48_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DMFC0(uint64 instruction, Dis_info *info) +static char *DMFC0(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); uint64 c0s_value = extract_c0s_20_19_18_17_16(instruction); uint64 sel_value = extract_sel_15_14_13_12_11(instruction); - std::string rt = GPR(rt_value); - std::string c0s = CPR(c0s_value); - std::string sel = IMMEDIATE(sel_value); + const char *rt = GPR(rt_value); + char *c0s = CPR(c0s_value); + char *sel = IMMEDIATE(sel_value); return img_format("DMFC0 %s, %s, %s", rt, c0s, sel); } @@ -5907,13 +5808,13 @@ static std::string DMFC0(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DMFC1(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string fs = FPR(fs_value); + const char *rt = GPR(rt_value); + const char *fs = FPR(fs_value); return img_format("DMFC1 %s, %s", rt, fs); } @@ -5929,13 +5830,13 @@ static std::string DMFC1(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DMFC2(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string cs = CPR(cs_value); + const char *rt = GPR(rt_value); + char *cs = CPR(cs_value); return img_format("DMFC2 %s, %s", rt, cs); } @@ -5951,15 +5852,15 @@ static std::string DMFC2(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DMFGC0(uint64 instruction, Dis_info *info) +static char *DMFGC0(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); uint64 c0s_value = extract_c0s_20_19_18_17_16(instruction); uint64 sel_value = extract_sel_15_14_13_12_11(instruction); - std::string rt = GPR(rt_value); - std::string c0s = CPR(c0s_value); - std::string sel = IMMEDIATE(sel_value); + const char *rt = GPR(rt_value); + char *c0s = CPR(c0s_value); + char *sel = IMMEDIATE(sel_value); return img_format("DMFGC0 %s, %s, %s", rt, c0s, sel); } @@ -5975,15 +5876,15 @@ static std::string DMFGC0(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DMOD(uint64 instruction, Dis_info *info) +static char *DMOD(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("DMOD %s, %s, %s", rd, rs, rt); } @@ -5999,15 +5900,15 @@ static std::string DMOD(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DMODU(uint64 instruction, Dis_info *info) +static char *DMODU(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("DMODU %s, %s, %s", rd, rs, rt); } @@ -6023,15 +5924,15 @@ static std::string DMODU(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DMTC0(uint64 instruction, Dis_info *info) +static char *DMTC0(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); uint64 c0s_value = extract_c0s_20_19_18_17_16(instruction); uint64 sel_value = extract_sel_15_14_13_12_11(instruction); - std::string rt = GPR(rt_value); - std::string c0s = CPR(c0s_value); - std::string sel = IMMEDIATE(sel_value); + const char *rt = GPR(rt_value); + char *c0s = CPR(c0s_value); + char *sel = IMMEDIATE(sel_value); return img_format("DMTC0 %s, %s, %s", rt, c0s, sel); } @@ -6047,13 +5948,13 @@ static std::string DMTC0(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DMTC1(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string fs = FPR(fs_value); + const char *rt = GPR(rt_value); + const char *fs = FPR(fs_value); return img_format("DMTC1 %s, %s", rt, fs); } @@ -6069,13 +5970,13 @@ static std::string DMTC1(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DMTC2(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string cs = CPR(cs_value); + const char *rt = GPR(rt_value); + char *cs = CPR(cs_value); return img_format("DMTC2 %s, %s", rt, cs); } @@ -6091,15 +5992,15 @@ static std::string DMTC2(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DMTGC0(uint64 instruction, Dis_info *info) +static char *DMTGC0(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); uint64 c0s_value = extract_c0s_20_19_18_17_16(instruction); uint64 sel_value = extract_sel_15_14_13_12_11(instruction); - std::string rt = GPR(rt_value); - std::string c0s = CPR(c0s_value); - std::string sel = IMMEDIATE(sel_value); + const char *rt = GPR(rt_value); + char *c0s = CPR(c0s_value); + char *sel = IMMEDIATE(sel_value); return img_format("DMTGC0 %s, %s, %s", rt, c0s, sel); } @@ -6115,11 +6016,11 @@ static std::string DMTGC0(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DMT(uint64 instruction, Dis_info *info) +static char *DMT(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); - std::string rt = GPR(rt_value); + const char *rt = GPR(rt_value); return img_format("DMT %s", rt); } @@ -6135,15 +6036,15 @@ static std::string DMT(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DMUH(uint64 instruction, Dis_info *info) +static char *DMUH(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("DMUH %s, %s, %s", rd, rs, rt); } @@ -6159,15 +6060,15 @@ static std::string DMUH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DMUHU(uint64 instruction, Dis_info *info) +static char *DMUHU(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("DMUHU %s, %s, %s", rd, rs, rt); } @@ -6183,15 +6084,15 @@ static std::string DMUHU(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DMUL(uint64 instruction, Dis_info *info) +static char *DMUL(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("DMUL %s, %s, %s", rd, rs, rt); } @@ -6207,15 +6108,15 @@ static std::string DMUL(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DMULU(uint64 instruction, Dis_info *info) +static char *DMULU(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("DMULU %s, %s, %s", rd, rs, rt); } @@ -6232,15 +6133,15 @@ static std::string DMULU(uint64 instruction, Dis_info *info) * rs ----- * ac -- */ -static std::string DPA_W_PH(uint64 instruction, Dis_info *info) +static char *DPA_W_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); uint64 ac_value = extract_ac_15_14(instruction); - std::string ac = AC(ac_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *ac = AC(ac_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("DPA.W.PH %s, %s, %s", ac, rs, rt); } @@ -6256,15 +6157,15 @@ static std::string DPA_W_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DPAQ_SA_L_W(uint64 instruction, Dis_info *info) +static char *DPAQ_SA_L_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); uint64 ac_value = extract_ac_15_14(instruction); - std::string ac = AC(ac_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *ac = AC(ac_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("DPAQ_SA.L.W %s, %s, %s", ac, rs, rt); } @@ -6280,15 +6181,15 @@ static std::string DPAQ_SA_L_W(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DPAQ_S_W_PH(uint64 instruction, Dis_info *info) +static char *DPAQ_S_W_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); uint64 ac_value = extract_ac_15_14(instruction); - std::string ac = AC(ac_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *ac = AC(ac_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("DPAQ_S.W.PH %s, %s, %s", ac, rs, rt); } @@ -6304,15 +6205,15 @@ static std::string DPAQ_S_W_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DPAQX_SA_W_PH(uint64 instruction, Dis_info *info) +static char *DPAQX_SA_W_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); uint64 ac_value = extract_ac_15_14(instruction); - std::string ac = AC(ac_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *ac = AC(ac_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("DPAQX_SA.W.PH %s, %s, %s", ac, rs, rt); } @@ -6328,15 +6229,15 @@ static std::string DPAQX_SA_W_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DPAQX_S_W_PH(uint64 instruction, Dis_info *info) +static char *DPAQX_S_W_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); uint64 ac_value = extract_ac_15_14(instruction); - std::string ac = AC(ac_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *ac = AC(ac_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("DPAQX_S.W.PH %s, %s, %s", ac, rs, rt); } @@ -6352,15 +6253,15 @@ static std::string DPAQX_S_W_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DPAU_H_QBL(uint64 instruction, Dis_info *info) +static char *DPAU_H_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); uint64 ac_value = extract_ac_15_14(instruction); - std::string ac = AC(ac_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *ac = AC(ac_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("DPAU.H.QBL %s, %s, %s", ac, rs, rt); } @@ -6376,15 +6277,15 @@ static std::string DPAU_H_QBL(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DPAU_H_QBR(uint64 instruction, Dis_info *info) +static char *DPAU_H_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); uint64 ac_value = extract_ac_15_14(instruction); - std::string ac = AC(ac_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *ac = AC(ac_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("DPAU.H.QBR %s, %s, %s", ac, rs, rt); } @@ -6400,15 +6301,15 @@ static std::string DPAU_H_QBR(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DPAX_W_PH(uint64 instruction, Dis_info *info) +static char *DPAX_W_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); uint64 ac_value = extract_ac_15_14(instruction); - std::string ac = AC(ac_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *ac = AC(ac_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("DPAX.W.PH %s, %s, %s", ac, rs, rt); } @@ -6424,15 +6325,15 @@ static std::string DPAX_W_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DPS_W_PH(uint64 instruction, Dis_info *info) +static char *DPS_W_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); uint64 ac_value = extract_ac_15_14(instruction); - std::string ac = AC(ac_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *ac = AC(ac_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("DPS.W.PH %s, %s, %s", ac, rs, rt); } @@ -6448,15 +6349,15 @@ static std::string DPS_W_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DPSQ_SA_L_W(uint64 instruction, Dis_info *info) +static char *DPSQ_SA_L_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); uint64 ac_value = extract_ac_15_14(instruction); - std::string ac = AC(ac_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *ac = AC(ac_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("DPSQ_SA.L.W %s, %s, %s", ac, rs, rt); } @@ -6472,15 +6373,15 @@ static std::string DPSQ_SA_L_W(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DPSQ_S_W_PH(uint64 instruction, Dis_info *info) +static char *DPSQ_S_W_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); uint64 ac_value = extract_ac_15_14(instruction); - std::string ac = AC(ac_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *ac = AC(ac_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("DPSQ_S.W.PH %s, %s, %s", ac, rs, rt); } @@ -6496,15 +6397,15 @@ static std::string DPSQ_S_W_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DPSQX_SA_W_PH(uint64 instruction, Dis_info *info) +static char *DPSQX_SA_W_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); uint64 ac_value = extract_ac_15_14(instruction); - std::string ac = AC(ac_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *ac = AC(ac_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("DPSQX_SA.W.PH %s, %s, %s", ac, rs, rt); } @@ -6520,15 +6421,15 @@ static std::string DPSQX_SA_W_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DPSQX_S_W_PH(uint64 instruction, Dis_info *info) +static char *DPSQX_S_W_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); uint64 ac_value = extract_ac_15_14(instruction); - std::string ac = AC(ac_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *ac = AC(ac_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("DPSQX_S.W.PH %s, %s, %s", ac, rs, rt); } @@ -6544,15 +6445,15 @@ static std::string DPSQX_S_W_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DPSU_H_QBL(uint64 instruction, Dis_info *info) +static char *DPSU_H_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); uint64 ac_value = extract_ac_15_14(instruction); - std::string ac = AC(ac_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *ac = AC(ac_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("DPSU.H.QBL %s, %s, %s", ac, rs, rt); } @@ -6568,15 +6469,15 @@ static std::string DPSU_H_QBL(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DPSU_H_QBR(uint64 instruction, Dis_info *info) +static char *DPSU_H_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); uint64 ac_value = extract_ac_15_14(instruction); - std::string ac = AC(ac_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *ac = AC(ac_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("DPSU.H.QBR %s, %s, %s", ac, rs, rt); } @@ -6592,15 +6493,15 @@ static std::string DPSU_H_QBR(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DPSX_W_PH(uint64 instruction, Dis_info *info) +static char *DPSX_W_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); uint64 ac_value = extract_ac_15_14(instruction); - std::string ac = AC(ac_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *ac = AC(ac_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("DPSX.W.PH %s, %s, %s", ac, rs, rt); } @@ -6616,15 +6517,15 @@ static std::string DPSX_W_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DROTR(uint64 instruction, Dis_info *info) +static char *DROTR(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); uint64 shift_value = extract_shift_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string shift = IMMEDIATE(shift_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *shift = IMMEDIATE(shift_value); return img_format("DROTR %s, %s, %s", rt, rs, shift); } @@ -6640,15 +6541,15 @@ static std::string DROTR(uint64 instruction, Dis_info *info) * rs ----- * shift ----- */ -static std::string DROTR32(uint64 instruction, Dis_info *info) +static char *DROTR32(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); uint64 shift_value = extract_shift_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string shift = IMMEDIATE(shift_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *shift = IMMEDIATE(shift_value); return img_format("DROTR32 %s, %s, %s", rt, rs, shift); } @@ -6664,15 +6565,15 @@ static std::string DROTR32(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DROTRV(uint64 instruction, Dis_info *info) +static char *DROTRV(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("DROTRV %s, %s, %s", rd, rs, rt); } @@ -6688,17 +6589,17 @@ static std::string DROTRV(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DROTX(uint64 instruction, Dis_info *info) +static char *DROTX(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); uint64 shiftx_value = extract_shiftx_11_10_9_8_7_6(instruction); uint64 shift_value = extract_shift_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string shift = IMMEDIATE(shift_value); - std::string shiftx = IMMEDIATE(shiftx_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *shift = IMMEDIATE(shift_value); + char *shiftx = IMMEDIATE(shiftx_value); return img_format("DROTX %s, %s, %s, %s", rt, rs, shift, shiftx); } @@ -6714,15 +6615,15 @@ static std::string DROTX(uint64 instruction, Dis_info *info) * rs ----- * shift ----- */ -static std::string DSLL(uint64 instruction, Dis_info *info) +static char *DSLL(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); uint64 shift_value = extract_shift_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string shift = IMMEDIATE(shift_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *shift = IMMEDIATE(shift_value); return img_format("DSLL %s, %s, %s", rt, rs, shift); } @@ -6738,15 +6639,15 @@ static std::string DSLL(uint64 instruction, Dis_info *info) * rs ----- * shift ----- */ -static std::string DSLL32(uint64 instruction, Dis_info *info) +static char *DSLL32(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); uint64 shift_value = extract_shift_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string shift = IMMEDIATE(shift_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *shift = IMMEDIATE(shift_value); return img_format("DSLL32 %s, %s, %s", rt, rs, shift); } @@ -6762,15 +6663,15 @@ static std::string DSLL32(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DSLLV(uint64 instruction, Dis_info *info) +static char *DSLLV(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("DSLLV %s, %s, %s", rd, rs, rt); } @@ -6786,15 +6687,15 @@ static std::string DSLLV(uint64 instruction, Dis_info *info) * rs ----- * shift ----- */ -static std::string DSRA(uint64 instruction, Dis_info *info) +static char *DSRA(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); uint64 shift_value = extract_shift_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string shift = IMMEDIATE(shift_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *shift = IMMEDIATE(shift_value); return img_format("DSRA %s, %s, %s", rt, rs, shift); } @@ -6810,15 +6711,15 @@ static std::string DSRA(uint64 instruction, Dis_info *info) * rs ----- * shift ----- */ -static std::string DSRA32(uint64 instruction, Dis_info *info) +static char *DSRA32(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); uint64 shift_value = extract_shift_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string shift = IMMEDIATE(shift_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *shift = IMMEDIATE(shift_value); return img_format("DSRA32 %s, %s, %s", rt, rs, shift); } @@ -6834,15 +6735,15 @@ static std::string DSRA32(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DSRAV(uint64 instruction, Dis_info *info) +static char *DSRAV(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("DSRAV %s, %s, %s", rd, rs, rt); } @@ -6858,15 +6759,15 @@ static std::string DSRAV(uint64 instruction, Dis_info *info) * rs ----- * shift ----- */ -static std::string DSRL(uint64 instruction, Dis_info *info) +static char *DSRL(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); uint64 shift_value = extract_shift_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string shift = IMMEDIATE(shift_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *shift = IMMEDIATE(shift_value); return img_format("DSRL %s, %s, %s", rt, rs, shift); } @@ -6882,15 +6783,15 @@ static std::string DSRL(uint64 instruction, Dis_info *info) * rs ----- * shift ----- */ -static std::string DSRL32(uint64 instruction, Dis_info *info) +static char *DSRL32(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); uint64 shift_value = extract_shift_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string shift = IMMEDIATE(shift_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *shift = IMMEDIATE(shift_value); return img_format("DSRL32 %s, %s, %s", rt, rs, shift); } @@ -6906,15 +6807,15 @@ static std::string DSRL32(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DSRLV(uint64 instruction, Dis_info *info) +static char *DSRLV(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("DSRLV %s, %s, %s", rd, rs, rt); } @@ -6930,15 +6831,15 @@ static std::string DSRLV(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DSUB(uint64 instruction, Dis_info *info) +static char *DSUB(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("DSUB %s, %s, %s", rd, rs, rt); } @@ -6954,15 +6855,15 @@ static std::string DSUB(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DSUBU(uint64 instruction, Dis_info *info) +static char *DSUBU(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("DSUBU %s, %s, %s", rd, rs, rt); } @@ -6978,11 +6879,11 @@ static std::string DSUBU(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DVPE(uint64 instruction, Dis_info *info) +static char *DVPE(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); - std::string rt = GPR(rt_value); + const char *rt = GPR(rt_value); return img_format("DVPE %s", rt); } @@ -6998,11 +6899,11 @@ static std::string DVPE(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string DVP(uint64 instruction, Dis_info *info) +static char *DVP(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); - std::string rt = GPR(rt_value); + const char *rt = GPR(rt_value); return img_format("DVP %s", rt); } @@ -7018,11 +6919,11 @@ static std::string DVP(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string EHB(uint64 instruction, Dis_info *info) +static char *EHB(uint64 instruction, Dis_info *info) { (void)instruction; - return "EHB "; + return g_strdup("EHB "); } @@ -7036,11 +6937,11 @@ static std::string EHB(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string EI(uint64 instruction, Dis_info *info) +static char *EI(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); - std::string rt = GPR(rt_value); + const char *rt = GPR(rt_value); return img_format("EI %s", rt); } @@ -7056,11 +6957,11 @@ static std::string EI(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string EMT(uint64 instruction, Dis_info *info) +static char *EMT(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); - std::string rt = GPR(rt_value); + const char *rt = GPR(rt_value); return img_format("EMT %s", rt); } @@ -7076,11 +6977,11 @@ static std::string EMT(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string ERET(uint64 instruction, Dis_info *info) +static char *ERET(uint64 instruction, Dis_info *info) { (void)instruction; - return "ERET "; + return g_strdup("ERET "); } @@ -7094,11 +6995,11 @@ static std::string ERET(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string ERETNC(uint64 instruction, Dis_info *info) +static char *ERETNC(uint64 instruction, Dis_info *info) { (void)instruction; - return "ERETNC "; + return g_strdup("ERETNC "); } @@ -7112,11 +7013,11 @@ static std::string ERETNC(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string EVP(uint64 instruction, Dis_info *info) +static char *EVP(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); - std::string rt = GPR(rt_value); + const char *rt = GPR(rt_value); return img_format("EVP %s", rt); } @@ -7132,11 +7033,11 @@ static std::string EVP(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string EVPE(uint64 instruction, Dis_info *info) +static char *EVPE(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); - std::string rt = GPR(rt_value); + const char *rt = GPR(rt_value); return img_format("EVPE %s", rt); } @@ -7152,17 +7053,17 @@ static std::string EVPE(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string EXT(uint64 instruction, Dis_info *info) +static char *EXT(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); uint64 msbd_value = extract_msbt_10_9_8_7_6(instruction); uint64 lsb_value = extract_lsb_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string lsb = IMMEDIATE(lsb_value); - std::string msbd = IMMEDIATE(encode_msbd_from_size(msbd_value)); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *lsb = IMMEDIATE(lsb_value); + char *msbd = IMMEDIATE(encode_msbd_from_size(msbd_value)); return img_format("EXT %s, %s, %s, %s", rt, rs, lsb, msbd); } @@ -7178,17 +7079,17 @@ static std::string EXT(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string EXTD(uint64 instruction, Dis_info *info) +static char *EXTD(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); uint64 shift_value = extract_shift_10_9_8_7_6(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); - std::string shift = IMMEDIATE(shift_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *shift = IMMEDIATE(shift_value); return img_format("EXTD %s, %s, %s, %s", rd, rs, rt, shift); } @@ -7204,17 +7105,17 @@ static std::string EXTD(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string EXTD32(uint64 instruction, Dis_info *info) +static char *EXTD32(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); uint64 shift_value = extract_shift_10_9_8_7_6(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); - std::string shift = IMMEDIATE(shift_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *shift = IMMEDIATE(shift_value); return img_format("EXTD32 %s, %s, %s, %s", rd, rs, rt, shift); } @@ -7230,15 +7131,15 @@ static std::string EXTD32(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string EXTPDP(uint64 instruction, Dis_info *info) +static char *EXTPDP(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); uint64 size_value = extract_size_20_19_18_17_16(instruction); uint64 ac_value = extract_ac_15_14(instruction); - std::string rt = GPR(rt_value); - std::string ac = AC(ac_value); - std::string size = IMMEDIATE(size_value); + const char *rt = GPR(rt_value); + const char *ac = AC(ac_value); + char *size = IMMEDIATE(size_value); return img_format("EXTPDP %s, %s, %s", rt, ac, size); } @@ -7254,15 +7155,15 @@ static std::string EXTPDP(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string EXTPDPV(uint64 instruction, Dis_info *info) +static char *EXTPDPV(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); uint64 ac_value = extract_ac_15_14(instruction); - std::string rt = GPR(rt_value); - std::string ac = AC(ac_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *ac = AC(ac_value); + const char *rs = GPR(rs_value); return img_format("EXTPDPV %s, %s, %s", rt, ac, rs); } @@ -7278,15 +7179,15 @@ static std::string EXTPDPV(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string EXTP(uint64 instruction, Dis_info *info) +static char *EXTP(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); uint64 size_value = extract_size_20_19_18_17_16(instruction); uint64 ac_value = extract_ac_15_14(instruction); - std::string rt = GPR(rt_value); - std::string ac = AC(ac_value); - std::string size = IMMEDIATE(size_value); + const char *rt = GPR(rt_value); + const char *ac = AC(ac_value); + char *size = IMMEDIATE(size_value); return img_format("EXTP %s, %s, %s", rt, ac, size); } @@ -7302,15 +7203,15 @@ static std::string EXTP(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string EXTPV(uint64 instruction, Dis_info *info) +static char *EXTPV(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); uint64 ac_value = extract_ac_15_14(instruction); - std::string rt = GPR(rt_value); - std::string ac = AC(ac_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *ac = AC(ac_value); + const char *rs = GPR(rs_value); return img_format("EXTPV %s, %s, %s", rt, ac, rs); } @@ -7327,15 +7228,15 @@ static std::string EXTPV(uint64 instruction, Dis_info *info) * shift ----- * ac -- */ -static std::string EXTR_RS_W(uint64 instruction, Dis_info *info) +static char *EXTR_RS_W(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); uint64 shift_value = extract_shift_20_19_18_17_16(instruction); uint64 ac_value = extract_ac_15_14(instruction); - std::string rt = GPR(rt_value); - std::string ac = AC(ac_value); - std::string shift = IMMEDIATE(shift_value); + const char *rt = GPR(rt_value); + const char *ac = AC(ac_value); + char *shift = IMMEDIATE(shift_value); return img_format("EXTR_RS.W %s, %s, %s", rt, ac, shift); } @@ -7352,15 +7253,15 @@ static std::string EXTR_RS_W(uint64 instruction, Dis_info *info) * shift ----- * ac -- */ -static std::string EXTR_R_W(uint64 instruction, Dis_info *info) +static char *EXTR_R_W(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); uint64 shift_value = extract_shift_20_19_18_17_16(instruction); uint64 ac_value = extract_ac_15_14(instruction); - std::string rt = GPR(rt_value); - std::string ac = AC(ac_value); - std::string shift = IMMEDIATE(shift_value); + const char *rt = GPR(rt_value); + const char *ac = AC(ac_value); + char *shift = IMMEDIATE(shift_value); return img_format("EXTR_R.W %s, %s, %s", rt, ac, shift); } @@ -7377,15 +7278,15 @@ static std::string EXTR_R_W(uint64 instruction, Dis_info *info) * shift ----- * ac -- */ -static std::string EXTR_S_H(uint64 instruction, Dis_info *info) +static char *EXTR_S_H(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); uint64 shift_value = extract_shift_20_19_18_17_16(instruction); uint64 ac_value = extract_ac_15_14(instruction); - std::string rt = GPR(rt_value); - std::string ac = AC(ac_value); - std::string shift = IMMEDIATE(shift_value); + const char *rt = GPR(rt_value); + const char *ac = AC(ac_value); + char *shift = IMMEDIATE(shift_value); return img_format("EXTR_S.H %s, %s, %s", rt, ac, shift); } @@ -7402,15 +7303,15 @@ static std::string EXTR_S_H(uint64 instruction, Dis_info *info) * shift ----- * ac -- */ -static std::string EXTR_W(uint64 instruction, Dis_info *info) +static char *EXTR_W(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); uint64 shift_value = extract_shift_20_19_18_17_16(instruction); uint64 ac_value = extract_ac_15_14(instruction); - std::string rt = GPR(rt_value); - std::string ac = AC(ac_value); - std::string shift = IMMEDIATE(shift_value); + const char *rt = GPR(rt_value); + const char *ac = AC(ac_value); + char *shift = IMMEDIATE(shift_value); return img_format("EXTR.W %s, %s, %s", rt, ac, shift); } @@ -7427,15 +7328,15 @@ static std::string EXTR_W(uint64 instruction, Dis_info *info) * rs ----- * ac -- */ -static std::string EXTRV_RS_W(uint64 instruction, Dis_info *info) +static char *EXTRV_RS_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); uint64 ac_value = extract_ac_15_14(instruction); - std::string rt = GPR(rt_value); - std::string ac = AC(ac_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *ac = AC(ac_value); + const char *rs = GPR(rs_value); return img_format("EXTRV_RS.W %s, %s, %s", rt, ac, rs); } @@ -7452,15 +7353,15 @@ static std::string EXTRV_RS_W(uint64 instruction, Dis_info *info) * rs ----- * ac -- */ -static std::string EXTRV_R_W(uint64 instruction, Dis_info *info) +static char *EXTRV_R_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); uint64 ac_value = extract_ac_15_14(instruction); - std::string rt = GPR(rt_value); - std::string ac = AC(ac_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *ac = AC(ac_value); + const char *rs = GPR(rs_value); return img_format("EXTRV_R.W %s, %s, %s", rt, ac, rs); } @@ -7477,15 +7378,15 @@ static std::string EXTRV_R_W(uint64 instruction, Dis_info *info) * rs ----- * ac -- */ -static std::string EXTRV_S_H(uint64 instruction, Dis_info *info) +static char *EXTRV_S_H(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); uint64 ac_value = extract_ac_15_14(instruction); - std::string rt = GPR(rt_value); - std::string ac = AC(ac_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *ac = AC(ac_value); + const char *rs = GPR(rs_value); return img_format("EXTRV_S.H %s, %s, %s", rt, ac, rs); } @@ -7502,15 +7403,15 @@ static std::string EXTRV_S_H(uint64 instruction, Dis_info *info) * rs ----- * ac -- */ -static std::string EXTRV_W(uint64 instruction, Dis_info *info) +static char *EXTRV_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); uint64 ac_value = extract_ac_15_14(instruction); - std::string rt = GPR(rt_value); - std::string ac = AC(ac_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *ac = AC(ac_value); + const char *rs = GPR(rs_value); return img_format("EXTRV.W %s, %s, %s", rt, ac, rs); } @@ -7527,17 +7428,17 @@ static std::string EXTRV_W(uint64 instruction, Dis_info *info) * rd ----- * shift ----- */ -static std::string EXTW(uint64 instruction, Dis_info *info) +static char *EXTW(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); uint64 shift_value = extract_shift_10_9_8_7_6(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); - std::string shift = IMMEDIATE(shift_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *shift = IMMEDIATE(shift_value); return img_format("EXTW %s, %s, %s, %s", rd, rs, rt, shift); } @@ -7553,13 +7454,13 @@ static std::string EXTW(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string FLOOR_L_D(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("FLOOR.L.D %s, %s", ft, fs); } @@ -7575,13 +7476,13 @@ static std::string FLOOR_L_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string FLOOR_L_S(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("FLOOR.L.S %s, %s", ft, fs); } @@ -7597,13 +7498,13 @@ static std::string FLOOR_L_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string FLOOR_W_D(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("FLOOR.W.D %s, %s", ft, fs); } @@ -7619,13 +7520,13 @@ static std::string FLOOR_W_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string FLOOR_W_S(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("FLOOR.W.S %s, %s", ft, fs); } @@ -7641,15 +7542,15 @@ static std::string FLOOR_W_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string FORK(uint64 instruction, Dis_info *info) +static char *FORK(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("FORK %s, %s, %s", rd, rs, rt); } @@ -7665,11 +7566,11 @@ static std::string FORK(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string HYPCALL(uint64 instruction, Dis_info *info) +static char *HYPCALL(uint64 instruction, Dis_info *info) { uint64 code_value = extract_code_17_to_0(instruction); - std::string code = IMMEDIATE(code_value); + char *code = IMMEDIATE(code_value); return img_format("HYPCALL %s", code); } @@ -7685,11 +7586,11 @@ static std::string HYPCALL(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string HYPCALL_16_(uint64 instruction, Dis_info *info) +static char *HYPCALL_16_(uint64 instruction, Dis_info *info) { uint64 code_value = extract_code_1_0(instruction); - std::string code = IMMEDIATE(code_value); + char *code = IMMEDIATE(code_value); return img_format("HYPCALL %s", code); } @@ -7705,17 +7606,17 @@ static std::string HYPCALL_16_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string INS(uint64 instruction, Dis_info *info) +static char *INS(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); uint64 msbd_value = extract_msbt_10_9_8_7_6(instruction); uint64 lsb_value = extract_lsb_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string pos = IMMEDIATE(lsb_value); - std::string size = IMMEDIATE(msbd_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *pos = IMMEDIATE(lsb_value); + char *size = IMMEDIATE(msbd_value); /* !!!!!!!!!! - no conversion function */ return img_format("INS %s, %s, %s, %s", rt, rs, pos, size); @@ -7732,13 +7633,13 @@ static std::string INS(uint64 instruction, Dis_info *info) * rt ----- * rs ----- */ -static std::string INSV(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("INSV %s, %s", rt, rs); } @@ -7754,11 +7655,11 @@ static std::string INSV(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string IRET(uint64 instruction, Dis_info *info) +static char *IRET(uint64 instruction, Dis_info *info) { (void)instruction; - return "IRET "; + return g_strdup("IRET "); } @@ -7772,11 +7673,11 @@ static std::string IRET(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string JALRC_16_(uint64 instruction, Dis_info *info) +static char *JALRC_16_(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_9_8_7_6_5(instruction); - std::string rt = GPR(rt_value); + const char *rt = GPR(rt_value); return img_format("JALRC $%d, %s", 31, rt); } @@ -7792,13 +7693,13 @@ static std::string JALRC_16_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string JALRC_32_(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("JALRC %s, %s", rt, rs); } @@ -7814,13 +7715,13 @@ static std::string JALRC_32_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string JALRC_HB(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("JALRC.HB %s, %s", rt, rs); } @@ -7836,11 +7737,11 @@ static std::string JALRC_HB(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string JRC(uint64 instruction, Dis_info *info) +static char *JRC(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_9_8_7_6_5(instruction); - std::string rt = GPR(rt_value); + const char *rt = GPR(rt_value); return img_format("JRC %s", rt); } @@ -7856,15 +7757,15 @@ static std::string JRC(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LB_16_(uint64 instruction, Dis_info *info) +static char *LB_16_(uint64 instruction, Dis_info *info) { uint64 rt3_value = extract_rt3_9_8_7(instruction); uint64 rs3_value = extract_rs3_6_5_4(instruction); uint64 u_value = extract_u_1_0(instruction); - std::string rt3 = GPR(decode_gpr_gpr3(rt3_value)); - std::string u = IMMEDIATE(u_value); - std::string rs3 = GPR(decode_gpr_gpr3(rs3_value)); + const char *rt3 = GPR(decode_gpr_gpr3(rt3_value)); + char *u = IMMEDIATE(u_value); + const char *rs3 = GPR(decode_gpr_gpr3(rs3_value)); return img_format("LB %s, %s(%s)", rt3, u, rs3); } @@ -7880,13 +7781,13 @@ static std::string LB_16_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LB_GP_(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string u = IMMEDIATE(u_value); + const char *rt = GPR(rt_value); + char *u = IMMEDIATE(u_value); return img_format("LB %s, %s($%d)", rt, u, 28); } @@ -7902,15 +7803,15 @@ static std::string LB_GP_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LB_S9_(uint64 instruction, Dis_info *info) +static char *LB_S9_(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); int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("LB %s, %s(%s)", rt, s, rs); } @@ -7926,15 +7827,15 @@ static std::string LB_S9_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LB_U12_(uint64 instruction, Dis_info *info) +static char *LB_U12_(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); uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string u = IMMEDIATE(u_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *u = IMMEDIATE(u_value); + const char *rs = GPR(rs_value); return img_format("LB %s, %s(%s)", rt, u, rs); } @@ -7950,15 +7851,15 @@ static std::string LB_U12_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LBE(uint64 instruction, Dis_info *info) +static char *LBE(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); int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("LBE %s, %s(%s)", rt, s, rs); } @@ -7974,15 +7875,15 @@ static std::string LBE(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LBU_16_(uint64 instruction, Dis_info *info) +static char *LBU_16_(uint64 instruction, Dis_info *info) { uint64 rt3_value = extract_rt3_9_8_7(instruction); uint64 rs3_value = extract_rs3_6_5_4(instruction); uint64 u_value = extract_u_1_0(instruction); - std::string rt3 = GPR(decode_gpr_gpr3(rt3_value)); - std::string u = IMMEDIATE(u_value); - std::string rs3 = GPR(decode_gpr_gpr3(rs3_value)); + const char *rt3 = GPR(decode_gpr_gpr3(rt3_value)); + char *u = IMMEDIATE(u_value); + const char *rs3 = GPR(decode_gpr_gpr3(rs3_value)); return img_format("LBU %s, %s(%s)", rt3, u, rs3); } @@ -7998,13 +7899,13 @@ static std::string LBU_16_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LBU_GP_(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string u = IMMEDIATE(u_value); + const char *rt = GPR(rt_value); + char *u = IMMEDIATE(u_value); return img_format("LBU %s, %s($%d)", rt, u, 28); } @@ -8020,15 +7921,15 @@ static std::string LBU_GP_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LBU_S9_(uint64 instruction, Dis_info *info) +static char *LBU_S9_(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); int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("LBU %s, %s(%s)", rt, s, rs); } @@ -8044,15 +7945,15 @@ static std::string LBU_S9_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LBU_U12_(uint64 instruction, Dis_info *info) +static char *LBU_U12_(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); uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string u = IMMEDIATE(u_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *u = IMMEDIATE(u_value); + const char *rs = GPR(rs_value); return img_format("LBU %s, %s(%s)", rt, u, rs); } @@ -8068,15 +7969,15 @@ static std::string LBU_U12_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LBUE(uint64 instruction, Dis_info *info) +static char *LBUE(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); int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("LBUE %s, %s(%s)", rt, s, rs); } @@ -8092,15 +7993,15 @@ static std::string LBUE(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LBUX(uint64 instruction, Dis_info *info) +static char *LBUX(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("LBUX %s, %s(%s)", rd, rs, rt); } @@ -8116,15 +8017,15 @@ static std::string LBUX(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LBX(uint64 instruction, Dis_info *info) +static char *LBX(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("LBX %s, %s(%s)", rd, rs, rt); } @@ -8140,13 +8041,13 @@ static std::string LBX(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LD_GP_(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string u = IMMEDIATE(u_value); + const char *rt = GPR(rt_value); + char *u = IMMEDIATE(u_value); return img_format("LD %s, %s($%d)", rt, u, 28); } @@ -8162,15 +8063,15 @@ static std::string LD_GP_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LD_S9_(uint64 instruction, Dis_info *info) +static char *LD_S9_(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); int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("LD %s, %s(%s)", rt, s, rs); } @@ -8186,15 +8087,15 @@ static std::string LD_S9_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LD_U12_(uint64 instruction, Dis_info *info) +static char *LD_U12_(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); uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string u = IMMEDIATE(u_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *u = IMMEDIATE(u_value); + const char *rs = GPR(rs_value); return img_format("LD %s, %s(%s)", rt, u, rs); } @@ -8210,13 +8111,13 @@ static std::string LD_U12_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LDC1_GP_(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string u = IMMEDIATE(u_value); + const char *ft = FPR(ft_value); + char *u = IMMEDIATE(u_value); return img_format("LDC1 %s, %s($%d)", ft, u, 28); } @@ -8232,15 +8133,15 @@ static std::string LDC1_GP_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LDC1_S9_(uint64 instruction, Dis_info *info) +static char *LDC1_S9_(uint64 instruction, Dis_info *info) { uint64 ft_value = extract_ft_25_24_23_22_21(instruction); 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); - std::string ft = FPR(ft_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + const char *ft = FPR(ft_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("LDC1 %s, %s(%s)", ft, s, rs); } @@ -8256,15 +8157,15 @@ static std::string LDC1_S9_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LDC1_U12_(uint64 instruction, Dis_info *info) +static char *LDC1_U12_(uint64 instruction, Dis_info *info) { uint64 ft_value = extract_ft_25_24_23_22_21(instruction); 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); - std::string ft = FPR(ft_value); - std::string u = IMMEDIATE(u_value); - std::string rs = GPR(rs_value); + const char *ft = FPR(ft_value); + char *u = IMMEDIATE(u_value); + const char *rs = GPR(rs_value); return img_format("LDC1 %s, %s(%s)", ft, u, rs); } @@ -8280,15 +8181,15 @@ static std::string LDC1_U12_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LDC1XS(uint64 instruction, Dis_info *info) +static char *LDC1XS(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); uint64 ft_value = extract_ft_15_14_13_12_11(instruction); - std::string ft = FPR(ft_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *ft = FPR(ft_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("LDC1XS %s, %s(%s)", ft, rs, rt); } @@ -8304,15 +8205,15 @@ static std::string LDC1XS(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LDC1X(uint64 instruction, Dis_info *info) +static char *LDC1X(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); uint64 ft_value = extract_ft_15_14_13_12_11(instruction); - std::string ft = FPR(ft_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *ft = FPR(ft_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("LDC1X %s, %s(%s)", ft, rs, rt); } @@ -8328,15 +8229,15 @@ static std::string LDC1X(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LDC2(uint64 instruction, Dis_info *info) +static char *LDC2(uint64 instruction, Dis_info *info) { uint64 ct_value = extract_ct_25_24_23_22_21(instruction); 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); - std::string ct = CPR(ct_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + char *ct = CPR(ct_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("LDC2 %s, %s(%s)", ct, s, rs); } @@ -8352,17 +8253,17 @@ static std::string LDC2(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LDM(uint64 instruction, Dis_info *info) +static char *LDM(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); 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); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); - std::string count3 = IMMEDIATE(encode_count3_from_count(count3_value)); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); + char *count3 = IMMEDIATE(encode_count3_from_count(count3_value)); return img_format("LDM %s, %s(%s), %s", rt, s, rs, count3); } @@ -8378,13 +8279,13 @@ static std::string LDM(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LDPC_48_(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string s = ADDRESS(s_value, 6, info); + const char *rt = GPR(rt_value); + char *s = ADDRESS(s_value, 6, info); return img_format("LDPC %s, %s", rt, s); } @@ -8400,15 +8301,15 @@ static std::string LDPC_48_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LDX(uint64 instruction, Dis_info *info) +static char *LDX(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("LDX %s, %s(%s)", rd, rs, rt); } @@ -8424,15 +8325,15 @@ static std::string LDX(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LDXS(uint64 instruction, Dis_info *info) +static char *LDXS(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("LDXS %s, %s(%s)", rd, rs, rt); } @@ -8448,15 +8349,15 @@ static std::string LDXS(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LH_16_(uint64 instruction, Dis_info *info) +static char *LH_16_(uint64 instruction, Dis_info *info) { uint64 rt3_value = extract_rt3_9_8_7(instruction); uint64 rs3_value = extract_rs3_6_5_4(instruction); uint64 u_value = extract_u_2_1__s1(instruction); - std::string rt3 = GPR(decode_gpr_gpr3(rt3_value)); - std::string u = IMMEDIATE(u_value); - std::string rs3 = GPR(decode_gpr_gpr3(rs3_value)); + const char *rt3 = GPR(decode_gpr_gpr3(rt3_value)); + char *u = IMMEDIATE(u_value); + const char *rs3 = GPR(decode_gpr_gpr3(rs3_value)); return img_format("LH %s, %s(%s)", rt3, u, rs3); } @@ -8472,13 +8373,13 @@ static std::string LH_16_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LH_GP_(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string u = IMMEDIATE(u_value); + const char *rt = GPR(rt_value); + char *u = IMMEDIATE(u_value); return img_format("LH %s, %s($%d)", rt, u, 28); } @@ -8494,15 +8395,15 @@ static std::string LH_GP_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LH_S9_(uint64 instruction, Dis_info *info) +static char *LH_S9_(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); int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("LH %s, %s(%s)", rt, s, rs); } @@ -8518,15 +8419,15 @@ static std::string LH_S9_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LH_U12_(uint64 instruction, Dis_info *info) +static char *LH_U12_(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); uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string u = IMMEDIATE(u_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *u = IMMEDIATE(u_value); + const char *rs = GPR(rs_value); return img_format("LH %s, %s(%s)", rt, u, rs); } @@ -8542,15 +8443,15 @@ static std::string LH_U12_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LHE(uint64 instruction, Dis_info *info) +static char *LHE(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); int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("LHE %s, %s(%s)", rt, s, rs); } @@ -8566,15 +8467,15 @@ static std::string LHE(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LHU_16_(uint64 instruction, Dis_info *info) +static char *LHU_16_(uint64 instruction, Dis_info *info) { uint64 rt3_value = extract_rt3_9_8_7(instruction); uint64 rs3_value = extract_rs3_6_5_4(instruction); uint64 u_value = extract_u_2_1__s1(instruction); - std::string rt3 = GPR(decode_gpr_gpr3(rt3_value)); - std::string u = IMMEDIATE(u_value); - std::string rs3 = GPR(decode_gpr_gpr3(rs3_value)); + const char *rt3 = GPR(decode_gpr_gpr3(rt3_value)); + char *u = IMMEDIATE(u_value); + const char *rs3 = GPR(decode_gpr_gpr3(rs3_value)); return img_format("LHU %s, %s(%s)", rt3, u, rs3); } @@ -8590,13 +8491,13 @@ static std::string LHU_16_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LHU_GP_(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string u = IMMEDIATE(u_value); + const char *rt = GPR(rt_value); + char *u = IMMEDIATE(u_value); return img_format("LHU %s, %s($%d)", rt, u, 28); } @@ -8612,15 +8513,15 @@ static std::string LHU_GP_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LHU_S9_(uint64 instruction, Dis_info *info) +static char *LHU_S9_(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); int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("LHU %s, %s(%s)", rt, s, rs); } @@ -8636,15 +8537,15 @@ static std::string LHU_S9_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LHU_U12_(uint64 instruction, Dis_info *info) +static char *LHU_U12_(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); uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string u = IMMEDIATE(u_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *u = IMMEDIATE(u_value); + const char *rs = GPR(rs_value); return img_format("LHU %s, %s(%s)", rt, u, rs); } @@ -8660,15 +8561,15 @@ static std::string LHU_U12_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LHUE(uint64 instruction, Dis_info *info) +static char *LHUE(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); int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("LHUE %s, %s(%s)", rt, s, rs); } @@ -8684,15 +8585,15 @@ static std::string LHUE(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LHUX(uint64 instruction, Dis_info *info) +static char *LHUX(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("LHUX %s, %s(%s)", rd, rs, rt); } @@ -8708,15 +8609,15 @@ static std::string LHUX(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LHUXS(uint64 instruction, Dis_info *info) +static char *LHUXS(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("LHUXS %s, %s(%s)", rd, rs, rt); } @@ -8732,15 +8633,15 @@ static std::string LHUXS(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LHXS(uint64 instruction, Dis_info *info) +static char *LHXS(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("LHXS %s, %s(%s)", rd, rs, rt); } @@ -8756,15 +8657,15 @@ static std::string LHXS(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LHX(uint64 instruction, Dis_info *info) +static char *LHX(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("LHX %s, %s(%s)", rd, rs, rt); } @@ -8780,13 +8681,13 @@ static std::string LHX(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LI_16_(uint64 instruction, Dis_info *info) +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); - std::string rt3 = GPR(decode_gpr_gpr3(rt3_value)); - std::string eu = IMMEDIATE(encode_eu_from_s_li16(eu_value)); + const char *rt3 = GPR(decode_gpr_gpr3(rt3_value)); + char *eu = IMMEDIATE(encode_eu_from_s_li16(eu_value)); return img_format("LI %s, %s", rt3, eu); } @@ -8802,13 +8703,13 @@ static std::string LI_16_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LI_48_(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); return img_format("LI %s, %s", rt, s); } @@ -8824,15 +8725,15 @@ static std::string LI_48_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LL(uint64 instruction, Dis_info *info) +static char *LL(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); int64 s_value = extract_s__se8_15_7_6_5_4_3_2_s2(instruction); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("LL %s, %s(%s)", rt, s, rs); } @@ -8848,15 +8749,15 @@ static std::string LL(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LLD(uint64 instruction, Dis_info *info) +static char *LLD(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); int64 s_value = extract_s__se8_15_7_6_5_4_3_s3(instruction); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("LLD %s, %s(%s)", rt, s, rs); } @@ -8872,15 +8773,15 @@ static std::string LLD(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LLDP(uint64 instruction, Dis_info *info) +static char *LLDP(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); uint64 ru_value = extract_ru_7_6_5_4_3(instruction); - std::string rt = GPR(rt_value); - std::string ru = GPR(ru_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *ru = GPR(ru_value); + const char *rs = GPR(rs_value); return img_format("LLDP %s, %s, (%s)", rt, ru, rs); } @@ -8896,15 +8797,15 @@ static std::string LLDP(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LLE(uint64 instruction, Dis_info *info) +static char *LLE(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); int64 s_value = extract_s__se8_15_7_6_5_4_3_2_s2(instruction); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("LLE %s, %s(%s)", rt, s, rs); } @@ -8920,15 +8821,15 @@ static std::string LLE(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LLWP(uint64 instruction, Dis_info *info) +static char *LLWP(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); uint64 ru_value = extract_ru_7_6_5_4_3(instruction); - std::string rt = GPR(rt_value); - std::string ru = GPR(ru_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *ru = GPR(ru_value); + const char *rs = GPR(rs_value); return img_format("LLWP %s, %s, (%s)", rt, ru, rs); } @@ -8944,15 +8845,15 @@ static std::string LLWP(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LLWPE(uint64 instruction, Dis_info *info) +static char *LLWPE(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); uint64 ru_value = extract_ru_7_6_5_4_3(instruction); - std::string rt = GPR(rt_value); - std::string ru = GPR(ru_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *ru = GPR(ru_value); + const char *rs = GPR(rs_value); return img_format("LLWPE %s, %s, (%s)", rt, ru, rs); } @@ -8968,17 +8869,17 @@ static std::string LLWPE(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LSA(uint64 instruction, Dis_info *info) +static char *LSA(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); uint64 u2_value = extract_u2_10_9(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); - std::string u2 = IMMEDIATE(u2_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *u2 = IMMEDIATE(u2_value); return img_format("LSA %s, %s, %s, %s", rd, rs, rt, u2); } @@ -8994,13 +8895,13 @@ static std::string LSA(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LUI(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); return img_format("LUI %s, %%hi(%s)", rt, s); } @@ -9016,15 +8917,15 @@ static std::string LUI(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LW_16_(uint64 instruction, Dis_info *info) +static char *LW_16_(uint64 instruction, Dis_info *info) { uint64 rt3_value = extract_rt3_9_8_7(instruction); uint64 rs3_value = extract_rs3_6_5_4(instruction); uint64 u_value = extract_u_3_2_1_0__s2(instruction); - std::string rt3 = GPR(decode_gpr_gpr3(rt3_value)); - std::string u = IMMEDIATE(u_value); - std::string rs3 = GPR(decode_gpr_gpr3(rs3_value)); + const char *rt3 = GPR(decode_gpr_gpr3(rt3_value)); + char *u = IMMEDIATE(u_value); + const char *rs3 = GPR(decode_gpr_gpr3(rs3_value)); return img_format("LW %s, %s(%s)", rt3, u, rs3); } @@ -9040,15 +8941,15 @@ static std::string LW_16_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LW_4X4_(uint64 instruction, Dis_info *info) +static char *LW_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); uint64 u_value = extract_u_3_8__s2(instruction); - std::string rt4 = GPR(decode_gpr_gpr4(rt4_value)); - std::string u = IMMEDIATE(u_value); - std::string rs4 = GPR(decode_gpr_gpr4(rs4_value)); + const char *rt4 = GPR(decode_gpr_gpr4(rt4_value)); + char *u = IMMEDIATE(u_value); + const char *rs4 = GPR(decode_gpr_gpr4(rs4_value)); return img_format("LW %s, %s(%s)", rt4, u, rs4); } @@ -9064,13 +8965,13 @@ static std::string LW_4X4_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LW_GP_(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string u = IMMEDIATE(u_value); + const char *rt = GPR(rt_value); + char *u = IMMEDIATE(u_value); return img_format("LW %s, %s($%d)", rt, u, 28); } @@ -9086,13 +8987,13 @@ static std::string LW_GP_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LW_GP16_(uint64 instruction, Dis_info *info) +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); - std::string rt3 = GPR(decode_gpr_gpr3(rt3_value)); - std::string u = IMMEDIATE(u_value); + const char *rt3 = GPR(decode_gpr_gpr3(rt3_value)); + char *u = IMMEDIATE(u_value); return img_format("LW %s, %s($%d)", rt3, u, 28); } @@ -9108,15 +9009,15 @@ static std::string LW_GP16_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LW_S9_(uint64 instruction, Dis_info *info) +static char *LW_S9_(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); int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("LW %s, %s(%s)", rt, s, rs); } @@ -9132,13 +9033,13 @@ static std::string LW_S9_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LW_SP_(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string u = IMMEDIATE(u_value); + const char *rt = GPR(rt_value); + char *u = IMMEDIATE(u_value); return img_format("LW %s, %s($%d)", rt, u, 29); } @@ -9154,15 +9055,15 @@ static std::string LW_SP_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LW_U12_(uint64 instruction, Dis_info *info) +static char *LW_U12_(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); uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string u = IMMEDIATE(u_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *u = IMMEDIATE(u_value); + const char *rs = GPR(rs_value); return img_format("LW %s, %s(%s)", rt, u, rs); } @@ -9178,13 +9079,13 @@ static std::string LW_U12_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LWC1_GP_(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string u = IMMEDIATE(u_value); + const char *ft = FPR(ft_value); + char *u = IMMEDIATE(u_value); return img_format("LWC1 %s, %s($%d)", ft, u, 28); } @@ -9200,15 +9101,15 @@ static std::string LWC1_GP_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LWC1_S9_(uint64 instruction, Dis_info *info) +static char *LWC1_S9_(uint64 instruction, Dis_info *info) { uint64 ft_value = extract_ft_25_24_23_22_21(instruction); 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); - std::string ft = FPR(ft_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + const char *ft = FPR(ft_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("LWC1 %s, %s(%s)", ft, s, rs); } @@ -9224,15 +9125,15 @@ static std::string LWC1_S9_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LWC1_U12_(uint64 instruction, Dis_info *info) +static char *LWC1_U12_(uint64 instruction, Dis_info *info) { uint64 ft_value = extract_ft_25_24_23_22_21(instruction); 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); - std::string ft = FPR(ft_value); - std::string u = IMMEDIATE(u_value); - std::string rs = GPR(rs_value); + const char *ft = FPR(ft_value); + char *u = IMMEDIATE(u_value); + const char *rs = GPR(rs_value); return img_format("LWC1 %s, %s(%s)", ft, u, rs); } @@ -9248,15 +9149,15 @@ static std::string LWC1_U12_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LWC1X(uint64 instruction, Dis_info *info) +static char *LWC1X(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); uint64 ft_value = extract_ft_15_14_13_12_11(instruction); - std::string ft = FPR(ft_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *ft = FPR(ft_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("LWC1X %s, %s(%s)", ft, rs, rt); } @@ -9272,15 +9173,15 @@ static std::string LWC1X(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LWC1XS(uint64 instruction, Dis_info *info) +static char *LWC1XS(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); uint64 ft_value = extract_ft_15_14_13_12_11(instruction); - std::string ft = FPR(ft_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *ft = FPR(ft_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("LWC1XS %s, %s(%s)", ft, rs, rt); } @@ -9296,15 +9197,15 @@ static std::string LWC1XS(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LWC2(uint64 instruction, Dis_info *info) +static char *LWC2(uint64 instruction, Dis_info *info) { uint64 ct_value = extract_ct_25_24_23_22_21(instruction); 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); - std::string ct = CPR(ct_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + char *ct = CPR(ct_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("LWC2 %s, %s(%s)", ct, s, rs); } @@ -9320,15 +9221,15 @@ static std::string LWC2(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LWE(uint64 instruction, Dis_info *info) +static char *LWE(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); int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("LWE %s, %s(%s)", rt, s, rs); } @@ -9344,17 +9245,17 @@ static std::string LWE(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LWM(uint64 instruction, Dis_info *info) +static char *LWM(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); 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); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); - std::string count3 = IMMEDIATE(encode_count3_from_count(count3_value)); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); + char *count3 = IMMEDIATE(encode_count3_from_count(count3_value)); return img_format("LWM %s, %s(%s), %s", rt, s, rs, count3); } @@ -9370,13 +9271,13 @@ static std::string LWM(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LWPC_48_(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string s = ADDRESS(s_value, 6, info); + const char *rt = GPR(rt_value); + char *s = ADDRESS(s_value, 6, info); return img_format("LWPC %s, %s", rt, s); } @@ -9392,13 +9293,13 @@ static std::string LWPC_48_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LWU_GP_(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string u = IMMEDIATE(u_value); + const char *rt = GPR(rt_value); + char *u = IMMEDIATE(u_value); return img_format("LWU %s, %s($%d)", rt, u, 28); } @@ -9414,15 +9315,15 @@ static std::string LWU_GP_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LWU_S9_(uint64 instruction, Dis_info *info) +static char *LWU_S9_(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); int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("LWU %s, %s(%s)", rt, s, rs); } @@ -9438,15 +9339,15 @@ static std::string LWU_S9_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LWU_U12_(uint64 instruction, Dis_info *info) +static char *LWU_U12_(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); uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string u = IMMEDIATE(u_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *u = IMMEDIATE(u_value); + const char *rs = GPR(rs_value); return img_format("LWU %s, %s(%s)", rt, u, rs); } @@ -9462,15 +9363,15 @@ static std::string LWU_U12_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LWUX(uint64 instruction, Dis_info *info) +static char *LWUX(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("LWUX %s, %s(%s)", rd, rs, rt); } @@ -9486,15 +9387,15 @@ static std::string LWUX(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LWUXS(uint64 instruction, Dis_info *info) +static char *LWUXS(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("LWUXS %s, %s(%s)", rd, rs, rt); } @@ -9510,15 +9411,15 @@ static std::string LWUXS(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LWX(uint64 instruction, Dis_info *info) +static char *LWX(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("LWX %s, %s(%s)", rd, rs, rt); } @@ -9534,15 +9435,15 @@ static std::string LWX(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LWXS_16_(uint64 instruction, Dis_info *info) +static char *LWXS_16_(uint64 instruction, Dis_info *info) { uint64 rt3_value = extract_rt3_9_8_7(instruction); uint64 rs3_value = extract_rs3_6_5_4(instruction); uint64 rd3_value = extract_rd3_3_2_1(instruction); - std::string rd3 = GPR(decode_gpr_gpr3(rd3_value)); - std::string rs3 = GPR(decode_gpr_gpr3(rs3_value)); - std::string rt3 = IMMEDIATE(decode_gpr_gpr3(rt3_value)); + const char *rd3 = GPR(decode_gpr_gpr3(rd3_value)); + const char *rs3 = GPR(decode_gpr_gpr3(rs3_value)); + char *rt3 = IMMEDIATE(decode_gpr_gpr3(rt3_value)); return img_format("LWXS %s, %s(%s)", rd3, rs3, rt3); } @@ -9558,15 +9459,15 @@ static std::string LWXS_16_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string LWXS_32_(uint64 instruction, Dis_info *info) +static char *LWXS_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("LWXS %s, %s(%s)", rd, rs, rt); } @@ -9583,15 +9484,15 @@ static std::string LWXS_32_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MADD_DSP_(uint64 instruction, Dis_info *info) +static char *MADD_DSP_(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); uint64 ac_value = extract_ac_15_14(instruction); - std::string ac = AC(ac_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *ac = AC(ac_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("MADD %s, %s, %s", ac, rs, rt); } @@ -9607,15 +9508,15 @@ static std::string MADD_DSP_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MADDF_D(uint64 instruction, Dis_info *info) +static char *MADDF_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("MADDF.D %s, %s, %s", fd, fs, ft); } @@ -9631,15 +9532,15 @@ static std::string MADDF_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MADDF_S(uint64 instruction, Dis_info *info) +static char *MADDF_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("MADDF.S %s, %s, %s", fd, fs, ft); } @@ -9656,15 +9557,15 @@ static std::string MADDF_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MADDU_DSP_(uint64 instruction, Dis_info *info) +static char *MADDU_DSP_(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); uint64 ac_value = extract_ac_15_14(instruction); - std::string ac = AC(ac_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *ac = AC(ac_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("MADDU %s, %s, %s", ac, rs, rt); } @@ -9681,15 +9582,15 @@ static std::string MADDU_DSP_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MAQ_S_W_PHL(uint64 instruction, Dis_info *info) +static char *MAQ_S_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); uint64 ac_value = extract_ac_15_14(instruction); - std::string ac = AC(ac_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *ac = AC(ac_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("MAQ_S.W.PHL %s, %s, %s", ac, rs, rt); } @@ -9706,15 +9607,15 @@ static std::string MAQ_S_W_PHL(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MAQ_S_W_PHR(uint64 instruction, Dis_info *info) +static char *MAQ_S_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); uint64 ac_value = extract_ac_15_14(instruction); - std::string ac = AC(ac_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *ac = AC(ac_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("MAQ_S.W.PHR %s, %s, %s", ac, rs, rt); } @@ -9731,15 +9632,15 @@ static std::string MAQ_S_W_PHR(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MAQ_SA_W_PHL(uint64 instruction, Dis_info *info) +static char *MAQ_SA_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); uint64 ac_value = extract_ac_15_14(instruction); - std::string ac = AC(ac_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *ac = AC(ac_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("MAQ_SA.W.PHL %s, %s, %s", ac, rs, rt); } @@ -9756,15 +9657,15 @@ static std::string MAQ_SA_W_PHL(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MAQ_SA_W_PHR(uint64 instruction, Dis_info *info) +static char *MAQ_SA_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); uint64 ac_value = extract_ac_15_14(instruction); - std::string ac = AC(ac_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *ac = AC(ac_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("MAQ_SA.W.PHR %s, %s, %s", ac, rs, rt); } @@ -9780,15 +9681,15 @@ static std::string MAQ_SA_W_PHR(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MAX_D(uint64 instruction, Dis_info *info) +static char *MAX_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("MAX.D %s, %s, %s", fd, fs, ft); } @@ -9804,15 +9705,15 @@ static std::string MAX_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MAX_S(uint64 instruction, Dis_info *info) +static char *MAX_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("MAX.S %s, %s, %s", fd, fs, ft); } @@ -9828,15 +9729,15 @@ static std::string MAX_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MAXA_D(uint64 instruction, Dis_info *info) +static char *MAXA_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("MAXA.D %s, %s, %s", fd, fs, ft); } @@ -9852,15 +9753,15 @@ static std::string MAXA_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MAXA_S(uint64 instruction, Dis_info *info) +static char *MAXA_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("MAXA.S %s, %s, %s", fd, fs, ft); } @@ -9876,15 +9777,15 @@ static std::string MAXA_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MFC0(uint64 instruction, Dis_info *info) +static char *MFC0(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); uint64 c0s_value = extract_c0s_20_19_18_17_16(instruction); uint64 sel_value = extract_sel_15_14_13_12_11(instruction); - std::string rt = GPR(rt_value); - std::string c0s = CPR(c0s_value); - std::string sel = IMMEDIATE(sel_value); + const char *rt = GPR(rt_value); + char *c0s = CPR(c0s_value); + char *sel = IMMEDIATE(sel_value); return img_format("MFC0 %s, %s, %s", rt, c0s, sel); } @@ -9900,13 +9801,13 @@ static std::string MFC0(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MFC1(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string fs = FPR(fs_value); + const char *rt = GPR(rt_value); + const char *fs = FPR(fs_value); return img_format("MFC1 %s, %s", rt, fs); } @@ -9922,13 +9823,13 @@ static std::string MFC1(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MFC2(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string cs = CPR(cs_value); + const char *rt = GPR(rt_value); + char *cs = CPR(cs_value); return img_format("MFC2 %s, %s", rt, cs); } @@ -9944,15 +9845,15 @@ static std::string MFC2(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MFGC0(uint64 instruction, Dis_info *info) +static char *MFGC0(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); uint64 c0s_value = extract_c0s_20_19_18_17_16(instruction); uint64 sel_value = extract_sel_15_14_13_12_11(instruction); - std::string rt = GPR(rt_value); - std::string c0s = CPR(c0s_value); - std::string sel = IMMEDIATE(sel_value); + const char *rt = GPR(rt_value); + char *c0s = CPR(c0s_value); + char *sel = IMMEDIATE(sel_value); return img_format("MFGC0 %s, %s, %s", rt, c0s, sel); } @@ -9968,15 +9869,15 @@ static std::string MFGC0(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MFHC0(uint64 instruction, Dis_info *info) +static char *MFHC0(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); uint64 c0s_value = extract_c0s_20_19_18_17_16(instruction); uint64 sel_value = extract_sel_15_14_13_12_11(instruction); - std::string rt = GPR(rt_value); - std::string c0s = CPR(c0s_value); - std::string sel = IMMEDIATE(sel_value); + const char *rt = GPR(rt_value); + char *c0s = CPR(c0s_value); + char *sel = IMMEDIATE(sel_value); return img_format("MFHC0 %s, %s, %s", rt, c0s, sel); } @@ -9992,13 +9893,13 @@ static std::string MFHC0(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MFHC1(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string fs = FPR(fs_value); + const char *rt = GPR(rt_value); + const char *fs = FPR(fs_value); return img_format("MFHC1 %s, %s", rt, fs); } @@ -10014,13 +9915,13 @@ static std::string MFHC1(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MFHC2(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string cs = CPR(cs_value); + const char *rt = GPR(rt_value); + char *cs = CPR(cs_value); return img_format("MFHC2 %s, %s", rt, cs); } @@ -10036,15 +9937,15 @@ static std::string MFHC2(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MFHGC0(uint64 instruction, Dis_info *info) +static char *MFHGC0(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); uint64 c0s_value = extract_c0s_20_19_18_17_16(instruction); uint64 sel_value = extract_sel_15_14_13_12_11(instruction); - std::string rt = GPR(rt_value); - std::string c0s = CPR(c0s_value); - std::string sel = IMMEDIATE(sel_value); + const char *rt = GPR(rt_value); + char *c0s = CPR(c0s_value); + char *sel = IMMEDIATE(sel_value); return img_format("MFHGC0 %s, %s, %s", rt, c0s, sel); } @@ -10059,13 +9960,13 @@ static std::string MFHGC0(uint64 instruction, Dis_info *info) * rt ----- * ac -- */ -static std::string MFHI_DSP_(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string ac = AC(ac_value); + const char *rt = GPR(rt_value); + const char *ac = AC(ac_value); return img_format("MFHI %s, %s", rt, ac); } @@ -10081,17 +9982,17 @@ static std::string MFHI_DSP_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MFHTR(uint64 instruction, Dis_info *info) +static char *MFHTR(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); uint64 c0s_value = extract_c0s_20_19_18_17_16(instruction); uint64 sel_value = extract_sel_15_14_13_12_11(instruction); uint64 u_value = extract_u_10(instruction); - std::string rt = GPR(rt_value); - std::string c0s = IMMEDIATE(c0s_value); - std::string u = IMMEDIATE(u_value); - std::string sel = IMMEDIATE(sel_value); + const char *rt = GPR(rt_value); + char *c0s = IMMEDIATE(c0s_value); + char *u = IMMEDIATE(u_value); + char *sel = IMMEDIATE(sel_value); return img_format("MFHTR %s, %s, %s, %s", rt, c0s, u, sel); } @@ -10106,13 +10007,13 @@ static std::string MFHTR(uint64 instruction, Dis_info *info) * rt ----- * ac -- */ -static std::string MFLO_DSP_(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string ac = AC(ac_value); + const char *rt = GPR(rt_value); + const char *ac = AC(ac_value); return img_format("MFLO %s, %s", rt, ac); } @@ -10128,17 +10029,17 @@ static std::string MFLO_DSP_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MFTR(uint64 instruction, Dis_info *info) +static char *MFTR(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); uint64 c0s_value = extract_c0s_20_19_18_17_16(instruction); uint64 sel_value = extract_sel_15_14_13_12_11(instruction); uint64 u_value = extract_u_10(instruction); - std::string rt = GPR(rt_value); - std::string c0s = IMMEDIATE(c0s_value); - std::string u = IMMEDIATE(u_value); - std::string sel = IMMEDIATE(sel_value); + const char *rt = GPR(rt_value); + char *c0s = IMMEDIATE(c0s_value); + char *u = IMMEDIATE(u_value); + char *sel = IMMEDIATE(sel_value); return img_format("MFTR %s, %s, %s, %s", rt, c0s, u, sel); } @@ -10154,15 +10055,15 @@ static std::string MFTR(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MIN_D(uint64 instruction, Dis_info *info) +static char *MIN_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("MIN.D %s, %s, %s", fd, fs, ft); } @@ -10178,15 +10079,15 @@ static std::string MIN_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MIN_S(uint64 instruction, Dis_info *info) +static char *MIN_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("MIN.S %s, %s, %s", fd, fs, ft); } @@ -10202,15 +10103,15 @@ static std::string MIN_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MINA_D(uint64 instruction, Dis_info *info) +static char *MINA_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("MINA.D %s, %s, %s", fd, fs, ft); } @@ -10226,15 +10127,15 @@ static std::string MINA_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MINA_S(uint64 instruction, Dis_info *info) +static char *MINA_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("MINA.S %s, %s, %s", fd, fs, ft); } @@ -10250,15 +10151,15 @@ static std::string MINA_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MOD(uint64 instruction, Dis_info *info) +static char *MOD(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("MOD %s, %s, %s", rd, rs, rt); } @@ -10274,15 +10175,15 @@ static std::string MOD(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MODSUB(uint64 instruction, Dis_info *info) +static char *MODSUB(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("MODSUB %s, %s, %s", rd, rs, rt); } @@ -10298,15 +10199,15 @@ static std::string MODSUB(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MODU(uint64 instruction, Dis_info *info) +static char *MODU(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("MODU %s, %s, %s", rd, rs, rt); } @@ -10322,13 +10223,13 @@ static std::string MODU(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MOV_D(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("MOV.D %s, %s", ft, fs); } @@ -10344,13 +10245,13 @@ static std::string MOV_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MOV_S(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("MOV.S %s, %s", ft, fs); } @@ -10366,15 +10267,15 @@ static std::string MOV_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MOVE_BALC(uint64 instruction, Dis_info *info) +static char *MOVE_BALC(uint64 instruction, Dis_info *info) { uint64 rtz4_value = extract_rtz4_27_26_25_23_22_21(instruction); uint64 rd1_value = extract_rdl_25_24(instruction); int64 s_value = extract_s__se21_0_20_to_1_s1(instruction); - std::string rd1 = GPR(decode_gpr_gpr1(rd1_value)); - std::string rtz4 = GPR(decode_gpr_gpr4_zero(rtz4_value)); - std::string s = ADDRESS(s_value, 4, info); + const char *rd1 = GPR(decode_gpr_gpr1(rd1_value)); + const char *rtz4 = GPR(decode_gpr_gpr4_zero(rtz4_value)); + char *s = ADDRESS(s_value, 4, info); return img_format("MOVE.BALC %s, %s, %s", rd1, rtz4, s); } @@ -10390,17 +10291,17 @@ static std::string MOVE_BALC(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MOVEP(uint64 instruction, Dis_info *info) +static char *MOVEP(uint64 instruction, Dis_info *info) { uint64 rtz4_value = extract_rtz4_9_7_6_5(instruction); uint64 rd2_value = extract_rd2_3_8(instruction); uint64 rsz4_value = extract_rsz4_4_2_1_0(instruction); - std::string rd2 = GPR(decode_gpr_gpr2_reg1(rd2_value)); - std::string re2 = GPR(decode_gpr_gpr2_reg2(rd2_value)); + const char *rd2 = GPR(decode_gpr_gpr2_reg1(rd2_value)); + const char *re2 = GPR(decode_gpr_gpr2_reg2(rd2_value)); /* !!!!!!!!!! - no conversion function */ - std::string rsz4 = GPR(decode_gpr_gpr4_zero(rsz4_value)); - std::string rtz4 = GPR(decode_gpr_gpr4_zero(rtz4_value)); + const char *rsz4 = GPR(decode_gpr_gpr4_zero(rsz4_value)); + const char *rtz4 = GPR(decode_gpr_gpr4_zero(rtz4_value)); return img_format("MOVEP %s, %s, %s, %s", rd2, re2, rsz4, rtz4); /* hand edited */ @@ -10417,16 +10318,16 @@ static std::string MOVEP(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MOVEP_REV_(uint64 instruction, Dis_info *info) +static char *MOVEP_REV_(uint64 instruction, Dis_info *info) { uint64 rt4_value = extract_rt4_9_7_6_5(instruction); uint64 rd2_value = extract_rd2_3_8(instruction); uint64 rs4_value = extract_rs4_4_2_1_0(instruction); - std::string rs4 = GPR(decode_gpr_gpr4(rs4_value)); - std::string rt4 = GPR(decode_gpr_gpr4(rt4_value)); - std::string rd2 = GPR(decode_gpr_gpr2_reg1(rd2_value)); - std::string rs2 = GPR(decode_gpr_gpr2_reg2(rd2_value)); + 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)); /* !!!!!!!!!! - no conversion function */ return img_format("MOVEP %s, %s, %s, %s", rs4, rt4, rd2, rs2); @@ -10444,13 +10345,13 @@ static std::string MOVEP_REV_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MOVE(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("MOVE %s, %s", rt, rs); } @@ -10466,15 +10367,15 @@ static std::string MOVE(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MOVN(uint64 instruction, Dis_info *info) +static char *MOVN(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("MOVN %s, %s, %s", rd, rs, rt); } @@ -10490,15 +10391,15 @@ static std::string MOVN(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MOVZ(uint64 instruction, Dis_info *info) +static char *MOVZ(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("MOVZ %s, %s, %s", rd, rs, rt); } @@ -10514,15 +10415,15 @@ static std::string MOVZ(uint64 instruction, Dis_info *info) * rs ----- * ac -- */ -static std::string MSUB_DSP_(uint64 instruction, Dis_info *info) +static char *MSUB_DSP_(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); uint64 ac_value = extract_ac_15_14(instruction); - std::string ac = AC(ac_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *ac = AC(ac_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("MSUB %s, %s, %s", ac, rs, rt); } @@ -10538,15 +10439,15 @@ static std::string MSUB_DSP_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MSUBF_D(uint64 instruction, Dis_info *info) +static char *MSUBF_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("MSUBF.D %s, %s, %s", fd, fs, ft); } @@ -10562,15 +10463,15 @@ static std::string MSUBF_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MSUBF_S(uint64 instruction, Dis_info *info) +static char *MSUBF_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("MSUBF.S %s, %s, %s", fd, fs, ft); } @@ -10586,15 +10487,15 @@ static std::string MSUBF_S(uint64 instruction, Dis_info *info) * rs ----- * ac -- */ -static std::string MSUBU_DSP_(uint64 instruction, Dis_info *info) +static char *MSUBU_DSP_(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); uint64 ac_value = extract_ac_15_14(instruction); - std::string ac = AC(ac_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *ac = AC(ac_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("MSUBU %s, %s, %s", ac, rs, rt); } @@ -10610,15 +10511,15 @@ static std::string MSUBU_DSP_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MTC0(uint64 instruction, Dis_info *info) +static char *MTC0(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); uint64 c0s_value = extract_c0s_20_19_18_17_16(instruction); uint64 sel_value = extract_sel_15_14_13_12_11(instruction); - std::string rt = GPR(rt_value); - std::string c0s = CPR(c0s_value); - std::string sel = IMMEDIATE(sel_value); + const char *rt = GPR(rt_value); + char *c0s = CPR(c0s_value); + char *sel = IMMEDIATE(sel_value); return img_format("MTC0 %s, %s, %s", rt, c0s, sel); } @@ -10634,13 +10535,13 @@ static std::string MTC0(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MTC1(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string fs = FPR(fs_value); + const char *rt = GPR(rt_value); + const char *fs = FPR(fs_value); return img_format("MTC1 %s, %s", rt, fs); } @@ -10656,13 +10557,13 @@ static std::string MTC1(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MTC2(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string cs = CPR(cs_value); + const char *rt = GPR(rt_value); + char *cs = CPR(cs_value); return img_format("MTC2 %s, %s", rt, cs); } @@ -10678,15 +10579,15 @@ static std::string MTC2(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MTGC0(uint64 instruction, Dis_info *info) +static char *MTGC0(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); uint64 c0s_value = extract_c0s_20_19_18_17_16(instruction); uint64 sel_value = extract_sel_15_14_13_12_11(instruction); - std::string rt = GPR(rt_value); - std::string c0s = CPR(c0s_value); - std::string sel = IMMEDIATE(sel_value); + const char *rt = GPR(rt_value); + char *c0s = CPR(c0s_value); + char *sel = IMMEDIATE(sel_value); return img_format("MTGC0 %s, %s, %s", rt, c0s, sel); } @@ -10702,15 +10603,15 @@ static std::string MTGC0(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MTHC0(uint64 instruction, Dis_info *info) +static char *MTHC0(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); uint64 c0s_value = extract_c0s_20_19_18_17_16(instruction); uint64 sel_value = extract_sel_15_14_13_12_11(instruction); - std::string rt = GPR(rt_value); - std::string c0s = CPR(c0s_value); - std::string sel = IMMEDIATE(sel_value); + const char *rt = GPR(rt_value); + char *c0s = CPR(c0s_value); + char *sel = IMMEDIATE(sel_value); return img_format("MTHC0 %s, %s, %s", rt, c0s, sel); } @@ -10726,13 +10627,13 @@ static std::string MTHC0(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MTHC1(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string fs = FPR(fs_value); + const char *rt = GPR(rt_value); + const char *fs = FPR(fs_value); return img_format("MTHC1 %s, %s", rt, fs); } @@ -10748,13 +10649,13 @@ static std::string MTHC1(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MTHC2(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string cs = CPR(cs_value); + const char *rt = GPR(rt_value); + char *cs = CPR(cs_value); return img_format("MTHC2 %s, %s", rt, cs); } @@ -10770,15 +10671,15 @@ static std::string MTHC2(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MTHGC0(uint64 instruction, Dis_info *info) +static char *MTHGC0(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); uint64 c0s_value = extract_c0s_20_19_18_17_16(instruction); uint64 sel_value = extract_sel_15_14_13_12_11(instruction); - std::string rt = GPR(rt_value); - std::string c0s = CPR(c0s_value); - std::string sel = IMMEDIATE(sel_value); + const char *rt = GPR(rt_value); + char *c0s = CPR(c0s_value); + char *sel = IMMEDIATE(sel_value); return img_format("MTHGC0 %s, %s, %s", rt, c0s, sel); } @@ -10793,13 +10694,13 @@ static std::string MTHGC0(uint64 instruction, Dis_info *info) * rs ----- * ac -- */ -static std::string MTHI_DSP_(uint64 instruction, Dis_info *info) +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); - std::string rs = GPR(rs_value); - std::string ac = AC(ac_value); + const char *rs = GPR(rs_value); + const char *ac = AC(ac_value); return img_format("MTHI %s, %s", rs, ac); } @@ -10814,13 +10715,13 @@ static std::string MTHI_DSP_(uint64 instruction, Dis_info *info) * rs ----- * ac -- */ -static std::string MTHLIP(uint64 instruction, Dis_info *info) +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); - std::string rs = GPR(rs_value); - std::string ac = AC(ac_value); + const char *rs = GPR(rs_value); + const char *ac = AC(ac_value); return img_format("MTHLIP %s, %s", rs, ac); } @@ -10836,17 +10737,17 @@ static std::string MTHLIP(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MTHTR(uint64 instruction, Dis_info *info) +static char *MTHTR(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); uint64 c0s_value = extract_c0s_20_19_18_17_16(instruction); uint64 sel_value = extract_sel_15_14_13_12_11(instruction); uint64 u_value = extract_u_10(instruction); - std::string rt = GPR(rt_value); - std::string c0s = IMMEDIATE(c0s_value); - std::string u = IMMEDIATE(u_value); - std::string sel = IMMEDIATE(sel_value); + const char *rt = GPR(rt_value); + char *c0s = IMMEDIATE(c0s_value); + char *u = IMMEDIATE(u_value); + char *sel = IMMEDIATE(sel_value); return img_format("MTHTR %s, %s, %s, %s", rt, c0s, u, sel); } @@ -10861,13 +10762,13 @@ static std::string MTHTR(uint64 instruction, Dis_info *info) * rs ----- * ac -- */ -static std::string MTLO_DSP_(uint64 instruction, Dis_info *info) +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); - std::string rs = GPR(rs_value); - std::string ac = AC(ac_value); + const char *rs = GPR(rs_value); + const char *ac = AC(ac_value); return img_format("MTLO %s, %s", rs, ac); } @@ -10883,17 +10784,17 @@ static std::string MTLO_DSP_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MTTR(uint64 instruction, Dis_info *info) +static char *MTTR(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); uint64 c0s_value = extract_c0s_20_19_18_17_16(instruction); uint64 sel_value = extract_sel_15_14_13_12_11(instruction); uint64 u_value = extract_u_10(instruction); - std::string rt = GPR(rt_value); - std::string c0s = IMMEDIATE(c0s_value); - std::string u = IMMEDIATE(u_value); - std::string sel = IMMEDIATE(sel_value); + const char *rt = GPR(rt_value); + char *c0s = IMMEDIATE(c0s_value); + char *u = IMMEDIATE(u_value); + char *sel = IMMEDIATE(sel_value); return img_format("MTTR %s, %s, %s, %s", rt, c0s, u, sel); } @@ -10909,15 +10810,15 @@ static std::string MTTR(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MUH(uint64 instruction, Dis_info *info) +static char *MUH(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("MUH %s, %s, %s", rd, rs, rt); } @@ -10933,15 +10834,15 @@ static std::string MUH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MUHU(uint64 instruction, Dis_info *info) +static char *MUHU(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("MUHU %s, %s, %s", rd, rs, rt); } @@ -10957,15 +10858,15 @@ static std::string MUHU(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MUL_32_(uint64 instruction, Dis_info *info) +static char *MUL_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("MUL %s, %s, %s", rd, rs, rt); } @@ -10981,13 +10882,13 @@ static std::string MUL_32_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MUL_4X4_(uint64 instruction, Dis_info *info) +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); - std::string rs4 = GPR(decode_gpr_gpr4(rs4_value)); - std::string 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)); return img_format("MUL %s, %s", rs4, rt4); } @@ -11003,15 +10904,15 @@ static std::string MUL_4X4_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MUL_D(uint64 instruction, Dis_info *info) +static char *MUL_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("MUL.D %s, %s, %s", fd, fs, ft); } @@ -11028,15 +10929,15 @@ static std::string MUL_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MUL_PH(uint64 instruction, Dis_info *info) +static char *MUL_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("MUL.PH %s, %s, %s", rd, rs, rt); } @@ -11053,15 +10954,15 @@ static std::string MUL_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MUL_S_PH(uint64 instruction, Dis_info *info) +static char *MUL_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("MUL_S.PH %s, %s, %s", rd, rs, rt); } @@ -11077,15 +10978,15 @@ static std::string MUL_S_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MUL_S(uint64 instruction, Dis_info *info) +static char *MUL_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("MUL.S %s, %s, %s", fd, fs, ft); } @@ -11102,15 +11003,15 @@ static std::string MUL_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MULEQ_S_W_PHL(uint64 instruction, Dis_info *info) +static char *MULEQ_S_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("MULEQ_S.W.PHL %s, %s, %s", rd, rs, rt); } @@ -11127,15 +11028,15 @@ static std::string MULEQ_S_W_PHL(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MULEQ_S_W_PHR(uint64 instruction, Dis_info *info) +static char *MULEQ_S_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("MULEQ_S.W.PHR %s, %s, %s", rd, rs, rt); } @@ -11152,15 +11053,15 @@ static std::string MULEQ_S_W_PHR(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MULEU_S_PH_QBL(uint64 instruction, Dis_info *info) +static char *MULEU_S_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("MULEU_S.PH.QBL %s, %s, %s", rd, rs, rt); } @@ -11177,15 +11078,15 @@ static std::string MULEU_S_PH_QBL(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MULEU_S_PH_QBR(uint64 instruction, Dis_info *info) +static char *MULEU_S_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("MULEU_S.PH.QBR %s, %s, %s", rd, rs, rt); } @@ -11202,15 +11103,15 @@ static std::string MULEU_S_PH_QBR(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MULQ_RS_PH(uint64 instruction, Dis_info *info) +static char *MULQ_RS_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("MULQ_RS.PH %s, %s, %s", rd, rs, rt); } @@ -11227,15 +11128,15 @@ static std::string MULQ_RS_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MULQ_RS_W(uint64 instruction, Dis_info *info) +static char *MULQ_RS_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("MULQ_RS.W %s, %s, %s", rd, rs, rt); } @@ -11252,15 +11153,15 @@ static std::string MULQ_RS_W(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MULQ_S_PH(uint64 instruction, Dis_info *info) +static char *MULQ_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("MULQ_S.PH %s, %s, %s", rd, rs, rt); } @@ -11277,15 +11178,15 @@ static std::string MULQ_S_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MULQ_S_W(uint64 instruction, Dis_info *info) +static char *MULQ_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("MULQ_S.W %s, %s, %s", rd, rs, rt); } @@ -11302,15 +11203,15 @@ static std::string MULQ_S_W(uint64 instruction, Dis_info *info) * rs ----- * ac -- */ -static std::string MULSA_W_PH(uint64 instruction, Dis_info *info) +static char *MULSA_W_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); uint64 ac_value = extract_ac_15_14(instruction); - std::string ac = AC(ac_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *ac = AC(ac_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("MULSA.W.PH %s, %s, %s", ac, rs, rt); } @@ -11327,15 +11228,15 @@ static std::string MULSA_W_PH(uint64 instruction, Dis_info *info) * rs ----- * ac -- */ -static std::string MULSAQ_S_W_PH(uint64 instruction, Dis_info *info) +static char *MULSAQ_S_W_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); uint64 ac_value = extract_ac_15_14(instruction); - std::string ac = AC(ac_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *ac = AC(ac_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("MULSAQ_S.W.PH %s, %s, %s", ac, rs, rt); } @@ -11351,15 +11252,15 @@ static std::string MULSAQ_S_W_PH(uint64 instruction, Dis_info *info) * rs ----- * ac -- */ -static std::string MULT_DSP_(uint64 instruction, Dis_info *info) +static char *MULT_DSP_(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); uint64 ac_value = extract_ac_15_14(instruction); - std::string ac = AC(ac_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *ac = AC(ac_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("MULT %s, %s, %s", ac, rs, rt); } @@ -11375,15 +11276,15 @@ static std::string MULT_DSP_(uint64 instruction, Dis_info *info) * rs ----- * ac -- */ -static std::string MULTU_DSP_(uint64 instruction, Dis_info *info) +static char *MULTU_DSP_(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); uint64 ac_value = extract_ac_15_14(instruction); - std::string ac = AC(ac_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *ac = AC(ac_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("MULTU %s, %s, %s", ac, rs, rt); } @@ -11399,15 +11300,15 @@ static std::string MULTU_DSP_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string MULU(uint64 instruction, Dis_info *info) +static char *MULU(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("MULU %s, %s, %s", rd, rs, rt); } @@ -11423,13 +11324,13 @@ static std::string MULU(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string NEG_D(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("NEG.D %s, %s", ft, fs); } @@ -11445,13 +11346,13 @@ static std::string NEG_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string NEG_S(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("NEG.S %s, %s", ft, fs); } @@ -11467,11 +11368,11 @@ static std::string NEG_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string NOP_16_(uint64 instruction, Dis_info *info) +static char *NOP_16_(uint64 instruction, Dis_info *info) { (void)instruction; - return "NOP "; + return g_strdup("NOP "); } @@ -11485,11 +11386,11 @@ static std::string NOP_16_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string NOP_32_(uint64 instruction, Dis_info *info) +static char *NOP_32_(uint64 instruction, Dis_info *info) { (void)instruction; - return "NOP "; + return g_strdup("NOP "); } @@ -11503,15 +11404,15 @@ static std::string NOP_32_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string NOR(uint64 instruction, Dis_info *info) +static char *NOR(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("NOR %s, %s, %s", rd, rs, rt); } @@ -11527,13 +11428,13 @@ static std::string NOR(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string NOT_16_(uint64 instruction, Dis_info *info) +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); - std::string rt3 = GPR(decode_gpr_gpr3(rt3_value)); - std::string 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)); return img_format("NOT %s, %s", rt3, rs3); } @@ -11549,13 +11450,13 @@ static std::string NOT_16_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string OR_16_(uint64 instruction, Dis_info *info) +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); - std::string rs3 = GPR(decode_gpr_gpr3(rs3_value)); - std::string 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)); return img_format("OR %s, %s", rs3, rt3); } @@ -11571,15 +11472,15 @@ static std::string OR_16_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string OR_32_(uint64 instruction, Dis_info *info) +static char *OR_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("OR %s, %s, %s", rd, rs, rt); } @@ -11595,15 +11496,15 @@ static std::string OR_32_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string ORI(uint64 instruction, Dis_info *info) +static char *ORI(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); uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string u = IMMEDIATE(u_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *u = IMMEDIATE(u_value); return img_format("ORI %s, %s, %s", rt, rs, u); } @@ -11620,15 +11521,15 @@ static std::string ORI(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string PACKRL_PH(uint64 instruction, Dis_info *info) +static char *PACKRL_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("PACKRL.PH %s, %s, %s", rd, rs, rt); } @@ -11644,11 +11545,11 @@ static std::string PACKRL_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string PAUSE(uint64 instruction, Dis_info *info) +static char *PAUSE(uint64 instruction, Dis_info *info) { (void)instruction; - return "PAUSE "; + return g_strdup("PAUSE "); } @@ -11663,15 +11564,15 @@ static std::string PAUSE(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string PICK_PH(uint64 instruction, Dis_info *info) +static char *PICK_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("PICK.PH %s, %s, %s", rd, rs, rt); } @@ -11688,15 +11589,15 @@ static std::string PICK_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string PICK_QB(uint64 instruction, Dis_info *info) +static char *PICK_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("PICK.QB %s, %s, %s", rd, rs, rt); } @@ -11713,13 +11614,13 @@ static std::string PICK_QB(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string PRECEQ_W_PHL(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("PRECEQ.W.PHL %s, %s", rt, rs); } @@ -11736,13 +11637,13 @@ static std::string PRECEQ_W_PHL(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string PRECEQ_W_PHR(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("PRECEQ.W.PHR %s, %s", rt, rs); } @@ -11759,13 +11660,13 @@ static std::string PRECEQ_W_PHR(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string PRECEQU_PH_QBLA(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("PRECEQU.PH.QBLA %s, %s", rt, rs); } @@ -11782,13 +11683,13 @@ static std::string PRECEQU_PH_QBLA(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string PRECEQU_PH_QBL(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("PRECEQU.PH.QBL %s, %s", rt, rs); } @@ -11805,13 +11706,13 @@ static std::string PRECEQU_PH_QBL(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string PRECEQU_PH_QBRA(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("PRECEQU.PH.QBRA %s, %s", rt, rs); } @@ -11828,13 +11729,13 @@ static std::string PRECEQU_PH_QBRA(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string PRECEQU_PH_QBR(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("PRECEQU.PH.QBR %s, %s", rt, rs); } @@ -11852,13 +11753,13 @@ static std::string PRECEQU_PH_QBR(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string PRECEU_PH_QBLA(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("PRECEU.PH.QBLA %s, %s", rt, rs); } @@ -11875,13 +11776,13 @@ static std::string PRECEU_PH_QBLA(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string PRECEU_PH_QBL(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("PRECEU.PH.QBL %s, %s", rt, rs); } @@ -11899,13 +11800,13 @@ static std::string PRECEU_PH_QBL(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string PRECEU_PH_QBRA(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("PRECEU.PH.QBRA %s, %s", rt, rs); } @@ -11922,13 +11823,13 @@ static std::string PRECEU_PH_QBRA(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string PRECEU_PH_QBR(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("PRECEU.PH.QBR %s, %s", rt, rs); } @@ -11945,15 +11846,15 @@ static std::string PRECEU_PH_QBR(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string PRECR_QB_PH(uint64 instruction, Dis_info *info) +static char *PRECR_QB_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("PRECR.QB.PH %s, %s, %s", rd, rs, rt); } @@ -11970,15 +11871,15 @@ static std::string PRECR_QB_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string PRECR_SRA_PH_W(uint64 instruction, Dis_info *info) +static char *PRECR_SRA_PH_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); uint64 sa_value = extract_sa_15_14_13_12_11(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string sa = IMMEDIATE(sa_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *sa = IMMEDIATE(sa_value); return img_format("PRECR_SRA.PH.W %s, %s, %s", rt, rs, sa); } @@ -11995,15 +11896,15 @@ static std::string PRECR_SRA_PH_W(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string PRECR_SRA_R_PH_W(uint64 instruction, Dis_info *info) +static char *PRECR_SRA_R_PH_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); uint64 sa_value = extract_sa_15_14_13_12_11(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string sa = IMMEDIATE(sa_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *sa = IMMEDIATE(sa_value); return img_format("PRECR_SRA_R.PH.W %s, %s, %s", rt, rs, sa); } @@ -12020,15 +11921,15 @@ static std::string PRECR_SRA_R_PH_W(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string PRECRQ_PH_W(uint64 instruction, Dis_info *info) +static char *PRECRQ_PH_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("PRECRQ.PH.W %s, %s, %s", rd, rs, rt); } @@ -12045,15 +11946,15 @@ static std::string PRECRQ_PH_W(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string PRECRQ_QB_PH(uint64 instruction, Dis_info *info) +static char *PRECRQ_QB_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("PRECRQ.QB.PH %s, %s, %s", rd, rs, rt); } @@ -12070,15 +11971,15 @@ static std::string PRECRQ_QB_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string PRECRQ_RS_PH_W(uint64 instruction, Dis_info *info) +static char *PRECRQ_RS_PH_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("PRECRQ_RS.PH.W %s, %s, %s", rd, rs, rt); } @@ -12095,15 +11996,15 @@ static std::string PRECRQ_RS_PH_W(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string PRECRQU_S_QB_PH(uint64 instruction, Dis_info *info) +static char *PRECRQU_S_QB_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("PRECRQU_S.QB.PH %s, %s, %s", rd, rs, rt); } @@ -12119,15 +12020,15 @@ static std::string PRECRQU_S_QB_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string PREF_S9_(uint64 instruction, Dis_info *info) +static char *PREF_S9_(uint64 instruction, Dis_info *info) { uint64 hint_value = extract_hint_25_24_23_22_21(instruction); 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); - std::string hint = IMMEDIATE(hint_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + char *hint = IMMEDIATE(hint_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("PREF %s, %s(%s)", hint, s, rs); } @@ -12143,15 +12044,15 @@ static std::string PREF_S9_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string PREF_U12_(uint64 instruction, Dis_info *info) +static char *PREF_U12_(uint64 instruction, Dis_info *info) { uint64 hint_value = extract_hint_25_24_23_22_21(instruction); 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); - std::string hint = IMMEDIATE(hint_value); - std::string u = IMMEDIATE(u_value); - std::string rs = GPR(rs_value); + char *hint = IMMEDIATE(hint_value); + char *u = IMMEDIATE(u_value); + const char *rs = GPR(rs_value); return img_format("PREF %s, %s(%s)", hint, u, rs); } @@ -12167,15 +12068,15 @@ static std::string PREF_U12_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string PREFE(uint64 instruction, Dis_info *info) +static char *PREFE(uint64 instruction, Dis_info *info) { uint64 hint_value = extract_hint_25_24_23_22_21(instruction); 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); - std::string hint = IMMEDIATE(hint_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + char *hint = IMMEDIATE(hint_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("PREFE %s, %s(%s)", hint, s, rs); } @@ -12191,15 +12092,15 @@ static std::string PREFE(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string PREPEND(uint64 instruction, Dis_info *info) +static char *PREPEND(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); uint64 sa_value = extract_sa_15_14_13_12_11(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string sa = IMMEDIATE(sa_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *sa = IMMEDIATE(sa_value); return img_format("PREPEND %s, %s, %s", rt, rs, sa); } @@ -12214,13 +12115,13 @@ static std::string PREPEND(uint64 instruction, Dis_info *info) * rt ----- * rs ----- */ -static std::string RADDU_W_QB(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("RADDU.W.QB %s, %s", rt, rs); } @@ -12235,13 +12136,13 @@ static std::string RADDU_W_QB(uint64 instruction, Dis_info *info) * rt ----- * mask ------- */ -static std::string RDDSP(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string mask = IMMEDIATE(mask_value); + const char *rt = GPR(rt_value); + char *mask = IMMEDIATE(mask_value); return img_format("RDDSP %s, %s", rt, mask); } @@ -12257,15 +12158,15 @@ static std::string RDDSP(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string RDHWR(uint64 instruction, Dis_info *info) +static char *RDHWR(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); uint64 hs_value = extract_hs_20_19_18_17_16(instruction); uint64 sel_value = extract_sel_13_12_11(instruction); - std::string rt = GPR(rt_value); - std::string hs = CPR(hs_value); - std::string sel = IMMEDIATE(sel_value); + const char *rt = GPR(rt_value); + char *hs = CPR(hs_value); + char *sel = IMMEDIATE(sel_value); return img_format("RDHWR %s, %s, %s", rt, hs, sel); } @@ -12281,13 +12182,13 @@ static std::string RDHWR(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string RDPGPR(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("RDPGPR %s, %s", rt, rs); } @@ -12303,13 +12204,13 @@ static std::string RDPGPR(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string RECIP_D(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("RECIP.D %s, %s", ft, fs); } @@ -12325,13 +12226,13 @@ static std::string RECIP_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string RECIP_S(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("RECIP.S %s, %s", ft, fs); } @@ -12347,13 +12248,13 @@ static std::string RECIP_S(uint64 instruction, Dis_info *info) * rt ----- * s ---------- */ -static std::string REPL_PH(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); return img_format("REPL.PH %s, %s", rt, s); } @@ -12369,13 +12270,13 @@ static std::string REPL_PH(uint64 instruction, Dis_info *info) * rt ----- * u -------- */ -static std::string REPL_QB(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string u = IMMEDIATE(u_value); + const char *rt = GPR(rt_value); + char *u = IMMEDIATE(u_value); return img_format("REPL.QB %s, %s", rt, u); } @@ -12391,13 +12292,13 @@ static std::string REPL_QB(uint64 instruction, Dis_info *info) * rt ----- * rs ----- */ -static std::string REPLV_PH(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("REPLV.PH %s, %s", rt, rs); } @@ -12412,13 +12313,13 @@ static std::string REPLV_PH(uint64 instruction, Dis_info *info) * rt ----- * rs ----- */ -static std::string REPLV_QB(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("REPLV.QB %s, %s", rt, rs); } @@ -12434,14 +12335,14 @@ static std::string REPLV_QB(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string RESTORE_32_(uint64 instruction, Dis_info *info) +static char *RESTORE_32_(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); uint64 count_value = extract_count_19_18_17_16(instruction); uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3__s3(instruction); uint64 gp_value = extract_gp_2(instruction); - std::string u = IMMEDIATE(u_value); + char *u = IMMEDIATE(u_value); return img_format("RESTORE %s%s", u, save_restore_list(rt_value, count_value, gp_value)); } @@ -12457,13 +12358,13 @@ static std::string RESTORE_32_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string RESTORE_JRC_16_(uint64 instruction, Dis_info *info) +static char *RESTORE_JRC_16_(uint64 instruction, Dis_info *info) { uint64 rt1_value = extract_rtl_11(instruction); uint64 u_value = extract_u_7_6_5_4__s4(instruction); uint64 count_value = extract_count_3_2_1_0(instruction); - std::string u = IMMEDIATE(u_value); + char *u = IMMEDIATE(u_value); return img_format("RESTORE.JRC %s%s", u, save_restore_list(encode_rt1_from_rt(rt1_value), count_value, 0)); } @@ -12479,14 +12380,14 @@ static std::string RESTORE_JRC_16_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string RESTORE_JRC_32_(uint64 instruction, Dis_info *info) +static char *RESTORE_JRC_32_(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); uint64 count_value = extract_count_19_18_17_16(instruction); uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3__s3(instruction); uint64 gp_value = extract_gp_2(instruction); - std::string u = IMMEDIATE(u_value); + char *u = IMMEDIATE(u_value); return img_format("RESTORE.JRC %s%s", u, save_restore_list(rt_value, count_value, gp_value)); } @@ -12502,13 +12403,13 @@ static std::string RESTORE_JRC_32_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string RESTOREF(uint64 instruction, Dis_info *info) +static char *RESTOREF(uint64 instruction, Dis_info *info) { uint64 count_value = extract_count_19_18_17_16(instruction); uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3__s3(instruction); - std::string u = IMMEDIATE(u_value); - std::string count = IMMEDIATE(count_value); + char *u = IMMEDIATE(u_value); + char *count = IMMEDIATE(count_value); return img_format("RESTOREF %s, %s", u, count); } @@ -12524,13 +12425,13 @@ static std::string RESTOREF(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string RINT_D(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("RINT.D %s, %s", ft, fs); } @@ -12546,13 +12447,13 @@ static std::string RINT_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string RINT_S(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("RINT.S %s, %s", ft, fs); } @@ -12568,15 +12469,15 @@ static std::string RINT_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string ROTR(uint64 instruction, Dis_info *info) +static char *ROTR(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); uint64 shift_value = extract_shift_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string shift = IMMEDIATE(shift_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *shift = IMMEDIATE(shift_value); return img_format("ROTR %s, %s, %s", rt, rs, shift); } @@ -12592,15 +12493,15 @@ static std::string ROTR(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string ROTRV(uint64 instruction, Dis_info *info) +static char *ROTRV(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("ROTRV %s, %s, %s", rd, rs, rt); } @@ -12616,7 +12517,7 @@ static std::string ROTRV(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string ROTX(uint64 instruction, Dis_info *info) +static char *ROTX(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); @@ -12624,11 +12525,11 @@ static std::string ROTX(uint64 instruction, Dis_info *info) uint64 stripe_value = extract_stripe_6(instruction); uint64 shift_value = extract_shift_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string shift = IMMEDIATE(shift_value); - std::string shiftx = IMMEDIATE(shiftx_value); - std::string stripe = IMMEDIATE(stripe_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *shift = IMMEDIATE(shift_value); + char *shiftx = IMMEDIATE(shiftx_value); + char *stripe = IMMEDIATE(stripe_value); return img_format("ROTX %s, %s, %s, %s, %s", rt, rs, shift, shiftx, stripe); @@ -12645,13 +12546,13 @@ static std::string ROTX(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string ROUND_L_D(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("ROUND.L.D %s, %s", ft, fs); } @@ -12667,13 +12568,13 @@ static std::string ROUND_L_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string ROUND_L_S(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("ROUND.L.S %s, %s", ft, fs); } @@ -12689,13 +12590,13 @@ static std::string ROUND_L_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string ROUND_W_D(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("ROUND.W.D %s, %s", ft, fs); } @@ -12711,13 +12612,13 @@ static std::string ROUND_W_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string ROUND_W_S(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("ROUND.W.S %s, %s", ft, fs); } @@ -12733,13 +12634,13 @@ static std::string ROUND_W_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string RSQRT_D(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("RSQRT.D %s, %s", ft, fs); } @@ -12755,13 +12656,13 @@ static std::string RSQRT_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string RSQRT_S(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("RSQRT.S %s, %s", ft, fs); } @@ -12777,13 +12678,13 @@ static std::string RSQRT_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SAVE_16_(uint64 instruction, Dis_info *info) +static char *SAVE_16_(uint64 instruction, Dis_info *info) { uint64 rt1_value = extract_rtl_11(instruction); uint64 u_value = extract_u_7_6_5_4__s4(instruction); uint64 count_value = extract_count_3_2_1_0(instruction); - std::string u = IMMEDIATE(u_value); + char *u = IMMEDIATE(u_value); return img_format("SAVE %s%s", u, save_restore_list(encode_rt1_from_rt(rt1_value), count_value, 0)); } @@ -12799,14 +12700,14 @@ static std::string SAVE_16_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SAVE_32_(uint64 instruction, Dis_info *info) +static char *SAVE_32_(uint64 instruction, Dis_info *info) { uint64 count_value = extract_count_19_18_17_16(instruction); uint64 rt_value = extract_rt_25_24_23_22_21(instruction); uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3__s3(instruction); uint64 gp_value = extract_gp_2(instruction); - std::string u = IMMEDIATE(u_value); + char *u = IMMEDIATE(u_value); return img_format("SAVE %s%s", u, save_restore_list(rt_value, count_value, gp_value)); } @@ -12822,13 +12723,13 @@ static std::string SAVE_32_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SAVEF(uint64 instruction, Dis_info *info) +static char *SAVEF(uint64 instruction, Dis_info *info) { uint64 count_value = extract_count_19_18_17_16(instruction); uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3__s3(instruction); - std::string u = IMMEDIATE(u_value); - std::string count = IMMEDIATE(count_value); + char *u = IMMEDIATE(u_value); + char *count = IMMEDIATE(count_value); return img_format("SAVEF %s, %s", u, count); } @@ -12844,15 +12745,15 @@ static std::string SAVEF(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SB_16_(uint64 instruction, Dis_info *info) +static char *SB_16_(uint64 instruction, Dis_info *info) { uint64 rtz3_value = extract_rtz3_9_8_7(instruction); uint64 rs3_value = extract_rs3_6_5_4(instruction); uint64 u_value = extract_u_1_0(instruction); - std::string rtz3 = GPR(decode_gpr_gpr3_src_store(rtz3_value)); - std::string u = IMMEDIATE(u_value); - std::string rs3 = GPR(decode_gpr_gpr3(rs3_value)); + const char *rtz3 = GPR(decode_gpr_gpr3_src_store(rtz3_value)); + char *u = IMMEDIATE(u_value); + const char *rs3 = GPR(decode_gpr_gpr3(rs3_value)); return img_format("SB %s, %s(%s)", rtz3, u, rs3); } @@ -12868,13 +12769,13 @@ static std::string SB_16_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SB_GP_(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string u = IMMEDIATE(u_value); + const char *rt = GPR(rt_value); + char *u = IMMEDIATE(u_value); return img_format("SB %s, %s($%d)", rt, u, 28); } @@ -12890,15 +12791,15 @@ static std::string SB_GP_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SB_S9_(uint64 instruction, Dis_info *info) +static char *SB_S9_(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); int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("SB %s, %s(%s)", rt, s, rs); } @@ -12914,15 +12815,15 @@ static std::string SB_S9_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SB_U12_(uint64 instruction, Dis_info *info) +static char *SB_U12_(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); uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string u = IMMEDIATE(u_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *u = IMMEDIATE(u_value); + const char *rs = GPR(rs_value); return img_format("SB %s, %s(%s)", rt, u, rs); } @@ -12938,15 +12839,15 @@ static std::string SB_U12_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SBE(uint64 instruction, Dis_info *info) +static char *SBE(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); int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("SBE %s, %s(%s)", rt, s, rs); } @@ -12962,15 +12863,15 @@ static std::string SBE(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SBX(uint64 instruction, Dis_info *info) +static char *SBX(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("SBX %s, %s(%s)", rd, rs, rt); } @@ -12986,15 +12887,15 @@ static std::string SBX(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SC(uint64 instruction, Dis_info *info) +static char *SC(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); int64 s_value = extract_s__se8_15_7_6_5_4_3_2_s2(instruction); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("SC %s, %s(%s)", rt, s, rs); } @@ -13010,15 +12911,15 @@ static std::string SC(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SCD(uint64 instruction, Dis_info *info) +static char *SCD(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); int64 s_value = extract_s__se8_15_7_6_5_4_3_s3(instruction); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("SCD %s, %s(%s)", rt, s, rs); } @@ -13034,15 +12935,15 @@ static std::string SCD(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SCDP(uint64 instruction, Dis_info *info) +static char *SCDP(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); uint64 ru_value = extract_ru_7_6_5_4_3(instruction); - std::string rt = GPR(rt_value); - std::string ru = GPR(ru_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *ru = GPR(ru_value); + const char *rs = GPR(rs_value); return img_format("SCDP %s, %s, (%s)", rt, ru, rs); } @@ -13058,15 +12959,15 @@ static std::string SCDP(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SCE(uint64 instruction, Dis_info *info) +static char *SCE(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); int64 s_value = extract_s__se8_15_7_6_5_4_3_2_s2(instruction); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("SCE %s, %s(%s)", rt, s, rs); } @@ -13082,15 +12983,15 @@ static std::string SCE(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SCWP(uint64 instruction, Dis_info *info) +static char *SCWP(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); uint64 ru_value = extract_ru_7_6_5_4_3(instruction); - std::string rt = GPR(rt_value); - std::string ru = GPR(ru_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *ru = GPR(ru_value); + const char *rs = GPR(rs_value); return img_format("SCWP %s, %s, (%s)", rt, ru, rs); } @@ -13106,15 +13007,15 @@ static std::string SCWP(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SCWPE(uint64 instruction, Dis_info *info) +static char *SCWPE(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); uint64 ru_value = extract_ru_7_6_5_4_3(instruction); - std::string rt = GPR(rt_value); - std::string ru = GPR(ru_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *ru = GPR(ru_value); + const char *rs = GPR(rs_value); return img_format("SCWPE %s, %s, (%s)", rt, ru, rs); } @@ -13130,13 +13031,13 @@ static std::string SCWPE(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SD_GP_(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string u = IMMEDIATE(u_value); + const char *rt = GPR(rt_value); + char *u = IMMEDIATE(u_value); return img_format("SD %s, %s($%d)", rt, u, 28); } @@ -13152,15 +13053,15 @@ static std::string SD_GP_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SD_S9_(uint64 instruction, Dis_info *info) +static char *SD_S9_(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); int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("SD %s, %s(%s)", rt, s, rs); } @@ -13176,15 +13077,15 @@ static std::string SD_S9_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SD_U12_(uint64 instruction, Dis_info *info) +static char *SD_U12_(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); uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string u = IMMEDIATE(u_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *u = IMMEDIATE(u_value); + const char *rs = GPR(rs_value); return img_format("SD %s, %s(%s)", rt, u, rs); } @@ -13200,11 +13101,11 @@ static std::string SD_U12_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SDBBP_16_(uint64 instruction, Dis_info *info) +static char *SDBBP_16_(uint64 instruction, Dis_info *info) { uint64 code_value = extract_code_2_1_0(instruction); - std::string code = IMMEDIATE(code_value); + char *code = IMMEDIATE(code_value); return img_format("SDBBP %s", code); } @@ -13220,11 +13121,11 @@ static std::string SDBBP_16_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SDBBP_32_(uint64 instruction, Dis_info *info) +static char *SDBBP_32_(uint64 instruction, Dis_info *info) { uint64 code_value = extract_code_18_to_0(instruction); - std::string code = IMMEDIATE(code_value); + char *code = IMMEDIATE(code_value); return img_format("SDBBP %s", code); } @@ -13240,13 +13141,13 @@ static std::string SDBBP_32_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SDC1_GP_(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string u = IMMEDIATE(u_value); + const char *ft = FPR(ft_value); + char *u = IMMEDIATE(u_value); return img_format("SDC1 %s, %s($%d)", ft, u, 28); } @@ -13262,15 +13163,15 @@ static std::string SDC1_GP_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SDC1_S9_(uint64 instruction, Dis_info *info) +static char *SDC1_S9_(uint64 instruction, Dis_info *info) { uint64 ft_value = extract_ft_25_24_23_22_21(instruction); 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); - std::string ft = FPR(ft_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + const char *ft = FPR(ft_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("SDC1 %s, %s(%s)", ft, s, rs); } @@ -13286,15 +13187,15 @@ static std::string SDC1_S9_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SDC1_U12_(uint64 instruction, Dis_info *info) +static char *SDC1_U12_(uint64 instruction, Dis_info *info) { uint64 ft_value = extract_ft_25_24_23_22_21(instruction); 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); - std::string ft = FPR(ft_value); - std::string u = IMMEDIATE(u_value); - std::string rs = GPR(rs_value); + const char *ft = FPR(ft_value); + char *u = IMMEDIATE(u_value); + const char *rs = GPR(rs_value); return img_format("SDC1 %s, %s(%s)", ft, u, rs); } @@ -13310,15 +13211,15 @@ static std::string SDC1_U12_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SDC1X(uint64 instruction, Dis_info *info) +static char *SDC1X(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); uint64 ft_value = extract_ft_15_14_13_12_11(instruction); - std::string ft = FPR(ft_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *ft = FPR(ft_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("SDC1X %s, %s(%s)", ft, rs, rt); } @@ -13334,15 +13235,15 @@ static std::string SDC1X(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SDC1XS(uint64 instruction, Dis_info *info) +static char *SDC1XS(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); uint64 ft_value = extract_ft_15_14_13_12_11(instruction); - std::string ft = FPR(ft_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *ft = FPR(ft_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("SDC1XS %s, %s(%s)", ft, rs, rt); } @@ -13358,15 +13259,15 @@ static std::string SDC1XS(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SDC2(uint64 instruction, Dis_info *info) +static char *SDC2(uint64 instruction, Dis_info *info) { uint64 cs_value = extract_cs_25_24_23_22_21(instruction); 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); - std::string cs = CPR(cs_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + char *cs = CPR(cs_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("SDC2 %s, %s(%s)", cs, s, rs); } @@ -13382,17 +13283,17 @@ static std::string SDC2(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SDM(uint64 instruction, Dis_info *info) +static char *SDM(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); 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); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); - std::string count3 = IMMEDIATE(encode_count3_from_count(count3_value)); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); + char *count3 = IMMEDIATE(encode_count3_from_count(count3_value)); return img_format("SDM %s, %s(%s), %s", rt, s, rs, count3); } @@ -13408,13 +13309,13 @@ static std::string SDM(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SDPC_48_(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string s = ADDRESS(s_value, 6, info); + const char *rt = GPR(rt_value); + char *s = ADDRESS(s_value, 6, info); return img_format("SDPC %s, %s", rt, s); } @@ -13430,15 +13331,15 @@ static std::string SDPC_48_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SDXS(uint64 instruction, Dis_info *info) +static char *SDXS(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("SDXS %s, %s(%s)", rd, rs, rt); } @@ -13454,15 +13355,15 @@ static std::string SDXS(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SDX(uint64 instruction, Dis_info *info) +static char *SDX(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("SDX %s, %s(%s)", rd, rs, rt); } @@ -13478,13 +13379,13 @@ static std::string SDX(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SEB(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("SEB %s, %s", rt, rs); } @@ -13500,13 +13401,13 @@ static std::string SEB(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SEH(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("SEH %s, %s", rt, rs); } @@ -13522,15 +13423,15 @@ static std::string SEH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SEL_D(uint64 instruction, Dis_info *info) +static char *SEL_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("SEL.D %s, %s, %s", fd, fs, ft); } @@ -13546,15 +13447,15 @@ static std::string SEL_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SEL_S(uint64 instruction, Dis_info *info) +static char *SEL_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("SEL.S %s, %s, %s", fd, fs, ft); } @@ -13570,15 +13471,15 @@ static std::string SEL_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SELEQZ_D(uint64 instruction, Dis_info *info) +static char *SELEQZ_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("SELEQZ.D %s, %s, %s", fd, fs, ft); } @@ -13594,15 +13495,15 @@ static std::string SELEQZ_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SELEQZ_S(uint64 instruction, Dis_info *info) +static char *SELEQZ_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("SELEQZ.S %s, %s, %s", fd, fs, ft); } @@ -13618,15 +13519,15 @@ static std::string SELEQZ_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SELNEZ_D(uint64 instruction, Dis_info *info) +static char *SELNEZ_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("SELNEZ.D %s, %s, %s", fd, fs, ft); } @@ -13642,15 +13543,15 @@ static std::string SELNEZ_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SELNEZ_S(uint64 instruction, Dis_info *info) +static char *SELNEZ_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("SELNEZ.S %s, %s, %s", fd, fs, ft); } @@ -13666,15 +13567,15 @@ static std::string SELNEZ_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SEQI(uint64 instruction, Dis_info *info) +static char *SEQI(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); uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string u = IMMEDIATE(u_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *u = IMMEDIATE(u_value); return img_format("SEQI %s, %s, %s", rt, rs, u); } @@ -13690,15 +13591,15 @@ static std::string SEQI(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SH_16_(uint64 instruction, Dis_info *info) +static char *SH_16_(uint64 instruction, Dis_info *info) { uint64 rtz3_value = extract_rtz3_9_8_7(instruction); uint64 rs3_value = extract_rs3_6_5_4(instruction); uint64 u_value = extract_u_2_1__s1(instruction); - std::string rtz3 = GPR(decode_gpr_gpr3_src_store(rtz3_value)); - std::string u = IMMEDIATE(u_value); - std::string rs3 = GPR(decode_gpr_gpr3(rs3_value)); + const char *rtz3 = GPR(decode_gpr_gpr3_src_store(rtz3_value)); + char *u = IMMEDIATE(u_value); + const char *rs3 = GPR(decode_gpr_gpr3(rs3_value)); return img_format("SH %s, %s(%s)", rtz3, u, rs3); } @@ -13714,13 +13615,13 @@ static std::string SH_16_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SH_GP_(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string u = IMMEDIATE(u_value); + const char *rt = GPR(rt_value); + char *u = IMMEDIATE(u_value); return img_format("SH %s, %s($%d)", rt, u, 28); } @@ -13736,15 +13637,15 @@ static std::string SH_GP_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SH_S9_(uint64 instruction, Dis_info *info) +static char *SH_S9_(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); int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("SH %s, %s(%s)", rt, s, rs); } @@ -13760,15 +13661,15 @@ static std::string SH_S9_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SH_U12_(uint64 instruction, Dis_info *info) +static char *SH_U12_(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); uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string u = IMMEDIATE(u_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *u = IMMEDIATE(u_value); + const char *rs = GPR(rs_value); return img_format("SH %s, %s(%s)", rt, u, rs); } @@ -13784,15 +13685,15 @@ static std::string SH_U12_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SHE(uint64 instruction, Dis_info *info) +static char *SHE(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); int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("SHE %s, %s(%s)", rt, s, rs); } @@ -13808,13 +13709,13 @@ static std::string SHE(uint64 instruction, Dis_info *info) * shift ------ * ac -- */ -static std::string SHILO(uint64 instruction, Dis_info *info) +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); - std::string shift = IMMEDIATE(shift_value); - std::string ac = AC(ac_value); + char *shift = IMMEDIATE(shift_value); + const char *ac = AC(ac_value); return img_format("SHILO %s, %s", ac, shift); } @@ -13830,13 +13731,13 @@ static std::string SHILO(uint64 instruction, Dis_info *info) * rs ----- * ac -- */ -static std::string SHILOV(uint64 instruction, Dis_info *info) +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); - std::string rs = GPR(rs_value); - std::string ac = AC(ac_value); + const char *rs = GPR(rs_value); + const char *ac = AC(ac_value); return img_format("SHILOV %s, %s", ac, rs); } @@ -13852,15 +13753,15 @@ static std::string SHILOV(uint64 instruction, Dis_info *info) * rs ----- * sa ---- */ -static std::string SHLL_PH(uint64 instruction, Dis_info *info) +static char *SHLL_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); uint64 sa_value = extract_sa_15_14_13_12(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string sa = IMMEDIATE(sa_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *sa = IMMEDIATE(sa_value); return img_format("SHLL.PH %s, %s, %s", rt, rs, sa); } @@ -13876,15 +13777,15 @@ static std::string SHLL_PH(uint64 instruction, Dis_info *info) * rs ----- * sa --- */ -static std::string SHLL_QB(uint64 instruction, Dis_info *info) +static char *SHLL_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); uint64 sa_value = extract_sa_15_14_13(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string sa = IMMEDIATE(sa_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *sa = IMMEDIATE(sa_value); return img_format("SHLL.QB %s, %s, %s", rt, rs, sa); } @@ -13901,15 +13802,15 @@ static std::string SHLL_QB(uint64 instruction, Dis_info *info) * rs ----- * sa ---- */ -static std::string SHLL_S_PH(uint64 instruction, Dis_info *info) +static char *SHLL_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); uint64 sa_value = extract_sa_15_14_13_12(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string sa = IMMEDIATE(sa_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *sa = IMMEDIATE(sa_value); return img_format("SHLL_S.PH %s, %s, %s", rt, rs, sa); } @@ -13925,15 +13826,15 @@ static std::string SHLL_S_PH(uint64 instruction, Dis_info *info) * rs ----- * sa ----- */ -static std::string SHLL_S_W(uint64 instruction, Dis_info *info) +static char *SHLL_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); uint64 sa_value = extract_sa_15_14_13_12_11(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string sa = IMMEDIATE(sa_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *sa = IMMEDIATE(sa_value); return img_format("SHLL_S.W %s, %s, %s", rt, rs, sa); } @@ -13950,15 +13851,15 @@ static std::string SHLL_S_W(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SHLLV_PH(uint64 instruction, Dis_info *info) +static char *SHLLV_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rd = GPR(rd_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("SHLLV.PH %s, %s, %s", rd, rt, rs); } @@ -13974,15 +13875,15 @@ static std::string SHLLV_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SHLLV_QB(uint64 instruction, Dis_info *info) +static char *SHLLV_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rd = GPR(rd_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("SHLLV.QB %s, %s, %s", rd, rt, rs); } @@ -13999,15 +13900,15 @@ static std::string SHLLV_QB(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SHLLV_S_PH(uint64 instruction, Dis_info *info) +static char *SHLLV_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rd = GPR(rd_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("SHLLV_S.PH %s, %s, %s", rd, rt, rs); } @@ -14023,15 +13924,15 @@ static std::string SHLLV_S_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SHLLV_S_W(uint64 instruction, Dis_info *info) +static char *SHLLV_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rd = GPR(rd_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("SHLLV_S.W %s, %s, %s", rd, rt, rs); } @@ -14047,15 +13948,15 @@ static std::string SHLLV_S_W(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SHRA_PH(uint64 instruction, Dis_info *info) +static char *SHRA_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); uint64 sa_value = extract_sa_15_14_13_12(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string sa = IMMEDIATE(sa_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *sa = IMMEDIATE(sa_value); return img_format("SHRA.PH %s, %s, %s", rt, rs, sa); } @@ -14071,15 +13972,15 @@ static std::string SHRA_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SHRA_QB(uint64 instruction, Dis_info *info) +static char *SHRA_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); uint64 sa_value = extract_sa_15_14_13(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string sa = IMMEDIATE(sa_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *sa = IMMEDIATE(sa_value); return img_format("SHRA.QB %s, %s, %s", rt, rs, sa); } @@ -14095,15 +13996,15 @@ static std::string SHRA_QB(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SHRA_R_PH(uint64 instruction, Dis_info *info) +static char *SHRA_R_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); uint64 sa_value = extract_sa_15_14_13_12(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string sa = IMMEDIATE(sa_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *sa = IMMEDIATE(sa_value); return img_format("SHRA_R.PH %s, %s, %s", rt, rs, sa); } @@ -14119,15 +14020,15 @@ static std::string SHRA_R_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SHRA_R_QB(uint64 instruction, Dis_info *info) +static char *SHRA_R_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); uint64 sa_value = extract_sa_15_14_13(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string sa = IMMEDIATE(sa_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *sa = IMMEDIATE(sa_value); return img_format("SHRA_R.QB %s, %s, %s", rt, rs, sa); } @@ -14143,15 +14044,15 @@ static std::string SHRA_R_QB(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SHRA_R_W(uint64 instruction, Dis_info *info) +static char *SHRA_R_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); uint64 sa_value = extract_sa_15_14_13_12_11(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string sa = IMMEDIATE(sa_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *sa = IMMEDIATE(sa_value); return img_format("SHRA_R.W %s, %s, %s", rt, rs, sa); } @@ -14167,15 +14068,15 @@ static std::string SHRA_R_W(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SHRAV_PH(uint64 instruction, Dis_info *info) +static char *SHRAV_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rd = GPR(rd_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("SHRAV.PH %s, %s, %s", rd, rt, rs); } @@ -14191,15 +14092,15 @@ static std::string SHRAV_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SHRAV_QB(uint64 instruction, Dis_info *info) +static char *SHRAV_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rd = GPR(rd_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("SHRAV.QB %s, %s, %s", rd, rt, rs); } @@ -14215,15 +14116,15 @@ static std::string SHRAV_QB(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SHRAV_R_PH(uint64 instruction, Dis_info *info) +static char *SHRAV_R_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rd = GPR(rd_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("SHRAV_R.PH %s, %s, %s", rd, rt, rs); } @@ -14239,15 +14140,15 @@ static std::string SHRAV_R_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SHRAV_R_QB(uint64 instruction, Dis_info *info) +static char *SHRAV_R_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rd = GPR(rd_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("SHRAV_R.QB %s, %s, %s", rd, rt, rs); } @@ -14263,15 +14164,15 @@ static std::string SHRAV_R_QB(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SHRAV_R_W(uint64 instruction, Dis_info *info) +static char *SHRAV_R_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rd = GPR(rd_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("SHRAV_R.W %s, %s, %s", rd, rt, rs); } @@ -14287,15 +14188,15 @@ static std::string SHRAV_R_W(uint64 instruction, Dis_info *info) * rs ----- * sa ---- */ -static std::string SHRL_PH(uint64 instruction, Dis_info *info) +static char *SHRL_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); uint64 sa_value = extract_sa_15_14_13_12(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string sa = IMMEDIATE(sa_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *sa = IMMEDIATE(sa_value); return img_format("SHRL.PH %s, %s, %s", rt, rs, sa); } @@ -14311,15 +14212,15 @@ static std::string SHRL_PH(uint64 instruction, Dis_info *info) * rs ----- * sa --- */ -static std::string SHRL_QB(uint64 instruction, Dis_info *info) +static char *SHRL_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); uint64 sa_value = extract_sa_15_14_13(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string sa = IMMEDIATE(sa_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *sa = IMMEDIATE(sa_value); return img_format("SHRL.QB %s, %s, %s", rt, rs, sa); } @@ -14336,15 +14237,15 @@ static std::string SHRL_QB(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SHRLV_PH(uint64 instruction, Dis_info *info) +static char *SHRLV_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rd = GPR(rd_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("SHRLV.PH %s, %s, %s", rd, rt, rs); } @@ -14360,15 +14261,15 @@ static std::string SHRLV_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SHRLV_QB(uint64 instruction, Dis_info *info) +static char *SHRLV_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rd = GPR(rd_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("SHRLV.QB %s, %s, %s", rd, rt, rs); } @@ -14384,15 +14285,15 @@ static std::string SHRLV_QB(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SHX(uint64 instruction, Dis_info *info) +static char *SHX(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("SHX %s, %s(%s)", rd, rs, rt); } @@ -14408,15 +14309,15 @@ static std::string SHX(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SHXS(uint64 instruction, Dis_info *info) +static char *SHXS(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("SHXS %s, %s(%s)", rd, rs, rt); } @@ -14432,11 +14333,11 @@ static std::string SHXS(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SIGRIE(uint64 instruction, Dis_info *info) +static char *SIGRIE(uint64 instruction, Dis_info *info) { uint64 code_value = extract_code_18_to_0(instruction); - std::string code = IMMEDIATE(code_value); + char *code = IMMEDIATE(code_value); return img_format("SIGRIE %s", code); } @@ -14452,15 +14353,15 @@ static std::string SIGRIE(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SLL_16_(uint64 instruction, Dis_info *info) +static char *SLL_16_(uint64 instruction, Dis_info *info) { uint64 rt3_value = extract_rt3_9_8_7(instruction); uint64 rs3_value = extract_rs3_6_5_4(instruction); uint64 shift3_value = extract_shift3_2_1_0(instruction); - std::string rt3 = GPR(decode_gpr_gpr3(rt3_value)); - std::string rs3 = GPR(decode_gpr_gpr3(rs3_value)); - std::string shift3 = IMMEDIATE(encode_shift3_from_shift(shift3_value)); + const char *rt3 = GPR(decode_gpr_gpr3(rt3_value)); + const char *rs3 = GPR(decode_gpr_gpr3(rs3_value)); + char *shift3 = IMMEDIATE(encode_shift3_from_shift(shift3_value)); return img_format("SLL %s, %s, %s", rt3, rs3, shift3); } @@ -14476,15 +14377,15 @@ static std::string SLL_16_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SLL_32_(uint64 instruction, Dis_info *info) +static char *SLL_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); uint64 shift_value = extract_shift_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string shift = IMMEDIATE(shift_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *shift = IMMEDIATE(shift_value); return img_format("SLL %s, %s, %s", rt, rs, shift); } @@ -14500,15 +14401,15 @@ static std::string SLL_32_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SLLV(uint64 instruction, Dis_info *info) +static char *SLLV(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("SLLV %s, %s, %s", rd, rs, rt); } @@ -14524,15 +14425,15 @@ static std::string SLLV(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SLT(uint64 instruction, Dis_info *info) +static char *SLT(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("SLT %s, %s, %s", rd, rs, rt); } @@ -14548,15 +14449,15 @@ static std::string SLT(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SLTI(uint64 instruction, Dis_info *info) +static char *SLTI(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); uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string u = IMMEDIATE(u_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *u = IMMEDIATE(u_value); return img_format("SLTI %s, %s, %s", rt, rs, u); } @@ -14572,15 +14473,15 @@ static std::string SLTI(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SLTIU(uint64 instruction, Dis_info *info) +static char *SLTIU(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); uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string u = IMMEDIATE(u_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *u = IMMEDIATE(u_value); return img_format("SLTIU %s, %s, %s", rt, rs, u); } @@ -14596,15 +14497,15 @@ static std::string SLTIU(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SLTU(uint64 instruction, Dis_info *info) +static char *SLTU(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("SLTU %s, %s, %s", rd, rs, rt); } @@ -14620,15 +14521,15 @@ static std::string SLTU(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SOV(uint64 instruction, Dis_info *info) +static char *SOV(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("SOV %s, %s, %s", rd, rs, rt); } @@ -14644,11 +14545,11 @@ static std::string SOV(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SPECIAL2(uint64 instruction, Dis_info *info) +static char *SPECIAL2(uint64 instruction, Dis_info *info) { uint64 op_value = extract_op_25_to_3(instruction); - std::string op = IMMEDIATE(op_value); + char *op = IMMEDIATE(op_value); return img_format("SPECIAL2 %s", op); } @@ -14664,13 +14565,13 @@ static std::string SPECIAL2(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SQRT_D(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("SQRT.D %s, %s", ft, fs); } @@ -14686,13 +14587,13 @@ static std::string SQRT_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SQRT_S(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("SQRT.S %s, %s", ft, fs); } @@ -14708,15 +14609,15 @@ static std::string SQRT_S(uint64 instruction, Dis_info *info) * rd ----- * sa ----- */ -static std::string SRA(uint64 instruction, Dis_info *info) +static char *SRA(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); uint64 shift_value = extract_shift_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string shift = IMMEDIATE(shift_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *shift = IMMEDIATE(shift_value); return img_format("SRA %s, %s, %s", rt, rs, shift); } @@ -14732,15 +14633,15 @@ static std::string SRA(uint64 instruction, Dis_info *info) * rt ----- * rd ----- */ -static std::string SRAV(uint64 instruction, Dis_info *info) +static char *SRAV(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("SRAV %s, %s, %s", rd, rs, rt); } @@ -14756,15 +14657,15 @@ static std::string SRAV(uint64 instruction, Dis_info *info) * rt ----- * rd ----- */ -static std::string SRL_16_(uint64 instruction, Dis_info *info) +static char *SRL_16_(uint64 instruction, Dis_info *info) { uint64 rt3_value = extract_rt3_9_8_7(instruction); uint64 rs3_value = extract_rs3_6_5_4(instruction); uint64 shift3_value = extract_shift3_2_1_0(instruction); - std::string rt3 = GPR(decode_gpr_gpr3(rt3_value)); - std::string rs3 = GPR(decode_gpr_gpr3(rs3_value)); - std::string shift3 = IMMEDIATE(encode_shift3_from_shift(shift3_value)); + const char *rt3 = GPR(decode_gpr_gpr3(rt3_value)); + const char *rs3 = GPR(decode_gpr_gpr3(rs3_value)); + char *shift3 = IMMEDIATE(encode_shift3_from_shift(shift3_value)); return img_format("SRL %s, %s, %s", rt3, rs3, shift3); } @@ -14780,15 +14681,15 @@ static std::string SRL_16_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SRL_32_(uint64 instruction, Dis_info *info) +static char *SRL_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); uint64 shift_value = extract_shift_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string shift = IMMEDIATE(shift_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *shift = IMMEDIATE(shift_value); return img_format("SRL %s, %s, %s", rt, rs, shift); } @@ -14804,15 +14705,15 @@ static std::string SRL_32_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SRLV(uint64 instruction, Dis_info *info) +static char *SRLV(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("SRLV %s, %s, %s", rd, rs, rt); } @@ -14828,15 +14729,15 @@ static std::string SRLV(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SUB(uint64 instruction, Dis_info *info) +static char *SUB(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("SUB %s, %s, %s", rd, rs, rt); } @@ -14852,15 +14753,15 @@ static std::string SUB(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SUB_D(uint64 instruction, Dis_info *info) +static char *SUB_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("SUB.D %s, %s, %s", fd, fs, ft); } @@ -14876,15 +14777,15 @@ static std::string SUB_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SUB_S(uint64 instruction, Dis_info *info) +static char *SUB_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); uint64 fd_value = extract_fd_15_14_13_12_11(instruction); - std::string fd = FPR(fd_value); - std::string fs = FPR(fs_value); - std::string ft = FPR(ft_value); + const char *fd = FPR(fd_value); + const char *fs = FPR(fs_value); + const char *ft = FPR(ft_value); return img_format("SUB.S %s, %s, %s", fd, fs, ft); } @@ -14900,15 +14801,15 @@ static std::string SUB_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SUBQ_PH(uint64 instruction, Dis_info *info) +static char *SUBQ_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("SUBQ.PH %s, %s, %s", rd, rs, rt); } @@ -14925,15 +14826,15 @@ static std::string SUBQ_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SUBQ_S_PH(uint64 instruction, Dis_info *info) +static char *SUBQ_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("SUBQ_S.PH %s, %s, %s", rd, rs, rt); } @@ -14950,15 +14851,15 @@ static std::string SUBQ_S_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SUBQ_S_W(uint64 instruction, Dis_info *info) +static char *SUBQ_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("SUBQ_S.W %s, %s, %s", rd, rs, rt); } @@ -14975,15 +14876,15 @@ static std::string SUBQ_S_W(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SUBQH_PH(uint64 instruction, Dis_info *info) +static char *SUBQH_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("SUBQH.PH %s, %s, %s", rd, rs, rt); } @@ -15000,15 +14901,15 @@ static std::string SUBQH_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SUBQH_R_PH(uint64 instruction, Dis_info *info) +static char *SUBQH_R_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("SUBQH_R.PH %s, %s, %s", rd, rs, rt); } @@ -15025,15 +14926,15 @@ static std::string SUBQH_R_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SUBQH_R_W(uint64 instruction, Dis_info *info) +static char *SUBQH_R_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("SUBQH_R.W %s, %s, %s", rd, rs, rt); } @@ -15050,15 +14951,15 @@ static std::string SUBQH_R_W(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SUBQH_W(uint64 instruction, Dis_info *info) +static char *SUBQH_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("SUBQH.W %s, %s, %s", rd, rs, rt); } @@ -15074,15 +14975,15 @@ static std::string SUBQH_W(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SUBU_16_(uint64 instruction, Dis_info *info) +static char *SUBU_16_(uint64 instruction, Dis_info *info) { uint64 rt3_value = extract_rt3_9_8_7(instruction); uint64 rs3_value = extract_rs3_6_5_4(instruction); uint64 rd3_value = extract_rd3_3_2_1(instruction); - std::string rd3 = GPR(decode_gpr_gpr3(rd3_value)); - std::string rs3 = GPR(decode_gpr_gpr3(rs3_value)); - std::string rt3 = GPR(decode_gpr_gpr3(rt3_value)); + 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)); return img_format("SUBU %s, %s, %s", rd3, rs3, rt3); } @@ -15098,15 +14999,15 @@ static std::string SUBU_16_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SUBU_32_(uint64 instruction, Dis_info *info) +static char *SUBU_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("SUBU %s, %s, %s", rd, rs, rt); } @@ -15122,15 +15023,15 @@ static std::string SUBU_32_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SUBU_PH(uint64 instruction, Dis_info *info) +static char *SUBU_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("SUBU.PH %s, %s, %s", rd, rs, rt); } @@ -15146,15 +15047,15 @@ static std::string SUBU_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SUBU_QB(uint64 instruction, Dis_info *info) +static char *SUBU_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("SUBU.QB %s, %s, %s", rd, rs, rt); } @@ -15171,15 +15072,15 @@ static std::string SUBU_QB(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SUBU_S_PH(uint64 instruction, Dis_info *info) +static char *SUBU_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("SUBU_S.PH %s, %s, %s", rd, rs, rt); } @@ -15196,15 +15097,15 @@ static std::string SUBU_S_PH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SUBU_S_QB(uint64 instruction, Dis_info *info) +static char *SUBU_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("SUBU_S.QB %s, %s, %s", rd, rs, rt); } @@ -15221,15 +15122,15 @@ static std::string SUBU_S_QB(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SUBUH_QB(uint64 instruction, Dis_info *info) +static char *SUBUH_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("SUBUH.QB %s, %s, %s", rd, rs, rt); } @@ -15246,15 +15147,15 @@ static std::string SUBUH_QB(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SUBUH_R_QB(uint64 instruction, Dis_info *info) +static char *SUBUH_R_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("SUBUH_R.QB %s, %s, %s", rd, rs, rt); } @@ -15270,15 +15171,15 @@ static std::string SUBUH_R_QB(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SW_16_(uint64 instruction, Dis_info *info) +static char *SW_16_(uint64 instruction, Dis_info *info) { uint64 rtz3_value = extract_rtz3_9_8_7(instruction); uint64 rs3_value = extract_rs3_6_5_4(instruction); uint64 u_value = extract_u_3_2_1_0__s2(instruction); - std::string rtz3 = GPR(decode_gpr_gpr3_src_store(rtz3_value)); - std::string u = IMMEDIATE(u_value); - std::string rs3 = GPR(decode_gpr_gpr3(rs3_value)); + const char *rtz3 = GPR(decode_gpr_gpr3_src_store(rtz3_value)); + char *u = IMMEDIATE(u_value); + const char *rs3 = GPR(decode_gpr_gpr3(rs3_value)); return img_format("SW %s, %s(%s)", rtz3, u, rs3); } @@ -15294,15 +15195,15 @@ static std::string SW_16_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SW_4X4_(uint64 instruction, Dis_info *info) +static char *SW_4X4_(uint64 instruction, Dis_info *info) { uint64 rtz4_value = extract_rtz4_9_7_6_5(instruction); uint64 rs4_value = extract_rs4_4_2_1_0(instruction); uint64 u_value = extract_u_3_8__s2(instruction); - std::string rtz4 = GPR(decode_gpr_gpr4_zero(rtz4_value)); - std::string u = IMMEDIATE(u_value); - std::string rs4 = GPR(decode_gpr_gpr4(rs4_value)); + const char *rtz4 = GPR(decode_gpr_gpr4_zero(rtz4_value)); + char *u = IMMEDIATE(u_value); + const char *rs4 = GPR(decode_gpr_gpr4(rs4_value)); return img_format("SW %s, %s(%s)", rtz4, u, rs4); } @@ -15318,13 +15219,13 @@ static std::string SW_4X4_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SW_GP16_(uint64 instruction, Dis_info *info) +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); - std::string rtz3 = GPR(decode_gpr_gpr3_src_store(rtz3_value)); - std::string u = IMMEDIATE(u_value); + const char *rtz3 = GPR(decode_gpr_gpr3_src_store(rtz3_value)); + char *u = IMMEDIATE(u_value); return img_format("SW %s, %s($%d)", rtz3, u, 28); } @@ -15340,13 +15241,13 @@ static std::string SW_GP16_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SW_GP_(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string u = IMMEDIATE(u_value); + const char *rt = GPR(rt_value); + char *u = IMMEDIATE(u_value); return img_format("SW %s, %s($%d)", rt, u, 28); } @@ -15362,15 +15263,15 @@ static std::string SW_GP_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SW_S9_(uint64 instruction, Dis_info *info) +static char *SW_S9_(uint64 instruction, Dis_info *info) { uint64 rt_value = extract_rt_25_24_23_22_21(instruction); 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); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("SW %s, %s(%s)", rt, s, rs); } @@ -15386,13 +15287,13 @@ static std::string SW_S9_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SW_SP_(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string u = IMMEDIATE(u_value); + const char *rt = GPR(rt_value); + char *u = IMMEDIATE(u_value); return img_format("SW %s, %s($%d)", rt, u, 29); } @@ -15408,15 +15309,15 @@ static std::string SW_SP_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SW_U12_(uint64 instruction, Dis_info *info) +static char *SW_U12_(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); uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string u = IMMEDIATE(u_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *u = IMMEDIATE(u_value); + const char *rs = GPR(rs_value); return img_format("SW %s, %s(%s)", rt, u, rs); } @@ -15432,13 +15333,13 @@ static std::string SW_U12_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SWC1_GP_(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string u = IMMEDIATE(u_value); + const char *ft = FPR(ft_value); + char *u = IMMEDIATE(u_value); return img_format("SWC1 %s, %s($%d)", ft, u, 28); } @@ -15454,15 +15355,15 @@ static std::string SWC1_GP_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SWC1_S9_(uint64 instruction, Dis_info *info) +static char *SWC1_S9_(uint64 instruction, Dis_info *info) { uint64 ft_value = extract_ft_25_24_23_22_21(instruction); 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); - std::string ft = FPR(ft_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + const char *ft = FPR(ft_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("SWC1 %s, %s(%s)", ft, s, rs); } @@ -15478,15 +15379,15 @@ static std::string SWC1_S9_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SWC1_U12_(uint64 instruction, Dis_info *info) +static char *SWC1_U12_(uint64 instruction, Dis_info *info) { uint64 ft_value = extract_ft_25_24_23_22_21(instruction); 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); - std::string ft = FPR(ft_value); - std::string u = IMMEDIATE(u_value); - std::string rs = GPR(rs_value); + const char *ft = FPR(ft_value); + char *u = IMMEDIATE(u_value); + const char *rs = GPR(rs_value); return img_format("SWC1 %s, %s(%s)", ft, u, rs); } @@ -15502,15 +15403,15 @@ static std::string SWC1_U12_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SWC1X(uint64 instruction, Dis_info *info) +static char *SWC1X(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); uint64 ft_value = extract_ft_15_14_13_12_11(instruction); - std::string ft = FPR(ft_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *ft = FPR(ft_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("SWC1X %s, %s(%s)", ft, rs, rt); } @@ -15526,15 +15427,15 @@ static std::string SWC1X(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SWC1XS(uint64 instruction, Dis_info *info) +static char *SWC1XS(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); uint64 ft_value = extract_ft_15_14_13_12_11(instruction); - std::string ft = FPR(ft_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *ft = FPR(ft_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("SWC1XS %s, %s(%s)", ft, rs, rt); } @@ -15550,15 +15451,15 @@ static std::string SWC1XS(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SWC2(uint64 instruction, Dis_info *info) +static char *SWC2(uint64 instruction, Dis_info *info) { uint64 cs_value = extract_cs_25_24_23_22_21(instruction); 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); - std::string cs = CPR(cs_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + char *cs = CPR(cs_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("SWC2 %s, %s(%s)", cs, s, rs); } @@ -15574,15 +15475,15 @@ static std::string SWC2(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SWE(uint64 instruction, Dis_info *info) +static char *SWE(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); int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("SWE %s, %s(%s)", rt, s, rs); } @@ -15598,17 +15499,17 @@ static std::string SWE(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SWM(uint64 instruction, Dis_info *info) +static char *SWM(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); 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); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); - std::string count3 = IMMEDIATE(encode_count3_from_count(count3_value)); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); + char *count3 = IMMEDIATE(encode_count3_from_count(count3_value)); return img_format("SWM %s, %s(%s), %s", rt, s, rs, count3); } @@ -15624,13 +15525,13 @@ static std::string SWM(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SWPC_48_(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string s = ADDRESS(s_value, 6, info); + const char *rt = GPR(rt_value); + char *s = ADDRESS(s_value, 6, info); return img_format("SWPC %s, %s", rt, s); } @@ -15646,15 +15547,15 @@ static std::string SWPC_48_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SWX(uint64 instruction, Dis_info *info) +static char *SWX(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("SWX %s, %s(%s)", rd, rs, rt); } @@ -15670,15 +15571,15 @@ static std::string SWX(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SWXS(uint64 instruction, Dis_info *info) +static char *SWXS(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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("SWXS %s, %s(%s)", rd, rs, rt); } @@ -15694,11 +15595,11 @@ static std::string SWXS(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SYNC(uint64 instruction, Dis_info *info) +static char *SYNC(uint64 instruction, Dis_info *info) { uint64 stype_value = extract_stype_20_19_18_17_16(instruction); - std::string stype = IMMEDIATE(stype_value); + char *stype = IMMEDIATE(stype_value); return img_format("SYNC %s", stype); } @@ -15714,13 +15615,13 @@ static std::string SYNC(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SYNCI(uint64 instruction, Dis_info *info) +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); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("SYNCI %s(%s)", s, rs); } @@ -15736,13 +15637,13 @@ static std::string SYNCI(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SYNCIE(uint64 instruction, Dis_info *info) +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); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("SYNCIE %s(%s)", s, rs); } @@ -15758,11 +15659,11 @@ static std::string SYNCIE(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string SYSCALL_16_(uint64 instruction, Dis_info *info) +static char *SYSCALL_16_(uint64 instruction, Dis_info *info) { uint64 code_value = extract_code_1_0(instruction); - std::string code = IMMEDIATE(code_value); + char *code = IMMEDIATE(code_value); return img_format("SYSCALL %s", code); } @@ -15776,11 +15677,11 @@ static std::string SYSCALL_16_(uint64 instruction, Dis_info *info) * 00000000000010 * code ------------------ */ -static std::string SYSCALL_32_(uint64 instruction, Dis_info *info) +static char *SYSCALL_32_(uint64 instruction, Dis_info *info) { uint64 code_value = extract_code_17_to_0(instruction); - std::string code = IMMEDIATE(code_value); + char *code = IMMEDIATE(code_value); return img_format("SYSCALL %s", code); } @@ -15796,13 +15697,13 @@ static std::string SYSCALL_32_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string TEQ(uint64 instruction, Dis_info *info) +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); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("TEQ %s, %s", rs, rt); } @@ -15818,11 +15719,11 @@ static std::string TEQ(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string TLBGINV(uint64 instruction, Dis_info *info) +static char *TLBGINV(uint64 instruction, Dis_info *info) { (void)instruction; - return "TLBGINV "; + return g_strdup("TLBGINV "); } @@ -15836,11 +15737,11 @@ static std::string TLBGINV(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string TLBGINVF(uint64 instruction, Dis_info *info) +static char *TLBGINVF(uint64 instruction, Dis_info *info) { (void)instruction; - return "TLBGINVF "; + return g_strdup("TLBGINVF "); } @@ -15854,11 +15755,11 @@ static std::string TLBGINVF(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string TLBGP(uint64 instruction, Dis_info *info) +static char *TLBGP(uint64 instruction, Dis_info *info) { (void)instruction; - return "TLBGP "; + return g_strdup("TLBGP "); } @@ -15872,11 +15773,11 @@ static std::string TLBGP(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string TLBGR(uint64 instruction, Dis_info *info) +static char *TLBGR(uint64 instruction, Dis_info *info) { (void)instruction; - return "TLBGR "; + return g_strdup("TLBGR "); } @@ -15890,11 +15791,11 @@ static std::string TLBGR(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string TLBGWI(uint64 instruction, Dis_info *info) +static char *TLBGWI(uint64 instruction, Dis_info *info) { (void)instruction; - return "TLBGWI "; + return g_strdup("TLBGWI "); } @@ -15908,11 +15809,11 @@ static std::string TLBGWI(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string TLBGWR(uint64 instruction, Dis_info *info) +static char *TLBGWR(uint64 instruction, Dis_info *info) { (void)instruction; - return "TLBGWR "; + return g_strdup("TLBGWR "); } @@ -15926,11 +15827,11 @@ static std::string TLBGWR(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string TLBINV(uint64 instruction, Dis_info *info) +static char *TLBINV(uint64 instruction, Dis_info *info) { (void)instruction; - return "TLBINV "; + return g_strdup("TLBINV "); } @@ -15944,11 +15845,11 @@ static std::string TLBINV(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string TLBINVF(uint64 instruction, Dis_info *info) +static char *TLBINVF(uint64 instruction, Dis_info *info) { (void)instruction; - return "TLBINVF "; + return g_strdup("TLBINVF "); } @@ -15962,11 +15863,11 @@ static std::string TLBINVF(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string TLBP(uint64 instruction, Dis_info *info) +static char *TLBP(uint64 instruction, Dis_info *info) { (void)instruction; - return "TLBP "; + return g_strdup("TLBP "); } @@ -15980,11 +15881,11 @@ static std::string TLBP(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string TLBR(uint64 instruction, Dis_info *info) +static char *TLBR(uint64 instruction, Dis_info *info) { (void)instruction; - return "TLBR "; + return g_strdup("TLBR "); } @@ -15998,11 +15899,11 @@ static std::string TLBR(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string TLBWI(uint64 instruction, Dis_info *info) +static char *TLBWI(uint64 instruction, Dis_info *info) { (void)instruction; - return "TLBWI "; + return g_strdup("TLBWI "); } @@ -16016,11 +15917,11 @@ static std::string TLBWI(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string TLBWR(uint64 instruction, Dis_info *info) +static char *TLBWR(uint64 instruction, Dis_info *info) { (void)instruction; - return "TLBWR "; + return g_strdup("TLBWR "); } @@ -16034,13 +15935,13 @@ static std::string TLBWR(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string TNE(uint64 instruction, Dis_info *info) +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); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("TNE %s, %s", rs, rt); } @@ -16056,13 +15957,13 @@ static std::string TNE(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string TRUNC_L_D(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("TRUNC.L.D %s, %s", ft, fs); } @@ -16078,13 +15979,13 @@ static std::string TRUNC_L_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string TRUNC_L_S(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("TRUNC.L.S %s, %s", ft, fs); } @@ -16100,13 +16001,13 @@ static std::string TRUNC_L_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string TRUNC_W_D(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("TRUNC.W.D %s, %s", ft, fs); } @@ -16122,13 +16023,13 @@ static std::string TRUNC_W_D(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string TRUNC_W_S(uint64 instruction, Dis_info *info) +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); - std::string ft = FPR(ft_value); - std::string fs = FPR(fs_value); + const char *ft = FPR(ft_value); + const char *fs = FPR(fs_value); return img_format("TRUNC.W.S %s, %s", ft, fs); } @@ -16144,17 +16045,17 @@ static std::string TRUNC_W_S(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string UALDM(uint64 instruction, Dis_info *info) +static char *UALDM(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); 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); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); - std::string count3 = IMMEDIATE(encode_count3_from_count(count3_value)); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); + char *count3 = IMMEDIATE(encode_count3_from_count(count3_value)); return img_format("UALDM %s, %s(%s), %s", rt, s, rs, count3); } @@ -16170,15 +16071,15 @@ static std::string UALDM(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string UALH(uint64 instruction, Dis_info *info) +static char *UALH(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); int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("UALH %s, %s(%s)", rt, s, rs); } @@ -16194,17 +16095,17 @@ static std::string UALH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string UALWM(uint64 instruction, Dis_info *info) +static char *UALWM(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); 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); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); - std::string count3 = IMMEDIATE(encode_count3_from_count(count3_value)); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); + char *count3 = IMMEDIATE(encode_count3_from_count(count3_value)); return img_format("UALWM %s, %s(%s), %s", rt, s, rs, count3); } @@ -16220,17 +16121,17 @@ static std::string UALWM(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string UASDM(uint64 instruction, Dis_info *info) +static char *UASDM(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); 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); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); - std::string count3 = IMMEDIATE(encode_count3_from_count(count3_value)); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); + char *count3 = IMMEDIATE(encode_count3_from_count(count3_value)); return img_format("UASDM %s, %s(%s), %s", rt, s, rs, count3); } @@ -16246,15 +16147,15 @@ static std::string UASDM(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string UASH(uint64 instruction, Dis_info *info) +static char *UASH(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); int64 s_value = extract_s__se8_15_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); return img_format("UASH %s, %s(%s)", rt, s, rs); } @@ -16270,17 +16171,17 @@ static std::string UASH(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string UASWM(uint64 instruction, Dis_info *info) +static char *UASWM(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); 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); - std::string rt = GPR(rt_value); - std::string s = IMMEDIATE(s_value); - std::string rs = GPR(rs_value); - std::string count3 = IMMEDIATE(encode_count3_from_count(count3_value)); + const char *rt = GPR(rt_value); + char *s = IMMEDIATE(s_value); + const char *rs = GPR(rs_value); + char *count3 = IMMEDIATE(encode_count3_from_count(count3_value)); return img_format("UASWM %s, %s(%s), %s", rt, s, rs, count3); } @@ -16296,11 +16197,11 @@ static std::string UASWM(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string UDI(uint64 instruction, Dis_info *info) +static char *UDI(uint64 instruction, Dis_info *info) { uint64 op_value = extract_op_25_to_3(instruction); - std::string op = IMMEDIATE(op_value); + char *op = IMMEDIATE(op_value); return img_format("UDI %s", op); } @@ -16314,11 +16215,11 @@ static std::string UDI(uint64 instruction, Dis_info *info) * 001000 1100001101111111 * code ---------- */ -static std::string WAIT(uint64 instruction, Dis_info *info) +static char *WAIT(uint64 instruction, Dis_info *info) { uint64 code_value = extract_code_25_24_23_22_21_20_19_18_17_16(instruction); - std::string code = IMMEDIATE(code_value); + char *code = IMMEDIATE(code_value); return img_format("WAIT %s", code); } @@ -16334,13 +16235,13 @@ static std::string WAIT(uint64 instruction, Dis_info *info) * rt ----- * mask ------- */ -static std::string WRDSP(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string mask = IMMEDIATE(mask_value); + const char *rt = GPR(rt_value); + char *mask = IMMEDIATE(mask_value); return img_format("WRDSP %s, %s", rt, mask); } @@ -16356,13 +16257,13 @@ static std::string WRDSP(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string WRPGPR(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("WRPGPR %s, %s", rt, rs); } @@ -16378,13 +16279,13 @@ static std::string WRPGPR(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string XOR_16_(uint64 instruction, Dis_info *info) +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); - std::string rs3 = GPR(decode_gpr_gpr3(rs3_value)); - std::string 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)); return img_format("XOR %s, %s", rs3, rt3); } @@ -16400,15 +16301,15 @@ static std::string XOR_16_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string XOR_32_(uint64 instruction, Dis_info *info) +static char *XOR_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); uint64 rd_value = extract_rd_15_14_13_12_11(instruction); - std::string rd = GPR(rd_value); - std::string rs = GPR(rs_value); - std::string rt = GPR(rt_value); + const char *rd = GPR(rd_value); + const char *rs = GPR(rs_value); + const char *rt = GPR(rt_value); return img_format("XOR %s, %s, %s", rd, rs, rt); } @@ -16424,15 +16325,15 @@ static std::string XOR_32_(uint64 instruction, Dis_info *info) * rs ----- * rd ----- */ -static std::string XORI(uint64 instruction, Dis_info *info) +static char *XORI(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); uint64 u_value = extract_u_11_10_9_8_7_6_5_4_3_2_1_0(instruction); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); - std::string u = IMMEDIATE(u_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); + char *u = IMMEDIATE(u_value); return img_format("XORI %s, %s, %s", rt, rs, u); } @@ -16447,13 +16348,13 @@ static std::string XORI(uint64 instruction, Dis_info *info) * rt ----- * rs ----- */ -static std::string YIELD(uint64 instruction, Dis_info *info) +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); - std::string rt = GPR(rt_value); - std::string rs = GPR(rs_value); + const char *rt = GPR(rt_value); + const char *rs = GPR(rs_value); return img_format("YIELD %s, %s", rt, rs); } @@ -22256,25 +22157,22 @@ static const Pool MAJOR[2] = { 0x0 }, /* P16 */ }; -static int Disassemble(const uint16 *data, std::string & dis, +static int Disassemble(const uint16 *data, char **dis, TABLE_ENTRY_TYPE & type, Dis_info *info) { return Disassemble(data, dis, type, MAJOR, 2, info); } -static int nanomips_dis(char *buf, +static int nanomips_dis(char **buf, Dis_info *info, unsigned short one, unsigned short two, unsigned short three) { - std::string disasm; uint16 bits[3] = {one, two, three}; TABLE_ENTRY_TYPE type; - int size = Disassemble(bits, disasm, type, info); - - strcpy(buf, disasm.c_str()); + int size = Disassemble(bits, buf, type, info); return size; } @@ -22283,7 +22181,7 @@ int print_insn_nanomips(bfd_vma memaddr, struct disassemble_info *info) int status; bfd_byte buffer[2]; uint16_t insn1 = 0, insn2 = 0, insn3 = 0; - char buf[200]; + char *buf = NULL; info->bytes_per_chunk = 2; info->display_endian = info->endian; @@ -22345,7 +22243,7 @@ int print_insn_nanomips(bfd_vma memaddr, struct disassemble_info *info) (*info->fprintf_func)(info->stream, " "); } - int length = nanomips_dis(buf, &disassm_info, insn1, insn2, insn3); + int length = nanomips_dis(&buf, &disassm_info, insn1, insn2, insn3); /* FIXME: Should probably use a hash table on the major opcode here. */ |