|
@@ -248,10 +248,10 @@ local map_op = {
|
|
|
["addic._3"] = "34000000RRI",
|
|
|
addi_3 = "38000000RRI",
|
|
|
li_2 = "38000000RI",
|
|
|
+ la_2 = "38000000RD",
|
|
|
addis_3 = "3c000000RRI",
|
|
|
lis_2 = "3c000000RI",
|
|
|
lus_2 = "3c000000RU",
|
|
|
- la_2 = "3c000000RD",
|
|
|
bc_3 = "40000000AAK",
|
|
|
bcl_3 = "40000001AAK",
|
|
|
bdnz_1 = "42000000K",
|
|
@@ -526,6 +526,282 @@ local map_op = {
|
|
|
fctidz_2 = "fc00065eF-F.",
|
|
|
fcfid_2 = "fc00069cF-F.",
|
|
|
|
|
|
+ -- Primary opcode 4, SPE APU extension:
|
|
|
+ evaddw_3 = "10000200RRR",
|
|
|
+ evaddiw_3 = "10000202RAR~",
|
|
|
+ evsubw_3 = "10000204RRR~",
|
|
|
+ evsubiw_3 = "10000206RAR~",
|
|
|
+ evabs_2 = "10000208RR",
|
|
|
+ evneg_2 = "10000209RR",
|
|
|
+ evextsb_2 = "1000020aRR",
|
|
|
+ evextsh_2 = "1000020bRR",
|
|
|
+ evrndw_2 = "1000020cRR",
|
|
|
+ evcntlzw_2 = "1000020dRR",
|
|
|
+ evcntlsw_2 = "1000020eRR",
|
|
|
+ brinc_3 = "1000020fRRR",
|
|
|
+ evand_3 = "10000211RRR",
|
|
|
+ evandc_3 = "10000212RRR",
|
|
|
+ evxor_3 = "10000216RRR",
|
|
|
+ evor_3 = "10000217RRR",
|
|
|
+ evmr_2 = "10000217RR=",
|
|
|
+ evnor_3 = "10000218RRR",
|
|
|
+ evnot_2 = "10000218RR=",
|
|
|
+ eveqv_3 = "10000219RRR",
|
|
|
+ evorc_3 = "1000021bRRR",
|
|
|
+ evnand_3 = "1000021eRRR",
|
|
|
+ evsrwu_3 = "10000220RRR",
|
|
|
+ evsrws_3 = "10000221RRR",
|
|
|
+ evsrwiu_3 = "10000222RRA",
|
|
|
+ evsrwis_3 = "10000223RRA",
|
|
|
+ evslw_3 = "10000224RRR",
|
|
|
+ evslwi_3 = "10000226RRA",
|
|
|
+ evrlw_3 = "10000228RRR",
|
|
|
+ evsplati_2 = "10000229RS",
|
|
|
+ evrlwi_3 = "1000022aRRA",
|
|
|
+ evsplatfi_2 = "1000022bRS",
|
|
|
+ evmergehi_3 = "1000022cRRR",
|
|
|
+ evmergelo_3 = "1000022dRRR",
|
|
|
+ evcmpgtu_3 = "10000230XRR",
|
|
|
+ evcmpgtu_2 = "10000230-RR",
|
|
|
+ evcmpgts_3 = "10000231XRR",
|
|
|
+ evcmpgts_2 = "10000231-RR",
|
|
|
+ evcmpltu_3 = "10000232XRR",
|
|
|
+ evcmpltu_2 = "10000232-RR",
|
|
|
+ evcmplts_3 = "10000233XRR",
|
|
|
+ evcmplts_2 = "10000233-RR",
|
|
|
+ evcmpeq_3 = "10000234XRR",
|
|
|
+ evcmpeq_2 = "10000234-RR",
|
|
|
+ evsel_4 = "10000278RRRW",
|
|
|
+ evsel_3 = "10000278RRR",
|
|
|
+ evfsadd_3 = "10000280RRR",
|
|
|
+ evfssub_3 = "10000281RRR",
|
|
|
+ evfsabs_2 = "10000284RR",
|
|
|
+ evfsnabs_2 = "10000285RR",
|
|
|
+ evfsneg_2 = "10000286RR",
|
|
|
+ evfsmul_3 = "10000288RRR",
|
|
|
+ evfsdiv_3 = "10000289RRR",
|
|
|
+ evfscmpgt_3 = "1000028cXRR",
|
|
|
+ evfscmpgt_2 = "1000028c-RR",
|
|
|
+ evfscmplt_3 = "1000028dXRR",
|
|
|
+ evfscmplt_2 = "1000028d-RR",
|
|
|
+ evfscmpeq_3 = "1000028eXRR",
|
|
|
+ evfscmpeq_2 = "1000028e-RR",
|
|
|
+ evfscfui_2 = "10000290R-R",
|
|
|
+ evfscfsi_2 = "10000291R-R",
|
|
|
+ evfscfuf_2 = "10000292R-R",
|
|
|
+ evfscfsf_2 = "10000293R-R",
|
|
|
+ evfsctui_2 = "10000294R-R",
|
|
|
+ evfsctsi_2 = "10000295R-R",
|
|
|
+ evfsctuf_2 = "10000296R-R",
|
|
|
+ evfsctsf_2 = "10000297R-R",
|
|
|
+ evfsctuiz_2 = "10000298R-R",
|
|
|
+ evfsctsiz_2 = "1000029aR-R",
|
|
|
+ evfststgt_3 = "1000029cXRR",
|
|
|
+ evfststgt_2 = "1000029c-RR",
|
|
|
+ evfststlt_3 = "1000029dXRR",
|
|
|
+ evfststlt_2 = "1000029d-RR",
|
|
|
+ evfststeq_3 = "1000029eXRR",
|
|
|
+ evfststeq_2 = "1000029e-RR",
|
|
|
+ efsadd_3 = "100002c0RRR",
|
|
|
+ efssub_3 = "100002c1RRR",
|
|
|
+ efsabs_2 = "100002c4RR",
|
|
|
+ efsnabs_2 = "100002c5RR",
|
|
|
+ efsneg_2 = "100002c6RR",
|
|
|
+ efsmul_3 = "100002c8RRR",
|
|
|
+ efsdiv_3 = "100002c9RRR",
|
|
|
+ efscmpgt_3 = "100002ccXRR",
|
|
|
+ efscmpgt_2 = "100002cc-RR",
|
|
|
+ efscmplt_3 = "100002cdXRR",
|
|
|
+ efscmplt_2 = "100002cd-RR",
|
|
|
+ efscmpeq_3 = "100002ceXRR",
|
|
|
+ efscmpeq_2 = "100002ce-RR",
|
|
|
+ efscfd_2 = "100002cfR-R",
|
|
|
+ efscfui_2 = "100002d0R-R",
|
|
|
+ efscfsi_2 = "100002d1R-R",
|
|
|
+ efscfuf_2 = "100002d2R-R",
|
|
|
+ efscfsf_2 = "100002d3R-R",
|
|
|
+ efsctui_2 = "100002d4R-R",
|
|
|
+ efsctsi_2 = "100002d5R-R",
|
|
|
+ efsctuf_2 = "100002d6R-R",
|
|
|
+ efsctsf_2 = "100002d7R-R",
|
|
|
+ efsctuiz_2 = "100002d8R-R",
|
|
|
+ efsctsiz_2 = "100002daR-R",
|
|
|
+ efststgt_3 = "100002dcXRR",
|
|
|
+ efststgt_2 = "100002dc-RR",
|
|
|
+ efststlt_3 = "100002ddXRR",
|
|
|
+ efststlt_2 = "100002dd-RR",
|
|
|
+ efststeq_3 = "100002deXRR",
|
|
|
+ efststeq_2 = "100002de-RR",
|
|
|
+ efdadd_3 = "100002e0RRR",
|
|
|
+ efdsub_3 = "100002e1RRR",
|
|
|
+ efdcfuid_2 = "100002e2R-R",
|
|
|
+ efdcfsid_2 = "100002e3R-R",
|
|
|
+ efdabs_2 = "100002e4RR",
|
|
|
+ efdnabs_2 = "100002e5RR",
|
|
|
+ efdneg_2 = "100002e6RR",
|
|
|
+ efdmul_3 = "100002e8RRR",
|
|
|
+ efddiv_3 = "100002e9RRR",
|
|
|
+ efdctuidz_2 = "100002eaR-R",
|
|
|
+ efdctsidz_2 = "100002ebR-R",
|
|
|
+ efdcmpgt_3 = "100002ecXRR",
|
|
|
+ efdcmpgt_2 = "100002ec-RR",
|
|
|
+ efdcmplt_3 = "100002edXRR",
|
|
|
+ efdcmplt_2 = "100002ed-RR",
|
|
|
+ efdcmpeq_3 = "100002eeXRR",
|
|
|
+ efdcmpeq_2 = "100002ee-RR",
|
|
|
+ efdcfs_2 = "100002efR-R",
|
|
|
+ efdcfui_2 = "100002f0R-R",
|
|
|
+ efdcfsi_2 = "100002f1R-R",
|
|
|
+ efdcfuf_2 = "100002f2R-R",
|
|
|
+ efdcfsf_2 = "100002f3R-R",
|
|
|
+ efdctui_2 = "100002f4R-R",
|
|
|
+ efdctsi_2 = "100002f5R-R",
|
|
|
+ efdctuf_2 = "100002f6R-R",
|
|
|
+ efdctsf_2 = "100002f7R-R",
|
|
|
+ efdctuiz_2 = "100002f8R-R",
|
|
|
+ efdctsiz_2 = "100002faR-R",
|
|
|
+ efdtstgt_3 = "100002fcXRR",
|
|
|
+ efdtstgt_2 = "100002fc-RR",
|
|
|
+ efdtstlt_3 = "100002fdXRR",
|
|
|
+ efdtstlt_2 = "100002fd-RR",
|
|
|
+ efdtsteq_3 = "100002feXRR",
|
|
|
+ efdtsteq_2 = "100002fe-RR",
|
|
|
+ evlddx_3 = "10000300RRR",
|
|
|
+ evldd_2 = "10000301R8",
|
|
|
+ evldwx_3 = "10000302RRR",
|
|
|
+ evldw_2 = "10000303R8",
|
|
|
+ evldhx_3 = "10000304RRR",
|
|
|
+ evldh_2 = "10000305R8",
|
|
|
+ evlwhex_3 = "10000310RRR",
|
|
|
+ evlwhe_2 = "10000311R4",
|
|
|
+ evlwhoux_3 = "10000314RRR",
|
|
|
+ evlwhou_2 = "10000315R4",
|
|
|
+ evlwhosx_3 = "10000316RRR",
|
|
|
+ evlwhos_2 = "10000317R4",
|
|
|
+ evstddx_3 = "10000320RRR",
|
|
|
+ evstdd_2 = "10000321R8",
|
|
|
+ evstdwx_3 = "10000322RRR",
|
|
|
+ evstdw_2 = "10000323R8",
|
|
|
+ evstdhx_3 = "10000324RRR",
|
|
|
+ evstdh_2 = "10000325R8",
|
|
|
+ evstwhex_3 = "10000330RRR",
|
|
|
+ evstwhe_2 = "10000331R4",
|
|
|
+ evstwhox_3 = "10000334RRR",
|
|
|
+ evstwho_2 = "10000335R4",
|
|
|
+ evstwwex_3 = "10000338RRR",
|
|
|
+ evstwwe_2 = "10000339R4",
|
|
|
+ evstwwox_3 = "1000033cRRR",
|
|
|
+ evstwwo_2 = "1000033dR4",
|
|
|
+ evmhessf_3 = "10000403RRR",
|
|
|
+ evmhossf_3 = "10000407RRR",
|
|
|
+ evmheumi_3 = "10000408RRR",
|
|
|
+ evmhesmi_3 = "10000409RRR",
|
|
|
+ evmhesmf_3 = "1000040bRRR",
|
|
|
+ evmhoumi_3 = "1000040cRRR",
|
|
|
+ evmhosmi_3 = "1000040dRRR",
|
|
|
+ evmhosmf_3 = "1000040fRRR",
|
|
|
+ evmhessfa_3 = "10000423RRR",
|
|
|
+ evmhossfa_3 = "10000427RRR",
|
|
|
+ evmheumia_3 = "10000428RRR",
|
|
|
+ evmhesmia_3 = "10000429RRR",
|
|
|
+ evmhesmfa_3 = "1000042bRRR",
|
|
|
+ evmhoumia_3 = "1000042cRRR",
|
|
|
+ evmhosmia_3 = "1000042dRRR",
|
|
|
+ evmhosmfa_3 = "1000042fRRR",
|
|
|
+ evmwhssf_3 = "10000447RRR",
|
|
|
+ evmwlumi_3 = "10000448RRR",
|
|
|
+ evmwhumi_3 = "1000044cRRR",
|
|
|
+ evmwhsmi_3 = "1000044dRRR",
|
|
|
+ evmwhsmf_3 = "1000044fRRR",
|
|
|
+ evmwssf_3 = "10000453RRR",
|
|
|
+ evmwumi_3 = "10000458RRR",
|
|
|
+ evmwsmi_3 = "10000459RRR",
|
|
|
+ evmwsmf_3 = "1000045bRRR",
|
|
|
+ evmwhssfa_3 = "10000467RRR",
|
|
|
+ evmwlumia_3 = "10000468RRR",
|
|
|
+ evmwhumia_3 = "1000046cRRR",
|
|
|
+ evmwhsmia_3 = "1000046dRRR",
|
|
|
+ evmwhsmfa_3 = "1000046fRRR",
|
|
|
+ evmwssfa_3 = "10000473RRR",
|
|
|
+ evmwumia_3 = "10000478RRR",
|
|
|
+ evmwsmia_3 = "10000479RRR",
|
|
|
+ evmwsmfa_3 = "1000047bRRR",
|
|
|
+ evmra_2 = "100004c4RR",
|
|
|
+ evdivws_3 = "100004c6RRR",
|
|
|
+ evdivwu_3 = "100004c7RRR",
|
|
|
+ evmwssfaa_3 = "10000553RRR",
|
|
|
+ evmwumiaa_3 = "10000558RRR",
|
|
|
+ evmwsmiaa_3 = "10000559RRR",
|
|
|
+ evmwsmfaa_3 = "1000055bRRR",
|
|
|
+ evmwssfan_3 = "100005d3RRR",
|
|
|
+ evmwumian_3 = "100005d8RRR",
|
|
|
+ evmwsmian_3 = "100005d9RRR",
|
|
|
+ evmwsmfan_3 = "100005dbRRR",
|
|
|
+ evmergehilo_3 = "1000022eRRR",
|
|
|
+ evmergelohi_3 = "1000022fRRR",
|
|
|
+ evlhhesplatx_3 = "10000308RRR",
|
|
|
+ evlhhesplat_2 = "10000309R2",
|
|
|
+ evlhhousplatx_3 = "1000030cRRR",
|
|
|
+ evlhhousplat_2 = "1000030dR2",
|
|
|
+ evlhhossplatx_3 = "1000030eRRR",
|
|
|
+ evlhhossplat_2 = "1000030fR2",
|
|
|
+ evlwwsplatx_3 = "10000318RRR",
|
|
|
+ evlwwsplat_2 = "10000319R4",
|
|
|
+ evlwhsplatx_3 = "1000031cRRR",
|
|
|
+ evlwhsplat_2 = "1000031dR4",
|
|
|
+ evaddusiaaw_2 = "100004c0RR",
|
|
|
+ evaddssiaaw_2 = "100004c1RR",
|
|
|
+ evsubfusiaaw_2 = "100004c2RR",
|
|
|
+ evsubfssiaaw_2 = "100004c3RR",
|
|
|
+ evaddumiaaw_2 = "100004c8RR",
|
|
|
+ evaddsmiaaw_2 = "100004c9RR",
|
|
|
+ evsubfumiaaw_2 = "100004caRR",
|
|
|
+ evsubfsmiaaw_2 = "100004cbRR",
|
|
|
+ evmheusiaaw_3 = "10000500RRR",
|
|
|
+ evmhessiaaw_3 = "10000501RRR",
|
|
|
+ evmhessfaaw_3 = "10000503RRR",
|
|
|
+ evmhousiaaw_3 = "10000504RRR",
|
|
|
+ evmhossiaaw_3 = "10000505RRR",
|
|
|
+ evmhossfaaw_3 = "10000507RRR",
|
|
|
+ evmheumiaaw_3 = "10000508RRR",
|
|
|
+ evmhesmiaaw_3 = "10000509RRR",
|
|
|
+ evmhesmfaaw_3 = "1000050bRRR",
|
|
|
+ evmhoumiaaw_3 = "1000050cRRR",
|
|
|
+ evmhosmiaaw_3 = "1000050dRRR",
|
|
|
+ evmhosmfaaw_3 = "1000050fRRR",
|
|
|
+ evmhegumiaa_3 = "10000528RRR",
|
|
|
+ evmhegsmiaa_3 = "10000529RRR",
|
|
|
+ evmhegsmfaa_3 = "1000052bRRR",
|
|
|
+ evmhogumiaa_3 = "1000052cRRR",
|
|
|
+ evmhogsmiaa_3 = "1000052dRRR",
|
|
|
+ evmhogsmfaa_3 = "1000052fRRR",
|
|
|
+ evmwlusiaaw_3 = "10000540RRR",
|
|
|
+ evmwlssiaaw_3 = "10000541RRR",
|
|
|
+ evmwlumiaaw_3 = "10000548RRR",
|
|
|
+ evmwlsmiaaw_3 = "10000549RRR",
|
|
|
+ evmheusianw_3 = "10000580RRR",
|
|
|
+ evmhessianw_3 = "10000581RRR",
|
|
|
+ evmhessfanw_3 = "10000583RRR",
|
|
|
+ evmhousianw_3 = "10000584RRR",
|
|
|
+ evmhossianw_3 = "10000585RRR",
|
|
|
+ evmhossfanw_3 = "10000587RRR",
|
|
|
+ evmheumianw_3 = "10000588RRR",
|
|
|
+ evmhesmianw_3 = "10000589RRR",
|
|
|
+ evmhesmfanw_3 = "1000058bRRR",
|
|
|
+ evmhoumianw_3 = "1000058cRRR",
|
|
|
+ evmhosmianw_3 = "1000058dRRR",
|
|
|
+ evmhosmfanw_3 = "1000058fRRR",
|
|
|
+ evmhegumian_3 = "100005a8RRR",
|
|
|
+ evmhegsmian_3 = "100005a9RRR",
|
|
|
+ evmhegsmfan_3 = "100005abRRR",
|
|
|
+ evmhogumian_3 = "100005acRRR",
|
|
|
+ evmhogsmian_3 = "100005adRRR",
|
|
|
+ evmhogsmfan_3 = "100005afRRR",
|
|
|
+ evmwlusianw_3 = "100005c0RRR",
|
|
|
+ evmwlssianw_3 = "100005c1RRR",
|
|
|
+ evmwlumianw_3 = "100005c8RRR",
|
|
|
+ evmwlsmianw_3 = "100005c9RRR",
|
|
|
+
|
|
|
-- NYI: some 64 bit PowerPC and Book E instructions:
|
|
|
-- rldicl, rldicr, rldic, rldimi, rldcl, rldcr, sradi, 64 bit ext. add/sub,
|
|
|
-- extended addressing branches, cache management, loads and stores
|
|
@@ -720,16 +996,26 @@ map_op[".template__"] = function(params, template, nparams)
|
|
|
rs = rs - 5; op = op + parse_fpr(params[n]) * 2^rs; n = n + 1
|
|
|
elseif p == "A" then
|
|
|
rs = rs - 5; op = op + parse_imm(params[n], 5, rs, 0, false); n = n + 1
|
|
|
+ elseif p == "S" then
|
|
|
+ rs = rs - 5; op = op + parse_imm(params[n], 5, rs, 0, true); n = n + 1
|
|
|
elseif p == "I" then
|
|
|
op = op + parse_imm(params[n], 16, 0, 0, true); n = n + 1
|
|
|
elseif p == "U" then
|
|
|
op = op + parse_imm(params[n], 16, 0, 0, false); n = n + 1
|
|
|
elseif p == "D" then
|
|
|
op = op + parse_disp(params[n]); n = n + 1
|
|
|
+ elseif p == "2" then
|
|
|
+ op = op + parse_u5disp(params[n], 1); n = n + 1
|
|
|
+ elseif p == "4" then
|
|
|
+ op = op + parse_u5disp(params[n], 2); n = n + 1
|
|
|
+ elseif p == "8" then
|
|
|
+ op = op + parse_u5disp(params[n], 3); n = n + 1
|
|
|
elseif p == "C" then
|
|
|
rs = rs - 5; op = op + parse_cond(params[n]) * 2^rs; n = n + 1
|
|
|
elseif p == "X" then
|
|
|
rs = rs - 5; op = op + parse_cr(params[n]) * 2^(rs+2); n = n + 1
|
|
|
+ elseif p == "W" then
|
|
|
+ op = op + parse_cr(params[n]); n = n + 1
|
|
|
elseif p == "J" or p == "K" then
|
|
|
local mode, n, s = parse_label(params[n], false)
|
|
|
if p == "K" then n = n + 2048 end
|