mirror of
https://github.com/darlinghq/darling-gdb.git
synced 2025-01-23 09:55:31 +00:00
regenerate cgen-based files
This commit is contained in:
parent
fee1d3e815
commit
c5351010e0
@ -1,3 +1,7 @@
|
||||
2010-02-12 Doug Evans <dje@sebabeach.org>
|
||||
|
||||
* decode.c, * decode.h: Regenerate.
|
||||
|
||||
2010-02-11 Doug Evans <dje@sebabeach.org>
|
||||
|
||||
* cpu.h, * decode.c, * model.c, * sem.c: Regenerate.
|
||||
|
401
sim/frv/decode.c
401
sim/frv/decode.c
@ -64,7 +64,7 @@ static const struct insn_sem frvbf_insn_sem[] =
|
||||
{ FRV_INSN_SLL, FRVBF_INSN_SLL, FRVBF_SFMT_ADD },
|
||||
{ FRV_INSN_SRL, FRVBF_INSN_SRL, FRVBF_SFMT_ADD },
|
||||
{ FRV_INSN_SRA, FRVBF_INSN_SRA, FRVBF_SFMT_ADD },
|
||||
{ FRV_INSN_SLASS, FRVBF_INSN_SLASS, FRVBF_SFMT_ADD },
|
||||
{ FRV_INSN_SLASS, FRVBF_INSN_SLASS, FRVBF_SFMT_SLASS },
|
||||
{ FRV_INSN_SCUTSS, FRVBF_INSN_SCUTSS, FRVBF_SFMT_SCUTSS },
|
||||
{ FRV_INSN_SCAN, FRVBF_INSN_SCAN, FRVBF_SFMT_ADD },
|
||||
{ FRV_INSN_CADD, FRVBF_INSN_CADD, FRVBF_SFMT_CADD },
|
||||
@ -103,8 +103,8 @@ static const struct insn_sem frvbf_insn_sem[] =
|
||||
{ FRV_INSN_SUBX, FRVBF_INSN_SUBX, FRVBF_SFMT_ADDX },
|
||||
{ FRV_INSN_ADDXCC, FRVBF_INSN_ADDXCC, FRVBF_SFMT_ADDCC },
|
||||
{ FRV_INSN_SUBXCC, FRVBF_INSN_SUBXCC, FRVBF_SFMT_ADDCC },
|
||||
{ FRV_INSN_ADDSS, FRVBF_INSN_ADDSS, FRVBF_SFMT_ADD },
|
||||
{ FRV_INSN_SUBSS, FRVBF_INSN_SUBSS, FRVBF_SFMT_ADD },
|
||||
{ FRV_INSN_ADDSS, FRVBF_INSN_ADDSS, FRVBF_SFMT_SLASS },
|
||||
{ FRV_INSN_SUBSS, FRVBF_INSN_SUBSS, FRVBF_SFMT_SLASS },
|
||||
{ FRV_INSN_ADDI, FRVBF_INSN_ADDI, FRVBF_SFMT_ADDI },
|
||||
{ FRV_INSN_SUBI, FRVBF_INSN_SUBI, FRVBF_SFMT_ADDI },
|
||||
{ FRV_INSN_ANDI, FRVBF_INSN_ANDI, FRVBF_SFMT_ADDI },
|
||||
@ -322,8 +322,8 @@ static const struct insn_sem frvbf_insn_sem[] =
|
||||
{ FRV_INSN_BP, FRVBF_INSN_BP, FRVBF_SFMT_BEQ },
|
||||
{ FRV_INSN_BV, FRVBF_INSN_BV, FRVBF_SFMT_BEQ },
|
||||
{ FRV_INSN_BNV, FRVBF_INSN_BNV, FRVBF_SFMT_BEQ },
|
||||
{ FRV_INSN_FBRA, FRVBF_INSN_FBRA, FRVBF_SFMT_BRA },
|
||||
{ FRV_INSN_FBNO, FRVBF_INSN_FBNO, FRVBF_SFMT_BNO },
|
||||
{ FRV_INSN_FBRA, FRVBF_INSN_FBRA, FRVBF_SFMT_FBRA },
|
||||
{ FRV_INSN_FBNO, FRVBF_INSN_FBNO, FRVBF_SFMT_FBNO },
|
||||
{ FRV_INSN_FBNE, FRVBF_INSN_FBNE, FRVBF_SFMT_FBNE },
|
||||
{ FRV_INSN_FBEQ, FRVBF_INSN_FBEQ, FRVBF_SFMT_FBNE },
|
||||
{ FRV_INSN_FBLG, FRVBF_INSN_FBLG, FRVBF_SFMT_FBNE },
|
||||
@ -355,8 +355,8 @@ static const struct insn_sem frvbf_insn_sem[] =
|
||||
{ FRV_INSN_BPLR, FRVBF_INSN_BPLR, FRVBF_SFMT_BEQLR },
|
||||
{ FRV_INSN_BVLR, FRVBF_INSN_BVLR, FRVBF_SFMT_BEQLR },
|
||||
{ FRV_INSN_BNVLR, FRVBF_INSN_BNVLR, FRVBF_SFMT_BEQLR },
|
||||
{ FRV_INSN_FBRALR, FRVBF_INSN_FBRALR, FRVBF_SFMT_BRALR },
|
||||
{ FRV_INSN_FBNOLR, FRVBF_INSN_FBNOLR, FRVBF_SFMT_BNOLR },
|
||||
{ FRV_INSN_FBRALR, FRVBF_INSN_FBRALR, FRVBF_SFMT_FBRALR },
|
||||
{ FRV_INSN_FBNOLR, FRVBF_INSN_FBNOLR, FRVBF_SFMT_FBNOLR },
|
||||
{ FRV_INSN_FBEQLR, FRVBF_INSN_FBEQLR, FRVBF_SFMT_FBEQLR },
|
||||
{ FRV_INSN_FBNELR, FRVBF_INSN_FBNELR, FRVBF_SFMT_FBEQLR },
|
||||
{ FRV_INSN_FBLGLR, FRVBF_INSN_FBLGLR, FRVBF_SFMT_FBEQLR },
|
||||
@ -387,8 +387,8 @@ static const struct insn_sem frvbf_insn_sem[] =
|
||||
{ FRV_INSN_BCPLR, FRVBF_INSN_BCPLR, FRVBF_SFMT_BCEQLR },
|
||||
{ FRV_INSN_BCVLR, FRVBF_INSN_BCVLR, FRVBF_SFMT_BCEQLR },
|
||||
{ FRV_INSN_BCNVLR, FRVBF_INSN_BCNVLR, FRVBF_SFMT_BCEQLR },
|
||||
{ FRV_INSN_FCBRALR, FRVBF_INSN_FCBRALR, FRVBF_SFMT_BCRALR },
|
||||
{ FRV_INSN_FCBNOLR, FRVBF_INSN_FCBNOLR, FRVBF_SFMT_BCNOLR },
|
||||
{ FRV_INSN_FCBRALR, FRVBF_INSN_FCBRALR, FRVBF_SFMT_FCBRALR },
|
||||
{ FRV_INSN_FCBNOLR, FRVBF_INSN_FCBNOLR, FRVBF_SFMT_FCBNOLR },
|
||||
{ FRV_INSN_FCBEQLR, FRVBF_INSN_FCBEQLR, FRVBF_SFMT_FCBEQLR },
|
||||
{ FRV_INSN_FCBNELR, FRVBF_INSN_FCBNELR, FRVBF_SFMT_FCBEQLR },
|
||||
{ FRV_INSN_FCBLGLR, FRVBF_INSN_FCBLGLR, FRVBF_SFMT_FCBEQLR },
|
||||
@ -404,9 +404,9 @@ static const struct insn_sem frvbf_insn_sem[] =
|
||||
{ FRV_INSN_FCBULR, FRVBF_INSN_FCBULR, FRVBF_SFMT_FCBEQLR },
|
||||
{ FRV_INSN_FCBOLR, FRVBF_INSN_FCBOLR, FRVBF_SFMT_FCBEQLR },
|
||||
{ FRV_INSN_JMPL, FRVBF_INSN_JMPL, FRVBF_SFMT_JMPL },
|
||||
{ FRV_INSN_CALLL, FRVBF_INSN_CALLL, FRVBF_SFMT_JMPL },
|
||||
{ FRV_INSN_CALLL, FRVBF_INSN_CALLL, FRVBF_SFMT_CALLL },
|
||||
{ FRV_INSN_JMPIL, FRVBF_INSN_JMPIL, FRVBF_SFMT_JMPIL },
|
||||
{ FRV_INSN_CALLIL, FRVBF_INSN_CALLIL, FRVBF_SFMT_JMPIL },
|
||||
{ FRV_INSN_CALLIL, FRVBF_INSN_CALLIL, FRVBF_SFMT_CALLIL },
|
||||
{ FRV_INSN_CALL, FRVBF_INSN_CALL, FRVBF_SFMT_CALL },
|
||||
{ FRV_INSN_RETT, FRVBF_INSN_RETT, FRVBF_SFMT_RETT },
|
||||
{ FRV_INSN_REI, FRVBF_INSN_REI, FRVBF_SFMT_REI },
|
||||
@ -426,7 +426,7 @@ static const struct insn_sem frvbf_insn_sem[] =
|
||||
{ FRV_INSN_TP, FRVBF_INSN_TP, FRVBF_SFMT_TEQ },
|
||||
{ FRV_INSN_TV, FRVBF_INSN_TV, FRVBF_SFMT_TEQ },
|
||||
{ FRV_INSN_TNV, FRVBF_INSN_TNV, FRVBF_SFMT_TEQ },
|
||||
{ FRV_INSN_FTRA, FRVBF_INSN_FTRA, FRVBF_SFMT_TRA },
|
||||
{ FRV_INSN_FTRA, FRVBF_INSN_FTRA, FRVBF_SFMT_FTRA },
|
||||
{ FRV_INSN_FTNO, FRVBF_INSN_FTNO, FRVBF_SFMT_REI },
|
||||
{ FRV_INSN_FTNE, FRVBF_INSN_FTNE, FRVBF_SFMT_FTNE },
|
||||
{ FRV_INSN_FTEQ, FRVBF_INSN_FTEQ, FRVBF_SFMT_FTNE },
|
||||
@ -458,7 +458,7 @@ static const struct insn_sem frvbf_insn_sem[] =
|
||||
{ FRV_INSN_TIP, FRVBF_INSN_TIP, FRVBF_SFMT_TIEQ },
|
||||
{ FRV_INSN_TIV, FRVBF_INSN_TIV, FRVBF_SFMT_TIEQ },
|
||||
{ FRV_INSN_TINV, FRVBF_INSN_TINV, FRVBF_SFMT_TIEQ },
|
||||
{ FRV_INSN_FTIRA, FRVBF_INSN_FTIRA, FRVBF_SFMT_TIRA },
|
||||
{ FRV_INSN_FTIRA, FRVBF_INSN_FTIRA, FRVBF_SFMT_FTIRA },
|
||||
{ FRV_INSN_FTINO, FRVBF_INSN_FTINO, FRVBF_SFMT_REI },
|
||||
{ FRV_INSN_FTINE, FRVBF_INSN_FTINE, FRVBF_SFMT_FTINE },
|
||||
{ FRV_INSN_FTIEQ, FRVBF_INSN_FTIEQ, FRVBF_SFMT_FTINE },
|
||||
@ -551,7 +551,7 @@ static const struct insn_sem frvbf_insn_sem[] =
|
||||
{ FRV_INSN_CFCKU, FRVBF_INSN_CFCKU, FRVBF_SFMT_CFCKNE },
|
||||
{ FRV_INSN_CFCKO, FRVBF_INSN_CFCKO, FRVBF_SFMT_CFCKNE },
|
||||
{ FRV_INSN_CJMPL, FRVBF_INSN_CJMPL, FRVBF_SFMT_CJMPL },
|
||||
{ FRV_INSN_CCALLL, FRVBF_INSN_CCALLL, FRVBF_SFMT_CJMPL },
|
||||
{ FRV_INSN_CCALLL, FRVBF_INSN_CCALLL, FRVBF_SFMT_CCALLL },
|
||||
{ FRV_INSN_ICI, FRVBF_INSN_ICI, FRVBF_SFMT_ICI },
|
||||
{ FRV_INSN_DCI, FRVBF_INSN_DCI, FRVBF_SFMT_ICI },
|
||||
{ FRV_INSN_ICEI, FRVBF_INSN_ICEI, FRVBF_SFMT_ICEI },
|
||||
@ -1299,7 +1299,7 @@ frvbf_decode (SIM_CPU *current_cpu, IADDR pc,
|
||||
itype = FRVBF_INSN_X_INVALID; goto extract_sfmt_empty;
|
||||
case 61 :
|
||||
if ((entire_insn & 0x7ffc0fc0) == 0x78100040)
|
||||
{ itype = FRVBF_INSN_FTRA; goto extract_sfmt_tra; }
|
||||
{ itype = FRVBF_INSN_FTRA; goto extract_sfmt_ftra; }
|
||||
itype = FRVBF_INSN_X_INVALID; goto extract_sfmt_empty;
|
||||
default : itype = FRVBF_INSN_X_INVALID; goto extract_sfmt_empty;
|
||||
}
|
||||
@ -1345,7 +1345,7 @@ frvbf_decode (SIM_CPU *current_cpu, IADDR pc,
|
||||
{
|
||||
case 0 :
|
||||
if ((entire_insn & 0x7ffcffff) == 0x1c0000)
|
||||
{ itype = FRVBF_INSN_FBNO; goto extract_sfmt_bno; }
|
||||
{ itype = FRVBF_INSN_FBNO; goto extract_sfmt_fbno; }
|
||||
itype = FRVBF_INSN_X_INVALID; goto extract_sfmt_empty;
|
||||
case 1 : itype = FRVBF_INSN_FBU; goto extract_sfmt_fbne;
|
||||
case 2 : itype = FRVBF_INSN_FBGT; goto extract_sfmt_fbne;
|
||||
@ -1363,7 +1363,7 @@ frvbf_decode (SIM_CPU *current_cpu, IADDR pc,
|
||||
case 14 : itype = FRVBF_INSN_FBO; goto extract_sfmt_fbne;
|
||||
case 15 :
|
||||
if ((entire_insn & 0x7ffc0000) == 0x781c0000)
|
||||
{ itype = FRVBF_INSN_FBRA; goto extract_sfmt_bra; }
|
||||
{ itype = FRVBF_INSN_FBRA; goto extract_sfmt_fbra; }
|
||||
itype = FRVBF_INSN_X_INVALID; goto extract_sfmt_empty;
|
||||
default : itype = FRVBF_INSN_X_INVALID; goto extract_sfmt_empty;
|
||||
}
|
||||
@ -1607,7 +1607,7 @@ frvbf_decode (SIM_CPU *current_cpu, IADDR pc,
|
||||
itype = FRVBF_INSN_X_INVALID; goto extract_sfmt_empty;
|
||||
case 1 :
|
||||
if ((entire_insn & 0x7ffc0fc0) == 0x2300000)
|
||||
{ itype = FRVBF_INSN_CALLL; goto extract_sfmt_jmpl; }
|
||||
{ itype = FRVBF_INSN_CALLL; goto extract_sfmt_calll; }
|
||||
itype = FRVBF_INSN_X_INVALID; goto extract_sfmt_empty;
|
||||
default : itype = FRVBF_INSN_X_INVALID; goto extract_sfmt_empty;
|
||||
}
|
||||
@ -1623,7 +1623,7 @@ frvbf_decode (SIM_CPU *current_cpu, IADDR pc,
|
||||
itype = FRVBF_INSN_X_INVALID; goto extract_sfmt_empty;
|
||||
case 1 :
|
||||
if ((entire_insn & 0x7ffc0000) == 0x2340000)
|
||||
{ itype = FRVBF_INSN_CALLIL; goto extract_sfmt_jmpil; }
|
||||
{ itype = FRVBF_INSN_CALLIL; goto extract_sfmt_callil; }
|
||||
itype = FRVBF_INSN_X_INVALID; goto extract_sfmt_empty;
|
||||
default : itype = FRVBF_INSN_X_INVALID; goto extract_sfmt_empty;
|
||||
}
|
||||
@ -1655,11 +1655,11 @@ frvbf_decode (SIM_CPU *current_cpu, IADDR pc,
|
||||
}
|
||||
case 2 :
|
||||
if ((entire_insn & 0x7ffcffff) == 0x38c000)
|
||||
{ itype = FRVBF_INSN_FBNOLR; goto extract_sfmt_bnolr; }
|
||||
{ itype = FRVBF_INSN_FBNOLR; goto extract_sfmt_fbnolr; }
|
||||
itype = FRVBF_INSN_X_INVALID; goto extract_sfmt_empty;
|
||||
case 3 :
|
||||
if ((entire_insn & 0x7ffcffff) == 0x38e000)
|
||||
{ itype = FRVBF_INSN_FCBNOLR; goto extract_sfmt_bcnolr; }
|
||||
{ itype = FRVBF_INSN_FCBNOLR; goto extract_sfmt_fcbnolr; }
|
||||
itype = FRVBF_INSN_X_INVALID; goto extract_sfmt_empty;
|
||||
case 4 :
|
||||
if ((entire_insn & 0x79fcffff) == 0x8384000)
|
||||
@ -1895,11 +1895,11 @@ frvbf_decode (SIM_CPU *current_cpu, IADDR pc,
|
||||
itype = FRVBF_INSN_X_INVALID; goto extract_sfmt_empty;
|
||||
case 62 :
|
||||
if ((entire_insn & 0x7ffcffff) == 0x7838c000)
|
||||
{ itype = FRVBF_INSN_FBRALR; goto extract_sfmt_bralr; }
|
||||
{ itype = FRVBF_INSN_FBRALR; goto extract_sfmt_fbralr; }
|
||||
itype = FRVBF_INSN_X_INVALID; goto extract_sfmt_empty;
|
||||
case 63 :
|
||||
if ((entire_insn & 0x7ffcefff) == 0x7838e000)
|
||||
{ itype = FRVBF_INSN_FCBRALR; goto extract_sfmt_bcralr; }
|
||||
{ itype = FRVBF_INSN_FCBRALR; goto extract_sfmt_fcbralr; }
|
||||
itype = FRVBF_INSN_X_INVALID; goto extract_sfmt_empty;
|
||||
default : itype = FRVBF_INSN_X_INVALID; goto extract_sfmt_empty;
|
||||
}
|
||||
@ -1972,7 +1972,7 @@ frvbf_decode (SIM_CPU *current_cpu, IADDR pc,
|
||||
case 14 : itype = FRVBF_INSN_FTIO; goto extract_sfmt_ftine;
|
||||
case 15 :
|
||||
if ((entire_insn & 0x7ffc0000) == 0x78740000)
|
||||
{ itype = FRVBF_INSN_FTIRA; goto extract_sfmt_tira; }
|
||||
{ itype = FRVBF_INSN_FTIRA; goto extract_sfmt_ftira; }
|
||||
itype = FRVBF_INSN_X_INVALID; goto extract_sfmt_empty;
|
||||
default : itype = FRVBF_INSN_X_INVALID; goto extract_sfmt_empty;
|
||||
}
|
||||
@ -2034,15 +2034,15 @@ frvbf_decode (SIM_CPU *current_cpu, IADDR pc,
|
||||
{
|
||||
case 0 :
|
||||
if ((entire_insn & 0x1fc0fc0) == 0x1180000)
|
||||
{ itype = FRVBF_INSN_ADDSS; goto extract_sfmt_add; }
|
||||
{ itype = FRVBF_INSN_ADDSS; goto extract_sfmt_slass; }
|
||||
itype = FRVBF_INSN_X_INVALID; goto extract_sfmt_empty;
|
||||
case 1 :
|
||||
if ((entire_insn & 0x1fc0fc0) == 0x1180040)
|
||||
{ itype = FRVBF_INSN_SUBSS; goto extract_sfmt_add; }
|
||||
{ itype = FRVBF_INSN_SUBSS; goto extract_sfmt_slass; }
|
||||
itype = FRVBF_INSN_X_INVALID; goto extract_sfmt_empty;
|
||||
case 2 :
|
||||
if ((entire_insn & 0x1fc0fc0) == 0x1180080)
|
||||
{ itype = FRVBF_INSN_SLASS; goto extract_sfmt_add; }
|
||||
{ itype = FRVBF_INSN_SLASS; goto extract_sfmt_slass; }
|
||||
itype = FRVBF_INSN_X_INVALID; goto extract_sfmt_empty;
|
||||
case 4 :
|
||||
if ((entire_insn & 0x1ffffc0) == 0x1180100)
|
||||
@ -2326,7 +2326,7 @@ frvbf_decode (SIM_CPU *current_cpu, IADDR pc,
|
||||
itype = FRVBF_INSN_X_INVALID; goto extract_sfmt_empty;
|
||||
case 3 :
|
||||
if ((entire_insn & 0x7ffc00c0) == 0x3a80080)
|
||||
{ itype = FRVBF_INSN_CCALLL; goto extract_sfmt_cjmpl; }
|
||||
{ itype = FRVBF_INSN_CCALLL; goto extract_sfmt_ccalll; }
|
||||
itype = FRVBF_INSN_X_INVALID; goto extract_sfmt_empty;
|
||||
default : itype = FRVBF_INSN_X_INVALID; goto extract_sfmt_empty;
|
||||
}
|
||||
@ -3440,6 +3440,38 @@ frvbf_decode (SIM_CPU *current_cpu, IADDR pc,
|
||||
FLD (out_h_iacc0_DI_0) = 0;
|
||||
}
|
||||
#endif
|
||||
#undef FLD
|
||||
return idesc;
|
||||
}
|
||||
|
||||
extract_sfmt_slass:
|
||||
{
|
||||
const IDESC *idesc = &frvbf_insn_data[itype];
|
||||
CGEN_INSN_WORD insn = entire_insn;
|
||||
#define FLD(f) abuf->fields.sfmt_addcc.f
|
||||
UINT f_GRk;
|
||||
UINT f_GRi;
|
||||
UINT f_GRj;
|
||||
|
||||
f_GRk = EXTRACT_LSB0_UINT (insn, 32, 30, 6);
|
||||
f_GRi = EXTRACT_LSB0_UINT (insn, 32, 17, 6);
|
||||
f_GRj = EXTRACT_LSB0_UINT (insn, 32, 5, 6);
|
||||
|
||||
/* Record the fields for the semantic handler. */
|
||||
FLD (f_GRi) = f_GRi;
|
||||
FLD (f_GRj) = f_GRj;
|
||||
FLD (f_GRk) = f_GRk;
|
||||
TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_slass", "f_GRi 0x%x", 'x', f_GRi, "f_GRj 0x%x", 'x', f_GRj, "f_GRk 0x%x", 'x', f_GRk, (char *) 0));
|
||||
|
||||
#if WITH_PROFILE_MODEL_P
|
||||
/* Record the fields for profiling. */
|
||||
if (PROFILE_MODEL_P (current_cpu))
|
||||
{
|
||||
FLD (in_GRi) = f_GRi;
|
||||
FLD (in_GRj) = f_GRj;
|
||||
FLD (out_GRk) = f_GRk;
|
||||
}
|
||||
#endif
|
||||
#undef FLD
|
||||
return idesc;
|
||||
}
|
||||
@ -7334,6 +7366,52 @@ frvbf_decode (SIM_CPU *current_cpu, IADDR pc,
|
||||
FLD (in_ICCi_2) = f_ICCi_2;
|
||||
}
|
||||
#endif
|
||||
#undef FLD
|
||||
return idesc;
|
||||
}
|
||||
|
||||
extract_sfmt_fbra:
|
||||
{
|
||||
const IDESC *idesc = &frvbf_insn_data[itype];
|
||||
CGEN_INSN_WORD insn = entire_insn;
|
||||
#define FLD(f) abuf->fields.sfmt_fbne.f
|
||||
UINT f_hint;
|
||||
SI f_label16;
|
||||
|
||||
f_hint = EXTRACT_LSB0_UINT (insn, 32, 17, 2);
|
||||
f_label16 = ((((EXTRACT_LSB0_SINT (insn, 32, 15, 16)) << (2))) + (pc));
|
||||
|
||||
/* Record the fields for the semantic handler. */
|
||||
FLD (f_hint) = f_hint;
|
||||
FLD (i_label16) = f_label16;
|
||||
TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_fbra", "f_hint 0x%x", 'x', f_hint, "label16 0x%x", 'x', f_label16, (char *) 0));
|
||||
|
||||
#if WITH_PROFILE_MODEL_P
|
||||
/* Record the fields for profiling. */
|
||||
if (PROFILE_MODEL_P (current_cpu))
|
||||
{
|
||||
}
|
||||
#endif
|
||||
#undef FLD
|
||||
return idesc;
|
||||
}
|
||||
|
||||
extract_sfmt_fbno:
|
||||
{
|
||||
const IDESC *idesc = &frvbf_insn_data[itype];
|
||||
CGEN_INSN_WORD insn = entire_insn;
|
||||
#define FLD(f) abuf->fields.sfmt_fbne.f
|
||||
UINT f_hint;
|
||||
SI f_label16;
|
||||
|
||||
f_hint = EXTRACT_LSB0_UINT (insn, 32, 17, 2);
|
||||
f_label16 = ((((EXTRACT_LSB0_SINT (insn, 32, 15, 16)) << (2))) + (pc));
|
||||
|
||||
/* Record the fields for the semantic handler. */
|
||||
FLD (f_hint) = f_hint;
|
||||
FLD (i_label16) = f_label16;
|
||||
TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_fbno", "f_hint 0x%x", 'x', f_hint, "label16 0x%x", 'x', f_label16, (char *) 0));
|
||||
|
||||
#undef FLD
|
||||
return idesc;
|
||||
}
|
||||
@ -7469,6 +7547,54 @@ frvbf_decode (SIM_CPU *current_cpu, IADDR pc,
|
||||
FLD (in_h_spr_USI_272) = 272;
|
||||
}
|
||||
#endif
|
||||
#undef FLD
|
||||
return idesc;
|
||||
}
|
||||
|
||||
extract_sfmt_fbralr:
|
||||
{
|
||||
const IDESC *idesc = &frvbf_insn_data[itype];
|
||||
CGEN_INSN_WORD insn = entire_insn;
|
||||
#define FLD(f) abuf->fields.sfmt_fcbeqlr.f
|
||||
UINT f_hint;
|
||||
|
||||
f_hint = EXTRACT_LSB0_UINT (insn, 32, 17, 2);
|
||||
|
||||
/* Record the fields for the semantic handler. */
|
||||
FLD (f_hint) = f_hint;
|
||||
TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_fbralr", "f_hint 0x%x", 'x', f_hint, (char *) 0));
|
||||
|
||||
#if WITH_PROFILE_MODEL_P
|
||||
/* Record the fields for profiling. */
|
||||
if (PROFILE_MODEL_P (current_cpu))
|
||||
{
|
||||
FLD (in_h_spr_USI_272) = 272;
|
||||
}
|
||||
#endif
|
||||
#undef FLD
|
||||
return idesc;
|
||||
}
|
||||
|
||||
extract_sfmt_fbnolr:
|
||||
{
|
||||
const IDESC *idesc = &frvbf_insn_data[itype];
|
||||
CGEN_INSN_WORD insn = entire_insn;
|
||||
#define FLD(f) abuf->fields.sfmt_fcbeqlr.f
|
||||
UINT f_hint;
|
||||
|
||||
f_hint = EXTRACT_LSB0_UINT (insn, 32, 17, 2);
|
||||
|
||||
/* Record the fields for the semantic handler. */
|
||||
FLD (f_hint) = f_hint;
|
||||
TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_fbnolr", "f_hint 0x%x", 'x', f_hint, (char *) 0));
|
||||
|
||||
#if WITH_PROFILE_MODEL_P
|
||||
/* Record the fields for profiling. */
|
||||
if (PROFILE_MODEL_P (current_cpu))
|
||||
{
|
||||
FLD (in_h_spr_USI_272) = 272;
|
||||
}
|
||||
#endif
|
||||
#undef FLD
|
||||
return idesc;
|
||||
}
|
||||
@ -7585,6 +7711,61 @@ frvbf_decode (SIM_CPU *current_cpu, IADDR pc,
|
||||
FLD (out_h_spr_USI_273) = 273;
|
||||
}
|
||||
#endif
|
||||
#undef FLD
|
||||
return idesc;
|
||||
}
|
||||
|
||||
extract_sfmt_fcbralr:
|
||||
{
|
||||
const IDESC *idesc = &frvbf_insn_data[itype];
|
||||
CGEN_INSN_WORD insn = entire_insn;
|
||||
#define FLD(f) abuf->fields.sfmt_fcbeqlr.f
|
||||
UINT f_hint;
|
||||
UINT f_ccond;
|
||||
|
||||
f_hint = EXTRACT_LSB0_UINT (insn, 32, 17, 2);
|
||||
f_ccond = EXTRACT_LSB0_UINT (insn, 32, 12, 1);
|
||||
|
||||
/* Record the fields for the semantic handler. */
|
||||
FLD (f_ccond) = f_ccond;
|
||||
FLD (f_hint) = f_hint;
|
||||
TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_fcbralr", "f_ccond 0x%x", 'x', f_ccond, "f_hint 0x%x", 'x', f_hint, (char *) 0));
|
||||
|
||||
#if WITH_PROFILE_MODEL_P
|
||||
/* Record the fields for profiling. */
|
||||
if (PROFILE_MODEL_P (current_cpu))
|
||||
{
|
||||
FLD (in_h_spr_USI_272) = 272;
|
||||
FLD (in_h_spr_USI_273) = 273;
|
||||
FLD (out_h_spr_USI_273) = 273;
|
||||
}
|
||||
#endif
|
||||
#undef FLD
|
||||
return idesc;
|
||||
}
|
||||
|
||||
extract_sfmt_fcbnolr:
|
||||
{
|
||||
const IDESC *idesc = &frvbf_insn_data[itype];
|
||||
CGEN_INSN_WORD insn = entire_insn;
|
||||
#define FLD(f) abuf->fields.sfmt_fcbeqlr.f
|
||||
UINT f_hint;
|
||||
|
||||
f_hint = EXTRACT_LSB0_UINT (insn, 32, 17, 2);
|
||||
|
||||
/* Record the fields for the semantic handler. */
|
||||
FLD (f_hint) = f_hint;
|
||||
TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_fcbnolr", "f_hint 0x%x", 'x', f_hint, (char *) 0));
|
||||
|
||||
#if WITH_PROFILE_MODEL_P
|
||||
/* Record the fields for profiling. */
|
||||
if (PROFILE_MODEL_P (current_cpu))
|
||||
{
|
||||
FLD (in_h_spr_USI_272) = 272;
|
||||
FLD (in_h_spr_USI_273) = 273;
|
||||
FLD (out_h_spr_USI_273) = 273;
|
||||
}
|
||||
#endif
|
||||
#undef FLD
|
||||
return idesc;
|
||||
}
|
||||
@ -7641,6 +7822,37 @@ frvbf_decode (SIM_CPU *current_cpu, IADDR pc,
|
||||
FLD (f_LI) = f_LI;
|
||||
TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_jmpl", "f_GRi 0x%x", 'x', f_GRi, "f_GRj 0x%x", 'x', f_GRj, "f_LI 0x%x", 'x', f_LI, (char *) 0));
|
||||
|
||||
#if WITH_PROFILE_MODEL_P
|
||||
/* Record the fields for profiling. */
|
||||
if (PROFILE_MODEL_P (current_cpu))
|
||||
{
|
||||
FLD (in_GRi) = f_GRi;
|
||||
FLD (in_GRj) = f_GRj;
|
||||
}
|
||||
#endif
|
||||
#undef FLD
|
||||
return idesc;
|
||||
}
|
||||
|
||||
extract_sfmt_calll:
|
||||
{
|
||||
const IDESC *idesc = &frvbf_insn_data[itype];
|
||||
CGEN_INSN_WORD insn = entire_insn;
|
||||
#define FLD(f) abuf->fields.sfmt_cjmpl.f
|
||||
UINT f_LI;
|
||||
UINT f_GRi;
|
||||
UINT f_GRj;
|
||||
|
||||
f_LI = EXTRACT_LSB0_UINT (insn, 32, 25, 1);
|
||||
f_GRi = EXTRACT_LSB0_UINT (insn, 32, 17, 6);
|
||||
f_GRj = EXTRACT_LSB0_UINT (insn, 32, 5, 6);
|
||||
|
||||
/* Record the fields for the semantic handler. */
|
||||
FLD (f_GRi) = f_GRi;
|
||||
FLD (f_GRj) = f_GRj;
|
||||
FLD (f_LI) = f_LI;
|
||||
TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_calll", "f_GRi 0x%x", 'x', f_GRi, "f_GRj 0x%x", 'x', f_GRj, "f_LI 0x%x", 'x', f_LI, (char *) 0));
|
||||
|
||||
#if WITH_PROFILE_MODEL_P
|
||||
/* Record the fields for profiling. */
|
||||
if (PROFILE_MODEL_P (current_cpu))
|
||||
@ -7672,6 +7884,36 @@ frvbf_decode (SIM_CPU *current_cpu, IADDR pc,
|
||||
FLD (f_d12) = f_d12;
|
||||
TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_jmpil", "f_GRi 0x%x", 'x', f_GRi, "f_LI 0x%x", 'x', f_LI, "f_d12 0x%x", 'x', f_d12, (char *) 0));
|
||||
|
||||
#if WITH_PROFILE_MODEL_P
|
||||
/* Record the fields for profiling. */
|
||||
if (PROFILE_MODEL_P (current_cpu))
|
||||
{
|
||||
FLD (in_GRi) = f_GRi;
|
||||
}
|
||||
#endif
|
||||
#undef FLD
|
||||
return idesc;
|
||||
}
|
||||
|
||||
extract_sfmt_callil:
|
||||
{
|
||||
const IDESC *idesc = &frvbf_insn_data[itype];
|
||||
CGEN_INSN_WORD insn = entire_insn;
|
||||
#define FLD(f) abuf->fields.sfmt_jmpil.f
|
||||
UINT f_LI;
|
||||
UINT f_GRi;
|
||||
INT f_d12;
|
||||
|
||||
f_LI = EXTRACT_LSB0_UINT (insn, 32, 25, 1);
|
||||
f_GRi = EXTRACT_LSB0_UINT (insn, 32, 17, 6);
|
||||
f_d12 = EXTRACT_LSB0_SINT (insn, 32, 11, 12);
|
||||
|
||||
/* Record the fields for the semantic handler. */
|
||||
FLD (f_GRi) = f_GRi;
|
||||
FLD (f_LI) = f_LI;
|
||||
FLD (f_d12) = f_d12;
|
||||
TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_callil", "f_GRi 0x%x", 'x', f_GRi, "f_LI 0x%x", 'x', f_LI, "f_d12 0x%x", 'x', f_d12, (char *) 0));
|
||||
|
||||
#if WITH_PROFILE_MODEL_P
|
||||
/* Record the fields for profiling. */
|
||||
if (PROFILE_MODEL_P (current_cpu))
|
||||
@ -7814,6 +8056,39 @@ frvbf_decode (SIM_CPU *current_cpu, IADDR pc,
|
||||
FLD (out_h_spr_USI_771) = 771;
|
||||
}
|
||||
#endif
|
||||
#undef FLD
|
||||
return idesc;
|
||||
}
|
||||
|
||||
extract_sfmt_ftra:
|
||||
{
|
||||
const IDESC *idesc = &frvbf_insn_data[itype];
|
||||
CGEN_INSN_WORD insn = entire_insn;
|
||||
#define FLD(f) abuf->fields.sfmt_ftne.f
|
||||
UINT f_GRi;
|
||||
UINT f_GRj;
|
||||
|
||||
f_GRi = EXTRACT_LSB0_UINT (insn, 32, 17, 6);
|
||||
f_GRj = EXTRACT_LSB0_UINT (insn, 32, 5, 6);
|
||||
|
||||
/* Record the fields for the semantic handler. */
|
||||
FLD (f_GRi) = f_GRi;
|
||||
FLD (f_GRj) = f_GRj;
|
||||
TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_ftra", "f_GRi 0x%x", 'x', f_GRi, "f_GRj 0x%x", 'x', f_GRj, (char *) 0));
|
||||
|
||||
#if WITH_PROFILE_MODEL_P
|
||||
/* Record the fields for profiling. */
|
||||
if (PROFILE_MODEL_P (current_cpu))
|
||||
{
|
||||
FLD (in_GRi) = f_GRi;
|
||||
FLD (in_GRj) = f_GRj;
|
||||
FLD (out_h_spr_USI_1) = 1;
|
||||
FLD (out_h_spr_USI_768) = 768;
|
||||
FLD (out_h_spr_USI_769) = 769;
|
||||
FLD (out_h_spr_USI_770) = 770;
|
||||
FLD (out_h_spr_USI_771) = 771;
|
||||
}
|
||||
#endif
|
||||
#undef FLD
|
||||
return idesc;
|
||||
}
|
||||
@ -7919,6 +8194,38 @@ frvbf_decode (SIM_CPU *current_cpu, IADDR pc,
|
||||
FLD (out_h_spr_USI_771) = 771;
|
||||
}
|
||||
#endif
|
||||
#undef FLD
|
||||
return idesc;
|
||||
}
|
||||
|
||||
extract_sfmt_ftira:
|
||||
{
|
||||
const IDESC *idesc = &frvbf_insn_data[itype];
|
||||
CGEN_INSN_WORD insn = entire_insn;
|
||||
#define FLD(f) abuf->fields.sfmt_ftine.f
|
||||
UINT f_GRi;
|
||||
INT f_d12;
|
||||
|
||||
f_GRi = EXTRACT_LSB0_UINT (insn, 32, 17, 6);
|
||||
f_d12 = EXTRACT_LSB0_SINT (insn, 32, 11, 12);
|
||||
|
||||
/* Record the fields for the semantic handler. */
|
||||
FLD (f_GRi) = f_GRi;
|
||||
FLD (f_d12) = f_d12;
|
||||
TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_ftira", "f_GRi 0x%x", 'x', f_GRi, "f_d12 0x%x", 'x', f_d12, (char *) 0));
|
||||
|
||||
#if WITH_PROFILE_MODEL_P
|
||||
/* Record the fields for profiling. */
|
||||
if (PROFILE_MODEL_P (current_cpu))
|
||||
{
|
||||
FLD (in_GRi) = f_GRi;
|
||||
FLD (out_h_spr_USI_1) = 1;
|
||||
FLD (out_h_spr_USI_768) = 768;
|
||||
FLD (out_h_spr_USI_769) = 769;
|
||||
FLD (out_h_spr_USI_770) = 770;
|
||||
FLD (out_h_spr_USI_771) = 771;
|
||||
}
|
||||
#endif
|
||||
#undef FLD
|
||||
return idesc;
|
||||
}
|
||||
@ -8300,6 +8607,44 @@ frvbf_decode (SIM_CPU *current_cpu, IADDR pc,
|
||||
FLD (f_cond) = f_cond;
|
||||
TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_cjmpl", "f_CCi 0x%x", 'x', f_CCi, "f_GRi 0x%x", 'x', f_GRi, "f_GRj 0x%x", 'x', f_GRj, "f_LI 0x%x", 'x', f_LI, "f_cond 0x%x", 'x', f_cond, (char *) 0));
|
||||
|
||||
#if WITH_PROFILE_MODEL_P
|
||||
/* Record the fields for profiling. */
|
||||
if (PROFILE_MODEL_P (current_cpu))
|
||||
{
|
||||
FLD (in_CCi) = f_CCi;
|
||||
FLD (in_GRi) = f_GRi;
|
||||
FLD (in_GRj) = f_GRj;
|
||||
}
|
||||
#endif
|
||||
#undef FLD
|
||||
return idesc;
|
||||
}
|
||||
|
||||
extract_sfmt_ccalll:
|
||||
{
|
||||
const IDESC *idesc = &frvbf_insn_data[itype];
|
||||
CGEN_INSN_WORD insn = entire_insn;
|
||||
#define FLD(f) abuf->fields.sfmt_cjmpl.f
|
||||
UINT f_LI;
|
||||
UINT f_GRi;
|
||||
UINT f_CCi;
|
||||
UINT f_cond;
|
||||
UINT f_GRj;
|
||||
|
||||
f_LI = EXTRACT_LSB0_UINT (insn, 32, 25, 1);
|
||||
f_GRi = EXTRACT_LSB0_UINT (insn, 32, 17, 6);
|
||||
f_CCi = EXTRACT_LSB0_UINT (insn, 32, 11, 3);
|
||||
f_cond = EXTRACT_LSB0_UINT (insn, 32, 8, 1);
|
||||
f_GRj = EXTRACT_LSB0_UINT (insn, 32, 5, 6);
|
||||
|
||||
/* Record the fields for the semantic handler. */
|
||||
FLD (f_CCi) = f_CCi;
|
||||
FLD (f_GRi) = f_GRi;
|
||||
FLD (f_GRj) = f_GRj;
|
||||
FLD (f_LI) = f_LI;
|
||||
FLD (f_cond) = f_cond;
|
||||
TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_ccalll", "f_CCi 0x%x", 'x', f_CCi, "f_GRi 0x%x", 'x', f_GRi, "f_GRj 0x%x", 'x', f_GRj, "f_LI 0x%x", 'x', f_LI, "f_cond 0x%x", 'x', f_cond, (char *) 0));
|
||||
|
||||
#if WITH_PROFILE_MODEL_P
|
||||
/* Record the fields for profiling. */
|
||||
if (PROFILE_MODEL_P (current_cpu))
|
||||
|
@ -227,44 +227,47 @@ typedef enum frvbf_insn_type {
|
||||
/* Enum declaration for semantic formats in cpu family frvbf. */
|
||||
typedef enum frvbf_sfmt_type {
|
||||
FRVBF_SFMT_EMPTY, FRVBF_SFMT_ADD, FRVBF_SFMT_NOT, FRVBF_SFMT_SDIV
|
||||
, FRVBF_SFMT_SMUL, FRVBF_SFMT_SMU, FRVBF_SFMT_SMASS, FRVBF_SFMT_SCUTSS
|
||||
, FRVBF_SFMT_CADD, FRVBF_SFMT_CNOT, FRVBF_SFMT_CSMUL, FRVBF_SFMT_CSDIV
|
||||
, FRVBF_SFMT_ADDCC, FRVBF_SFMT_ANDCC, FRVBF_SFMT_SMULCC, FRVBF_SFMT_CADDCC
|
||||
, FRVBF_SFMT_CSMULCC, FRVBF_SFMT_ADDX, FRVBF_SFMT_ADDI, FRVBF_SFMT_SDIVI
|
||||
, FRVBF_SFMT_SMULI, FRVBF_SFMT_ADDICC, FRVBF_SFMT_ANDICC, FRVBF_SFMT_SMULICC
|
||||
, FRVBF_SFMT_ADDXI, FRVBF_SFMT_CMPB, FRVBF_SFMT_SETLO, FRVBF_SFMT_SETHI
|
||||
, FRVBF_SFMT_SETLOS, FRVBF_SFMT_LDSB, FRVBF_SFMT_LDBF, FRVBF_SFMT_LDC
|
||||
, FRVBF_SFMT_NLDSB, FRVBF_SFMT_NLDBF, FRVBF_SFMT_LDD, FRVBF_SFMT_LDDF
|
||||
, FRVBF_SFMT_LDDC, FRVBF_SFMT_NLDD, FRVBF_SFMT_NLDDF, FRVBF_SFMT_LDQ
|
||||
, FRVBF_SFMT_LDQF, FRVBF_SFMT_LDQC, FRVBF_SFMT_NLDQ, FRVBF_SFMT_NLDQF
|
||||
, FRVBF_SFMT_LDSBU, FRVBF_SFMT_NLDSBU, FRVBF_SFMT_LDBFU, FRVBF_SFMT_LDCU
|
||||
, FRVBF_SFMT_NLDBFU, FRVBF_SFMT_LDDU, FRVBF_SFMT_NLDDU, FRVBF_SFMT_LDDFU
|
||||
, FRVBF_SFMT_LDDCU, FRVBF_SFMT_NLDDFU, FRVBF_SFMT_LDQU, FRVBF_SFMT_NLDQU
|
||||
, FRVBF_SFMT_LDQFU, FRVBF_SFMT_LDQCU, FRVBF_SFMT_NLDQFU, FRVBF_SFMT_LDSBI
|
||||
, FRVBF_SFMT_LDBFI, FRVBF_SFMT_NLDSBI, FRVBF_SFMT_NLDBFI, FRVBF_SFMT_LDDI
|
||||
, FRVBF_SFMT_LDDFI, FRVBF_SFMT_NLDDI, FRVBF_SFMT_NLDDFI, FRVBF_SFMT_LDQI
|
||||
, FRVBF_SFMT_LDQFI, FRVBF_SFMT_NLDQFI, FRVBF_SFMT_STB, FRVBF_SFMT_STBF
|
||||
, FRVBF_SFMT_STC, FRVBF_SFMT_STD, FRVBF_SFMT_STDF, FRVBF_SFMT_STDC
|
||||
, FRVBF_SFMT_STBU, FRVBF_SFMT_STBFU, FRVBF_SFMT_STCU, FRVBF_SFMT_STDU
|
||||
, FRVBF_SFMT_STDFU, FRVBF_SFMT_STDCU, FRVBF_SFMT_STQU, FRVBF_SFMT_CLDSB
|
||||
, FRVBF_SFMT_CLDBF, FRVBF_SFMT_CLDD, FRVBF_SFMT_CLDDF, FRVBF_SFMT_CLDQ
|
||||
, FRVBF_SFMT_CLDSBU, FRVBF_SFMT_CLDBFU, FRVBF_SFMT_CLDDU, FRVBF_SFMT_CLDDFU
|
||||
, FRVBF_SFMT_CLDQU, FRVBF_SFMT_CSTB, FRVBF_SFMT_CSTBF, FRVBF_SFMT_CSTD
|
||||
, FRVBF_SFMT_CSTDF, FRVBF_SFMT_CSTBU, FRVBF_SFMT_CSTBFU, FRVBF_SFMT_CSTDU
|
||||
, FRVBF_SFMT_CSTDFU, FRVBF_SFMT_STBI, FRVBF_SFMT_STBFI, FRVBF_SFMT_STDI
|
||||
, FRVBF_SFMT_STDFI, FRVBF_SFMT_SWAP, FRVBF_SFMT_SWAPI, FRVBF_SFMT_CSWAP
|
||||
, FRVBF_SFMT_MOVGF, FRVBF_SFMT_MOVFG, FRVBF_SFMT_MOVGFD, FRVBF_SFMT_MOVFGD
|
||||
, FRVBF_SFMT_MOVGFQ, FRVBF_SFMT_MOVFGQ, FRVBF_SFMT_CMOVGF, FRVBF_SFMT_CMOVFG
|
||||
, FRVBF_SFMT_CMOVGFD, FRVBF_SFMT_CMOVFGD, FRVBF_SFMT_MOVGS, FRVBF_SFMT_MOVSG
|
||||
, FRVBF_SFMT_BRA, FRVBF_SFMT_BNO, FRVBF_SFMT_BEQ, FRVBF_SFMT_FBNE
|
||||
, FRVBF_SFMT_BCTRLR, FRVBF_SFMT_BRALR, FRVBF_SFMT_BNOLR, FRVBF_SFMT_BEQLR
|
||||
, FRVBF_SFMT_FBEQLR, FRVBF_SFMT_BCRALR, FRVBF_SFMT_BCNOLR, FRVBF_SFMT_BCEQLR
|
||||
, FRVBF_SFMT_FCBEQLR, FRVBF_SFMT_JMPL, FRVBF_SFMT_JMPIL, FRVBF_SFMT_CALL
|
||||
, FRVBF_SFMT_RETT, FRVBF_SFMT_REI, FRVBF_SFMT_TRA, FRVBF_SFMT_TEQ
|
||||
, FRVBF_SFMT_FTNE, FRVBF_SFMT_TIRA, FRVBF_SFMT_TIEQ, FRVBF_SFMT_FTINE
|
||||
, FRVBF_SFMT_BREAK, FRVBF_SFMT_ANDCR, FRVBF_SFMT_NOTCR, FRVBF_SFMT_CKRA
|
||||
, FRVBF_SFMT_CKEQ, FRVBF_SFMT_FCKRA, FRVBF_SFMT_FCKNE, FRVBF_SFMT_CCKRA
|
||||
, FRVBF_SFMT_CCKEQ, FRVBF_SFMT_CFCKRA, FRVBF_SFMT_CFCKNE, FRVBF_SFMT_CJMPL
|
||||
, FRVBF_SFMT_SMUL, FRVBF_SFMT_SMU, FRVBF_SFMT_SMASS, FRVBF_SFMT_SLASS
|
||||
, FRVBF_SFMT_SCUTSS, FRVBF_SFMT_CADD, FRVBF_SFMT_CNOT, FRVBF_SFMT_CSMUL
|
||||
, FRVBF_SFMT_CSDIV, FRVBF_SFMT_ADDCC, FRVBF_SFMT_ANDCC, FRVBF_SFMT_SMULCC
|
||||
, FRVBF_SFMT_CADDCC, FRVBF_SFMT_CSMULCC, FRVBF_SFMT_ADDX, FRVBF_SFMT_ADDI
|
||||
, FRVBF_SFMT_SDIVI, FRVBF_SFMT_SMULI, FRVBF_SFMT_ADDICC, FRVBF_SFMT_ANDICC
|
||||
, FRVBF_SFMT_SMULICC, FRVBF_SFMT_ADDXI, FRVBF_SFMT_CMPB, FRVBF_SFMT_SETLO
|
||||
, FRVBF_SFMT_SETHI, FRVBF_SFMT_SETLOS, FRVBF_SFMT_LDSB, FRVBF_SFMT_LDBF
|
||||
, FRVBF_SFMT_LDC, FRVBF_SFMT_NLDSB, FRVBF_SFMT_NLDBF, FRVBF_SFMT_LDD
|
||||
, FRVBF_SFMT_LDDF, FRVBF_SFMT_LDDC, FRVBF_SFMT_NLDD, FRVBF_SFMT_NLDDF
|
||||
, FRVBF_SFMT_LDQ, FRVBF_SFMT_LDQF, FRVBF_SFMT_LDQC, FRVBF_SFMT_NLDQ
|
||||
, FRVBF_SFMT_NLDQF, FRVBF_SFMT_LDSBU, FRVBF_SFMT_NLDSBU, FRVBF_SFMT_LDBFU
|
||||
, FRVBF_SFMT_LDCU, FRVBF_SFMT_NLDBFU, FRVBF_SFMT_LDDU, FRVBF_SFMT_NLDDU
|
||||
, FRVBF_SFMT_LDDFU, FRVBF_SFMT_LDDCU, FRVBF_SFMT_NLDDFU, FRVBF_SFMT_LDQU
|
||||
, FRVBF_SFMT_NLDQU, FRVBF_SFMT_LDQFU, FRVBF_SFMT_LDQCU, FRVBF_SFMT_NLDQFU
|
||||
, FRVBF_SFMT_LDSBI, FRVBF_SFMT_LDBFI, FRVBF_SFMT_NLDSBI, FRVBF_SFMT_NLDBFI
|
||||
, FRVBF_SFMT_LDDI, FRVBF_SFMT_LDDFI, FRVBF_SFMT_NLDDI, FRVBF_SFMT_NLDDFI
|
||||
, FRVBF_SFMT_LDQI, FRVBF_SFMT_LDQFI, FRVBF_SFMT_NLDQFI, FRVBF_SFMT_STB
|
||||
, FRVBF_SFMT_STBF, FRVBF_SFMT_STC, FRVBF_SFMT_STD, FRVBF_SFMT_STDF
|
||||
, FRVBF_SFMT_STDC, FRVBF_SFMT_STBU, FRVBF_SFMT_STBFU, FRVBF_SFMT_STCU
|
||||
, FRVBF_SFMT_STDU, FRVBF_SFMT_STDFU, FRVBF_SFMT_STDCU, FRVBF_SFMT_STQU
|
||||
, FRVBF_SFMT_CLDSB, FRVBF_SFMT_CLDBF, FRVBF_SFMT_CLDD, FRVBF_SFMT_CLDDF
|
||||
, FRVBF_SFMT_CLDQ, FRVBF_SFMT_CLDSBU, FRVBF_SFMT_CLDBFU, FRVBF_SFMT_CLDDU
|
||||
, FRVBF_SFMT_CLDDFU, FRVBF_SFMT_CLDQU, FRVBF_SFMT_CSTB, FRVBF_SFMT_CSTBF
|
||||
, FRVBF_SFMT_CSTD, FRVBF_SFMT_CSTDF, FRVBF_SFMT_CSTBU, FRVBF_SFMT_CSTBFU
|
||||
, FRVBF_SFMT_CSTDU, FRVBF_SFMT_CSTDFU, FRVBF_SFMT_STBI, FRVBF_SFMT_STBFI
|
||||
, FRVBF_SFMT_STDI, FRVBF_SFMT_STDFI, FRVBF_SFMT_SWAP, FRVBF_SFMT_SWAPI
|
||||
, FRVBF_SFMT_CSWAP, FRVBF_SFMT_MOVGF, FRVBF_SFMT_MOVFG, FRVBF_SFMT_MOVGFD
|
||||
, FRVBF_SFMT_MOVFGD, FRVBF_SFMT_MOVGFQ, FRVBF_SFMT_MOVFGQ, FRVBF_SFMT_CMOVGF
|
||||
, FRVBF_SFMT_CMOVFG, FRVBF_SFMT_CMOVGFD, FRVBF_SFMT_CMOVFGD, FRVBF_SFMT_MOVGS
|
||||
, FRVBF_SFMT_MOVSG, FRVBF_SFMT_BRA, FRVBF_SFMT_BNO, FRVBF_SFMT_BEQ
|
||||
, FRVBF_SFMT_FBRA, FRVBF_SFMT_FBNO, FRVBF_SFMT_FBNE, FRVBF_SFMT_BCTRLR
|
||||
, FRVBF_SFMT_BRALR, FRVBF_SFMT_BNOLR, FRVBF_SFMT_BEQLR, FRVBF_SFMT_FBRALR
|
||||
, FRVBF_SFMT_FBNOLR, FRVBF_SFMT_FBEQLR, FRVBF_SFMT_BCRALR, FRVBF_SFMT_BCNOLR
|
||||
, FRVBF_SFMT_BCEQLR, FRVBF_SFMT_FCBRALR, FRVBF_SFMT_FCBNOLR, FRVBF_SFMT_FCBEQLR
|
||||
, FRVBF_SFMT_JMPL, FRVBF_SFMT_CALLL, FRVBF_SFMT_JMPIL, FRVBF_SFMT_CALLIL
|
||||
, FRVBF_SFMT_CALL, FRVBF_SFMT_RETT, FRVBF_SFMT_REI, FRVBF_SFMT_TRA
|
||||
, FRVBF_SFMT_TEQ, FRVBF_SFMT_FTRA, FRVBF_SFMT_FTNE, FRVBF_SFMT_TIRA
|
||||
, FRVBF_SFMT_TIEQ, FRVBF_SFMT_FTIRA, FRVBF_SFMT_FTINE, FRVBF_SFMT_BREAK
|
||||
, FRVBF_SFMT_ANDCR, FRVBF_SFMT_NOTCR, FRVBF_SFMT_CKRA, FRVBF_SFMT_CKEQ
|
||||
, FRVBF_SFMT_FCKRA, FRVBF_SFMT_FCKNE, FRVBF_SFMT_CCKRA, FRVBF_SFMT_CCKEQ
|
||||
, FRVBF_SFMT_CFCKRA, FRVBF_SFMT_CFCKNE, FRVBF_SFMT_CJMPL, FRVBF_SFMT_CCALLL
|
||||
, FRVBF_SFMT_ICI, FRVBF_SFMT_ICEI, FRVBF_SFMT_ICPL, FRVBF_SFMT_ICUL
|
||||
, FRVBF_SFMT_CLRGR, FRVBF_SFMT_CLRFR, FRVBF_SFMT_COMMITGR, FRVBF_SFMT_COMMITFR
|
||||
, FRVBF_SFMT_FITOS, FRVBF_SFMT_FSTOI, FRVBF_SFMT_FITOD, FRVBF_SFMT_FDTOI
|
||||
|
@ -1,3 +1,7 @@
|
||||
2010-02-12 Doug Evans <dje@sebabeach.org>
|
||||
|
||||
* decode-media.c, * decode-media.h: Regenerate.
|
||||
|
||||
2010-02-11 Doug Evans <dje@sebabeach.org>
|
||||
|
||||
* decode-compact.c, * decode-media.c, * defs-compact.h, * defs-media.h,
|
||||
|
@ -63,7 +63,7 @@ static const struct insn_sem sh64_media_insn_sem[] =
|
||||
{ SH_INSN_BGTU, SH64_MEDIA_INSN_BGTU, SH64_MEDIA_SFMT_BEQ },
|
||||
{ SH_INSN_BLINK, SH64_MEDIA_INSN_BLINK, SH64_MEDIA_SFMT_BLINK },
|
||||
{ SH_INSN_BNE, SH64_MEDIA_INSN_BNE, SH64_MEDIA_SFMT_BEQ },
|
||||
{ SH_INSN_BNEI, SH64_MEDIA_INSN_BNEI, SH64_MEDIA_SFMT_BEQI },
|
||||
{ SH_INSN_BNEI, SH64_MEDIA_INSN_BNEI, SH64_MEDIA_SFMT_BNEI },
|
||||
{ SH_INSN_BRK, SH64_MEDIA_INSN_BRK, SH64_MEDIA_SFMT_BRK },
|
||||
{ SH_INSN_BYTEREV, SH64_MEDIA_INSN_BYTEREV, SH64_MEDIA_SFMT_BYTEREV },
|
||||
{ SH_INSN_CMPEQ, SH64_MEDIA_INSN_CMPEQ, SH64_MEDIA_SFMT_ADD },
|
||||
@ -119,11 +119,11 @@ static const struct insn_sem sh64_media_insn_sem[] =
|
||||
{ SH_INSN_FSTXD, SH64_MEDIA_INSN_FSTXD, SH64_MEDIA_SFMT_FSTXD },
|
||||
{ SH_INSN_FSTXP, SH64_MEDIA_INSN_FSTXP, SH64_MEDIA_SFMT_FLDXP },
|
||||
{ SH_INSN_FSTXS, SH64_MEDIA_INSN_FSTXS, SH64_MEDIA_SFMT_FSTXS },
|
||||
{ SH_INSN_FSUBD, SH64_MEDIA_INSN_FSUBD, SH64_MEDIA_SFMT_FADDD },
|
||||
{ SH_INSN_FSUBD, SH64_MEDIA_INSN_FSUBD, SH64_MEDIA_SFMT_FSUBD },
|
||||
{ SH_INSN_FSUBS, SH64_MEDIA_INSN_FSUBS, SH64_MEDIA_SFMT_FADDS },
|
||||
{ SH_INSN_FTRCDL, SH64_MEDIA_INSN_FTRCDL, SH64_MEDIA_SFMT_FCNVDS },
|
||||
{ SH_INSN_FTRCSL, SH64_MEDIA_INSN_FTRCSL, SH64_MEDIA_SFMT_FABSS },
|
||||
{ SH_INSN_FTRCDQ, SH64_MEDIA_INSN_FTRCDQ, SH64_MEDIA_SFMT_FABSD },
|
||||
{ SH_INSN_FTRCDQ, SH64_MEDIA_INSN_FTRCDQ, SH64_MEDIA_SFMT_FTRCDQ },
|
||||
{ SH_INSN_FTRCSQ, SH64_MEDIA_INSN_FTRCSQ, SH64_MEDIA_SFMT_FCNVSD },
|
||||
{ SH_INSN_FTRVS, SH64_MEDIA_INSN_FTRVS, SH64_MEDIA_SFMT_FTRVS },
|
||||
{ SH_INSN_GETCFG, SH64_MEDIA_INSN_GETCFG, SH64_MEDIA_SFMT_GETCFG },
|
||||
@ -171,7 +171,7 @@ static const struct insn_sem sh64_media_insn_sem[] =
|
||||
{ SH_INSN_MEXTR6, SH64_MEDIA_INSN_MEXTR6, SH64_MEDIA_SFMT_ADD },
|
||||
{ SH_INSN_MEXTR7, SH64_MEDIA_INSN_MEXTR7, SH64_MEDIA_SFMT_ADD },
|
||||
{ SH_INSN_MMACFXWL, SH64_MEDIA_INSN_MMACFXWL, SH64_MEDIA_SFMT_MCMV },
|
||||
{ SH_INSN_MMACNFX_WL, SH64_MEDIA_INSN_MMACNFX_WL, SH64_MEDIA_SFMT_MCMV },
|
||||
{ SH_INSN_MMACNFX_WL, SH64_MEDIA_INSN_MMACNFX_WL, SH64_MEDIA_SFMT_MMACNFX_WL },
|
||||
{ SH_INSN_MMULL, SH64_MEDIA_INSN_MMULL, SH64_MEDIA_SFMT_ADD },
|
||||
{ SH_INSN_MMULW, SH64_MEDIA_INSN_MMULW, SH64_MEDIA_SFMT_ADD },
|
||||
{ SH_INSN_MMULFXL, SH64_MEDIA_INSN_MMULFXL, SH64_MEDIA_SFMT_ADD },
|
||||
@ -212,7 +212,7 @@ static const struct insn_sem sh64_media_insn_sem[] =
|
||||
{ SH_INSN_OCBWB, SH64_MEDIA_INSN_OCBWB, SH64_MEDIA_SFMT_ALLOCO },
|
||||
{ SH_INSN_OR, SH64_MEDIA_INSN_OR, SH64_MEDIA_SFMT_ADD },
|
||||
{ SH_INSN_ORI, SH64_MEDIA_INSN_ORI, SH64_MEDIA_SFMT_ORI },
|
||||
{ SH_INSN_PREFI, SH64_MEDIA_INSN_PREFI, SH64_MEDIA_SFMT_ALLOCO },
|
||||
{ SH_INSN_PREFI, SH64_MEDIA_INSN_PREFI, SH64_MEDIA_SFMT_PREFI },
|
||||
{ SH_INSN_PTA, SH64_MEDIA_INSN_PTA, SH64_MEDIA_SFMT_PTA },
|
||||
{ SH_INSN_PTABS, SH64_MEDIA_INSN_PTABS, SH64_MEDIA_SFMT_PTABS },
|
||||
{ SH_INSN_PTB, SH64_MEDIA_INSN_PTB, SH64_MEDIA_SFMT_PTA },
|
||||
@ -708,7 +708,7 @@ sh64_media_decode (SIM_CPU *current_cpu, IADDR pc,
|
||||
itype = SH64_MEDIA_INSN_X_INVALID; goto extract_sfmt_empty;
|
||||
case 211 :
|
||||
if ((entire_insn & 0xfc0f000f) == 0x34030000)
|
||||
{ itype = SH64_MEDIA_INSN_FSUBD; goto extract_sfmt_faddd; }
|
||||
{ itype = SH64_MEDIA_INSN_FSUBD; goto extract_sfmt_fsubd; }
|
||||
itype = SH64_MEDIA_INSN_X_INVALID; goto extract_sfmt_empty;
|
||||
case 212 :
|
||||
if ((entire_insn & 0xfc0f000f) == 0x34040000)
|
||||
@ -760,7 +760,7 @@ sh64_media_decode (SIM_CPU *current_cpu, IADDR pc,
|
||||
itype = SH64_MEDIA_INSN_X_INVALID; goto extract_sfmt_empty;
|
||||
case 233 :
|
||||
if ((entire_insn & 0xfc0f000f) == 0x38090000)
|
||||
{ itype = SH64_MEDIA_INSN_FTRCDQ; goto extract_sfmt_fabsd; }
|
||||
{ itype = SH64_MEDIA_INSN_FTRCDQ; goto extract_sfmt_ftrcdq; }
|
||||
itype = SH64_MEDIA_INSN_X_INVALID; goto extract_sfmt_empty;
|
||||
case 234 :
|
||||
if ((entire_insn & 0xfc0f000f) == 0x380a0000)
|
||||
@ -844,7 +844,7 @@ sh64_media_decode (SIM_CPU *current_cpu, IADDR pc,
|
||||
itype = SH64_MEDIA_INSN_X_INVALID; goto extract_sfmt_empty;
|
||||
case 293 :
|
||||
if ((entire_insn & 0xfc0f000f) == 0x48050000)
|
||||
{ itype = SH64_MEDIA_INSN_MMACNFX_WL; goto extract_sfmt_mcmv; }
|
||||
{ itype = SH64_MEDIA_INSN_MMACNFX_WL; goto extract_sfmt_mmacnfx_wl; }
|
||||
itype = SH64_MEDIA_INSN_X_INVALID; goto extract_sfmt_empty;
|
||||
case 297 :
|
||||
if ((entire_insn & 0xfc0f000f) == 0x48090000)
|
||||
@ -1438,7 +1438,7 @@ sh64_media_decode (SIM_CPU *current_cpu, IADDR pc,
|
||||
itype = SH64_MEDIA_INSN_X_INVALID; goto extract_sfmt_empty;
|
||||
case 897 :
|
||||
if ((entire_insn & 0xfc0ffc0f) == 0xe001fc00)
|
||||
{ itype = SH64_MEDIA_INSN_PREFI; goto extract_sfmt_alloco; }
|
||||
{ itype = SH64_MEDIA_INSN_PREFI; goto extract_sfmt_prefi; }
|
||||
itype = SH64_MEDIA_INSN_X_INVALID; goto extract_sfmt_empty;
|
||||
case 898 :
|
||||
if ((entire_insn & 0xfc0f000f) == 0xe0020000)
|
||||
@ -1486,7 +1486,7 @@ sh64_media_decode (SIM_CPU *current_cpu, IADDR pc,
|
||||
itype = SH64_MEDIA_INSN_X_INVALID; goto extract_sfmt_empty;
|
||||
case 917 :
|
||||
if ((entire_insn & 0xfc0f018f) == 0xe4050000)
|
||||
{ itype = SH64_MEDIA_INSN_BNEI; goto extract_sfmt_beqi; }
|
||||
{ itype = SH64_MEDIA_INSN_BNEI; goto extract_sfmt_bnei; }
|
||||
itype = SH64_MEDIA_INSN_X_INVALID; goto extract_sfmt_empty;
|
||||
case 928 : /* fall through */
|
||||
case 929 : /* fall through */
|
||||
@ -1721,6 +1721,37 @@ sh64_media_decode (SIM_CPU *current_cpu, IADDR pc,
|
||||
FLD (out_rd) = f_dest;
|
||||
}
|
||||
#endif
|
||||
#undef FLD
|
||||
return idesc;
|
||||
}
|
||||
|
||||
extract_sfmt_bnei:
|
||||
{
|
||||
const IDESC *idesc = &sh64_media_insn_data[itype];
|
||||
CGEN_INSN_WORD insn = entire_insn;
|
||||
#define FLD(f) abuf->fields.sfmt_beqi.f
|
||||
UINT f_left;
|
||||
INT f_imm6;
|
||||
UINT f_tra;
|
||||
|
||||
f_left = EXTRACT_MSB0_UINT (insn, 32, 6, 6);
|
||||
f_imm6 = EXTRACT_MSB0_SINT (insn, 32, 16, 6);
|
||||
f_tra = EXTRACT_MSB0_UINT (insn, 32, 25, 3);
|
||||
|
||||
/* Record the fields for the semantic handler. */
|
||||
FLD (f_imm6) = f_imm6;
|
||||
FLD (f_left) = f_left;
|
||||
FLD (f_tra) = f_tra;
|
||||
TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_bnei", "f_imm6 0x%x", 'x', f_imm6, "f_left 0x%x", 'x', f_left, "f_tra 0x%x", 'x', f_tra, (char *) 0));
|
||||
|
||||
#if WITH_PROFILE_MODEL_P
|
||||
/* Record the fields for profiling. */
|
||||
if (PROFILE_MODEL_P (current_cpu))
|
||||
{
|
||||
FLD (in_rm) = f_left;
|
||||
FLD (in_tra) = f_tra;
|
||||
}
|
||||
#endif
|
||||
#undef FLD
|
||||
return idesc;
|
||||
}
|
||||
@ -2612,6 +2643,70 @@ sh64_media_decode (SIM_CPU *current_cpu, IADDR pc,
|
||||
FLD (in_rn) = f_right;
|
||||
}
|
||||
#endif
|
||||
#undef FLD
|
||||
return idesc;
|
||||
}
|
||||
|
||||
extract_sfmt_fsubd:
|
||||
{
|
||||
const IDESC *idesc = &sh64_media_insn_data[itype];
|
||||
CGEN_INSN_WORD insn = entire_insn;
|
||||
#define FLD(f) abuf->fields.sfmt_add.f
|
||||
UINT f_left;
|
||||
UINT f_right;
|
||||
UINT f_dest;
|
||||
|
||||
f_left = EXTRACT_MSB0_UINT (insn, 32, 6, 6);
|
||||
f_right = EXTRACT_MSB0_UINT (insn, 32, 16, 6);
|
||||
f_dest = EXTRACT_MSB0_UINT (insn, 32, 22, 6);
|
||||
|
||||
/* Record the fields for the semantic handler. */
|
||||
FLD (f_left) = f_left;
|
||||
FLD (f_right) = f_right;
|
||||
FLD (f_dest) = f_dest;
|
||||
TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_fsubd", "f_left 0x%x", 'x', f_left, "f_right 0x%x", 'x', f_right, "f_dest 0x%x", 'x', f_dest, (char *) 0));
|
||||
|
||||
#if WITH_PROFILE_MODEL_P
|
||||
/* Record the fields for profiling. */
|
||||
if (PROFILE_MODEL_P (current_cpu))
|
||||
{
|
||||
FLD (in_drg) = f_left;
|
||||
FLD (in_drh) = f_right;
|
||||
FLD (out_drf) = f_dest;
|
||||
}
|
||||
#endif
|
||||
#undef FLD
|
||||
return idesc;
|
||||
}
|
||||
|
||||
extract_sfmt_ftrcdq:
|
||||
{
|
||||
const IDESC *idesc = &sh64_media_insn_data[itype];
|
||||
CGEN_INSN_WORD insn = entire_insn;
|
||||
#define FLD(f) abuf->fields.sfmt_fabsd.f
|
||||
UINT f_left;
|
||||
UINT f_right;
|
||||
UINT f_dest;
|
||||
UINT f_left_right;
|
||||
|
||||
f_left = EXTRACT_MSB0_UINT (insn, 32, 6, 6);
|
||||
f_right = EXTRACT_MSB0_UINT (insn, 32, 16, 6);
|
||||
f_dest = EXTRACT_MSB0_UINT (insn, 32, 22, 6);
|
||||
f_left_right = f_left;
|
||||
|
||||
/* Record the fields for the semantic handler. */
|
||||
FLD (f_left_right) = f_left_right;
|
||||
FLD (f_dest) = f_dest;
|
||||
TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_ftrcdq", "f_left_right 0x%x", 'x', f_left_right, "f_dest 0x%x", 'x', f_dest, (char *) 0));
|
||||
|
||||
#if WITH_PROFILE_MODEL_P
|
||||
/* Record the fields for profiling. */
|
||||
if (PROFILE_MODEL_P (current_cpu))
|
||||
{
|
||||
FLD (in_drgh) = f_left_right;
|
||||
FLD (out_drf) = f_dest;
|
||||
}
|
||||
#endif
|
||||
#undef FLD
|
||||
return idesc;
|
||||
}
|
||||
@ -3196,6 +3291,39 @@ sh64_media_decode (SIM_CPU *current_cpu, IADDR pc,
|
||||
FLD (f_right) = f_right;
|
||||
TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_mcmv", "f_dest 0x%x", 'x', f_dest, "f_left 0x%x", 'x', f_left, "f_right 0x%x", 'x', f_right, (char *) 0));
|
||||
|
||||
#if WITH_PROFILE_MODEL_P
|
||||
/* Record the fields for profiling. */
|
||||
if (PROFILE_MODEL_P (current_cpu))
|
||||
{
|
||||
FLD (in_rd) = f_dest;
|
||||
FLD (in_rm) = f_left;
|
||||
FLD (in_rn) = f_right;
|
||||
FLD (out_rd) = f_dest;
|
||||
}
|
||||
#endif
|
||||
#undef FLD
|
||||
return idesc;
|
||||
}
|
||||
|
||||
extract_sfmt_mmacnfx_wl:
|
||||
{
|
||||
const IDESC *idesc = &sh64_media_insn_data[itype];
|
||||
CGEN_INSN_WORD insn = entire_insn;
|
||||
#define FLD(f) abuf->fields.sfmt_add.f
|
||||
UINT f_left;
|
||||
UINT f_right;
|
||||
UINT f_dest;
|
||||
|
||||
f_left = EXTRACT_MSB0_UINT (insn, 32, 6, 6);
|
||||
f_right = EXTRACT_MSB0_UINT (insn, 32, 16, 6);
|
||||
f_dest = EXTRACT_MSB0_UINT (insn, 32, 22, 6);
|
||||
|
||||
/* Record the fields for the semantic handler. */
|
||||
FLD (f_dest) = f_dest;
|
||||
FLD (f_left) = f_left;
|
||||
FLD (f_right) = f_right;
|
||||
TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_mmacnfx_wl", "f_dest 0x%x", 'x', f_dest, "f_left 0x%x", 'x', f_left, "f_right 0x%x", 'x', f_right, (char *) 0));
|
||||
|
||||
#if WITH_PROFILE_MODEL_P
|
||||
/* Record the fields for profiling. */
|
||||
if (PROFILE_MODEL_P (current_cpu))
|
||||
@ -3277,6 +3405,31 @@ sh64_media_decode (SIM_CPU *current_cpu, IADDR pc,
|
||||
FLD (out_rd) = f_dest;
|
||||
}
|
||||
#endif
|
||||
#undef FLD
|
||||
return idesc;
|
||||
}
|
||||
|
||||
extract_sfmt_prefi:
|
||||
{
|
||||
const IDESC *idesc = &sh64_media_insn_data[itype];
|
||||
CGEN_INSN_WORD insn = entire_insn;
|
||||
#define FLD(f) abuf->fields.sfmt_xori.f
|
||||
UINT f_left;
|
||||
|
||||
f_left = EXTRACT_MSB0_UINT (insn, 32, 6, 6);
|
||||
|
||||
/* Record the fields for the semantic handler. */
|
||||
FLD (f_left) = f_left;
|
||||
TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_prefi", "f_left 0x%x", 'x', f_left, (char *) 0));
|
||||
|
||||
#if WITH_PROFILE_MODEL_P
|
||||
/* Record the fields for profiling. */
|
||||
if (PROFILE_MODEL_P (current_cpu))
|
||||
{
|
||||
FLD (in_rm) = f_left;
|
||||
FLD (out_rm) = f_left;
|
||||
}
|
||||
#endif
|
||||
#undef FLD
|
||||
return idesc;
|
||||
}
|
||||
|
@ -93,25 +93,27 @@ typedef enum sh64_media_insn_type {
|
||||
/* Enum declaration for semantic formats in cpu family sh64. */
|
||||
typedef enum sh64_media_sfmt_type {
|
||||
SH64_MEDIA_SFMT_EMPTY, SH64_MEDIA_SFMT_ADD, SH64_MEDIA_SFMT_ADDI, SH64_MEDIA_SFMT_ALLOCO
|
||||
, SH64_MEDIA_SFMT_BEQ, SH64_MEDIA_SFMT_BEQI, SH64_MEDIA_SFMT_BLINK, SH64_MEDIA_SFMT_BRK
|
||||
, SH64_MEDIA_SFMT_BYTEREV, SH64_MEDIA_SFMT_CMVEQ, SH64_MEDIA_SFMT_FABSD, SH64_MEDIA_SFMT_FABSS
|
||||
, SH64_MEDIA_SFMT_FADDD, SH64_MEDIA_SFMT_FADDS, SH64_MEDIA_SFMT_FCMPEQD, SH64_MEDIA_SFMT_FCMPEQS
|
||||
, SH64_MEDIA_SFMT_FCNVDS, SH64_MEDIA_SFMT_FCNVSD, SH64_MEDIA_SFMT_FGETSCR, SH64_MEDIA_SFMT_FIPRS
|
||||
, SH64_MEDIA_SFMT_FLDD, SH64_MEDIA_SFMT_FLDP, SH64_MEDIA_SFMT_FLDS, SH64_MEDIA_SFMT_FLDXD
|
||||
, SH64_MEDIA_SFMT_FLDXP, SH64_MEDIA_SFMT_FLDXS, SH64_MEDIA_SFMT_FMACS, SH64_MEDIA_SFMT_FMOVDQ
|
||||
, SH64_MEDIA_SFMT_FMOVLS, SH64_MEDIA_SFMT_FMOVQD, SH64_MEDIA_SFMT_FMOVSL, SH64_MEDIA_SFMT_FPUTSCR
|
||||
, SH64_MEDIA_SFMT_FSTD, SH64_MEDIA_SFMT_FSTS, SH64_MEDIA_SFMT_FSTXD, SH64_MEDIA_SFMT_FSTXS
|
||||
, SH64_MEDIA_SFMT_FTRVS, SH64_MEDIA_SFMT_GETCFG, SH64_MEDIA_SFMT_GETCON, SH64_MEDIA_SFMT_GETTR
|
||||
, SH64_MEDIA_SFMT_LDB, SH64_MEDIA_SFMT_LDL, SH64_MEDIA_SFMT_LDQ, SH64_MEDIA_SFMT_LDUW
|
||||
, SH64_MEDIA_SFMT_LDHIL, SH64_MEDIA_SFMT_LDHIQ, SH64_MEDIA_SFMT_LDLOL, SH64_MEDIA_SFMT_LDLOQ
|
||||
, SH64_MEDIA_SFMT_LDXB, SH64_MEDIA_SFMT_LDXL, SH64_MEDIA_SFMT_LDXQ, SH64_MEDIA_SFMT_LDXUB
|
||||
, SH64_MEDIA_SFMT_LDXUW, SH64_MEDIA_SFMT_LDXW, SH64_MEDIA_SFMT_MCMV, SH64_MEDIA_SFMT_MOVI
|
||||
, SH64_MEDIA_SFMT_NOP, SH64_MEDIA_SFMT_ORI, SH64_MEDIA_SFMT_PTA, SH64_MEDIA_SFMT_PTABS
|
||||
, SH64_MEDIA_SFMT_PTREL, SH64_MEDIA_SFMT_PUTCFG, SH64_MEDIA_SFMT_PUTCON, SH64_MEDIA_SFMT_SHARI
|
||||
, SH64_MEDIA_SFMT_SHORI, SH64_MEDIA_SFMT_STB, SH64_MEDIA_SFMT_STL, SH64_MEDIA_SFMT_STQ
|
||||
, SH64_MEDIA_SFMT_STW, SH64_MEDIA_SFMT_STHIL, SH64_MEDIA_SFMT_STHIQ, SH64_MEDIA_SFMT_STLOL
|
||||
, SH64_MEDIA_SFMT_STLOQ, SH64_MEDIA_SFMT_STXB, SH64_MEDIA_SFMT_STXL, SH64_MEDIA_SFMT_STXQ
|
||||
, SH64_MEDIA_SFMT_STXW, SH64_MEDIA_SFMT_SWAPQ, SH64_MEDIA_SFMT_TRAPA, SH64_MEDIA_SFMT_XORI
|
||||
, SH64_MEDIA_SFMT_BEQ, SH64_MEDIA_SFMT_BEQI, SH64_MEDIA_SFMT_BLINK, SH64_MEDIA_SFMT_BNEI
|
||||
, SH64_MEDIA_SFMT_BRK, SH64_MEDIA_SFMT_BYTEREV, SH64_MEDIA_SFMT_CMVEQ, SH64_MEDIA_SFMT_FABSD
|
||||
, SH64_MEDIA_SFMT_FABSS, SH64_MEDIA_SFMT_FADDD, SH64_MEDIA_SFMT_FADDS, SH64_MEDIA_SFMT_FCMPEQD
|
||||
, SH64_MEDIA_SFMT_FCMPEQS, SH64_MEDIA_SFMT_FCNVDS, SH64_MEDIA_SFMT_FCNVSD, SH64_MEDIA_SFMT_FGETSCR
|
||||
, SH64_MEDIA_SFMT_FIPRS, SH64_MEDIA_SFMT_FLDD, SH64_MEDIA_SFMT_FLDP, SH64_MEDIA_SFMT_FLDS
|
||||
, SH64_MEDIA_SFMT_FLDXD, SH64_MEDIA_SFMT_FLDXP, SH64_MEDIA_SFMT_FLDXS, SH64_MEDIA_SFMT_FMACS
|
||||
, SH64_MEDIA_SFMT_FMOVDQ, SH64_MEDIA_SFMT_FMOVLS, SH64_MEDIA_SFMT_FMOVQD, SH64_MEDIA_SFMT_FMOVSL
|
||||
, SH64_MEDIA_SFMT_FPUTSCR, SH64_MEDIA_SFMT_FSTD, SH64_MEDIA_SFMT_FSTS, SH64_MEDIA_SFMT_FSTXD
|
||||
, SH64_MEDIA_SFMT_FSTXS, SH64_MEDIA_SFMT_FSUBD, SH64_MEDIA_SFMT_FTRCDQ, SH64_MEDIA_SFMT_FTRVS
|
||||
, SH64_MEDIA_SFMT_GETCFG, SH64_MEDIA_SFMT_GETCON, SH64_MEDIA_SFMT_GETTR, SH64_MEDIA_SFMT_LDB
|
||||
, SH64_MEDIA_SFMT_LDL, SH64_MEDIA_SFMT_LDQ, SH64_MEDIA_SFMT_LDUW, SH64_MEDIA_SFMT_LDHIL
|
||||
, SH64_MEDIA_SFMT_LDHIQ, SH64_MEDIA_SFMT_LDLOL, SH64_MEDIA_SFMT_LDLOQ, SH64_MEDIA_SFMT_LDXB
|
||||
, SH64_MEDIA_SFMT_LDXL, SH64_MEDIA_SFMT_LDXQ, SH64_MEDIA_SFMT_LDXUB, SH64_MEDIA_SFMT_LDXUW
|
||||
, SH64_MEDIA_SFMT_LDXW, SH64_MEDIA_SFMT_MCMV, SH64_MEDIA_SFMT_MMACNFX_WL, SH64_MEDIA_SFMT_MOVI
|
||||
, SH64_MEDIA_SFMT_NOP, SH64_MEDIA_SFMT_ORI, SH64_MEDIA_SFMT_PREFI, SH64_MEDIA_SFMT_PTA
|
||||
, SH64_MEDIA_SFMT_PTABS, SH64_MEDIA_SFMT_PTREL, SH64_MEDIA_SFMT_PUTCFG, SH64_MEDIA_SFMT_PUTCON
|
||||
, SH64_MEDIA_SFMT_SHARI, SH64_MEDIA_SFMT_SHORI, SH64_MEDIA_SFMT_STB, SH64_MEDIA_SFMT_STL
|
||||
, SH64_MEDIA_SFMT_STQ, SH64_MEDIA_SFMT_STW, SH64_MEDIA_SFMT_STHIL, SH64_MEDIA_SFMT_STHIQ
|
||||
, SH64_MEDIA_SFMT_STLOL, SH64_MEDIA_SFMT_STLOQ, SH64_MEDIA_SFMT_STXB, SH64_MEDIA_SFMT_STXL
|
||||
, SH64_MEDIA_SFMT_STXQ, SH64_MEDIA_SFMT_STXW, SH64_MEDIA_SFMT_SWAPQ, SH64_MEDIA_SFMT_TRAPA
|
||||
, SH64_MEDIA_SFMT_XORI
|
||||
} SH64_MEDIA_SFMT_TYPE;
|
||||
|
||||
/* Function unit handlers (user written). */
|
||||
|
Loading…
x
Reference in New Issue
Block a user