diff options
Diffstat (limited to 'dynasm/dasm_ppc.lua')
| -rw-r--r-- | dynasm/dasm_ppc.lua | 702 |
1 files changed, 686 insertions, 16 deletions
diff --git a/dynasm/dasm_ppc.lua b/dynasm/dasm_ppc.lua index 2f6c88d4..88aa1933 100644 --- a/dynasm/dasm_ppc.lua +++ b/dynasm/dasm_ppc.lua | |||
| @@ -1,17 +1,19 @@ | |||
| 1 | ------------------------------------------------------------------------------ | 1 | ------------------------------------------------------------------------------ |
| 2 | -- DynASM PPC module. | 2 | -- DynASM PPC/PPC64 module. |
| 3 | -- | 3 | -- |
| 4 | -- Copyright (C) 2005-2026 Mike Pall. All rights reserved. | 4 | -- Copyright (C) 2005-2026 Mike Pall. All rights reserved. |
| 5 | -- See dynasm.lua for full copyright notice. | 5 | -- See dynasm.lua for full copyright notice. |
| 6 | -- | ||
| 7 | -- Support for various extensions contributed by Caio Souza Oliveira. | ||
| 6 | ------------------------------------------------------------------------------ | 8 | ------------------------------------------------------------------------------ |
| 7 | 9 | ||
| 8 | -- Module information: | 10 | -- Module information: |
| 9 | local _info = { | 11 | local _info = { |
| 10 | arch = "ppc", | 12 | arch = "ppc", |
| 11 | description = "DynASM PPC module", | 13 | description = "DynASM PPC module", |
| 12 | version = "1.3.0", | 14 | version = "1.5.0", |
| 13 | vernum = 10300, | 15 | vernum = 10500, |
| 14 | release = "2011-05-05", | 16 | release = "2021-05-02", |
| 15 | author = "Mike Pall", | 17 | author = "Mike Pall", |
| 16 | license = "MIT", | 18 | license = "MIT", |
| 17 | } | 19 | } |
| @@ -39,7 +41,7 @@ local wline, werror, wfatal, wwarn | |||
| 39 | local action_names = { | 41 | local action_names = { |
| 40 | "STOP", "SECTION", "ESC", "REL_EXT", | 42 | "STOP", "SECTION", "ESC", "REL_EXT", |
| 41 | "ALIGN", "REL_LG", "LABEL_LG", | 43 | "ALIGN", "REL_LG", "LABEL_LG", |
| 42 | "REL_PC", "LABEL_PC", "IMM", | 44 | "REL_PC", "LABEL_PC", "IMM", "IMMSH" |
| 43 | } | 45 | } |
| 44 | 46 | ||
| 45 | -- Maximum number of section buffer positions for dasm_put(). | 47 | -- Maximum number of section buffer positions for dasm_put(). |
| @@ -228,8 +230,18 @@ local map_cond = { | |||
| 228 | 230 | ||
| 229 | ------------------------------------------------------------------------------ | 231 | ------------------------------------------------------------------------------ |
| 230 | 232 | ||
| 233 | local map_op, op_template | ||
| 234 | |||
| 235 | local function op_alias(opname, f) | ||
| 236 | return function(params, nparams) | ||
| 237 | if not params then return "-> "..opname:sub(1, -3) end | ||
| 238 | f(params, nparams) | ||
| 239 | op_template(params, map_op[opname], nparams) | ||
| 240 | end | ||
| 241 | end | ||
| 242 | |||
| 231 | -- Template strings for PPC instructions. | 243 | -- Template strings for PPC instructions. |
| 232 | local map_op = { | 244 | map_op = { |
| 233 | tdi_3 = "08000000ARI", | 245 | tdi_3 = "08000000ARI", |
| 234 | twi_3 = "0c000000ARI", | 246 | twi_3 = "0c000000ARI", |
| 235 | mulli_3 = "1c000000RRI", | 247 | mulli_3 = "1c000000RRI", |
| @@ -297,6 +309,250 @@ local map_op = { | |||
| 297 | std_2 = "f8000000RD", | 309 | std_2 = "f8000000RD", |
| 298 | stdu_2 = "f8000001RD", | 310 | stdu_2 = "f8000001RD", |
| 299 | 311 | ||
| 312 | subi_3 = op_alias("addi_3", function(p) p[3] = "-("..p[3]..")" end), | ||
| 313 | subis_3 = op_alias("addis_3", function(p) p[3] = "-("..p[3]..")" end), | ||
| 314 | subic_3 = op_alias("addic_3", function(p) p[3] = "-("..p[3]..")" end), | ||
| 315 | ["subic._3"] = op_alias("addic._3", function(p) p[3] = "-("..p[3]..")" end), | ||
| 316 | |||
| 317 | rotlwi_3 = op_alias("rlwinm_5", function(p) | ||
| 318 | p[4] = "0"; p[5] = "31" | ||
| 319 | end), | ||
| 320 | rotrwi_3 = op_alias("rlwinm_5", function(p) | ||
| 321 | p[3] = "32-("..p[3]..")"; p[4] = "0"; p[5] = "31" | ||
| 322 | end), | ||
| 323 | rotlw_3 = op_alias("rlwnm_5", function(p) | ||
| 324 | p[4] = "0"; p[5] = "31" | ||
| 325 | end), | ||
| 326 | slwi_3 = op_alias("rlwinm_5", function(p) | ||
| 327 | p[5] = "31-("..p[3]..")"; p[4] = "0" | ||
| 328 | end), | ||
| 329 | srwi_3 = op_alias("rlwinm_5", function(p) | ||
| 330 | p[4] = p[3]; p[3] = "32-("..p[3]..")"; p[5] = "31" | ||
| 331 | end), | ||
| 332 | clrlwi_3 = op_alias("rlwinm_5", function(p) | ||
| 333 | p[4] = p[3]; p[3] = "0"; p[5] = "31" | ||
| 334 | end), | ||
| 335 | clrrwi_3 = op_alias("rlwinm_5", function(p) | ||
| 336 | p[5] = "31-("..p[3]..")"; p[3] = "0"; p[4] = "0" | ||
| 337 | end), | ||
| 338 | |||
| 339 | -- Primary opcode 4: | ||
| 340 | mulhhwu_3 = "10000010RRR.", | ||
| 341 | machhwu_3 = "10000018RRR.", | ||
| 342 | mulhhw_3 = "10000050RRR.", | ||
| 343 | nmachhw_3 = "1000005cRRR.", | ||
| 344 | machhwsu_3 = "10000098RRR.", | ||
| 345 | machhws_3 = "100000d8RRR.", | ||
| 346 | nmachhws_3 = "100000dcRRR.", | ||
| 347 | mulchwu_3 = "10000110RRR.", | ||
| 348 | macchwu_3 = "10000118RRR.", | ||
| 349 | mulchw_3 = "10000150RRR.", | ||
| 350 | macchw_3 = "10000158RRR.", | ||
| 351 | nmacchw_3 = "1000015cRRR.", | ||
| 352 | macchwsu_3 = "10000198RRR.", | ||
| 353 | macchws_3 = "100001d8RRR.", | ||
| 354 | nmacchws_3 = "100001dcRRR.", | ||
| 355 | mullhw_3 = "10000350RRR.", | ||
| 356 | maclhw_3 = "10000358RRR.", | ||
| 357 | nmaclhw_3 = "1000035cRRR.", | ||
| 358 | maclhwsu_3 = "10000398RRR.", | ||
| 359 | maclhws_3 = "100003d8RRR.", | ||
| 360 | nmaclhws_3 = "100003dcRRR.", | ||
| 361 | machhwuo_3 = "10000418RRR.", | ||
| 362 | nmachhwo_3 = "1000045cRRR.", | ||
| 363 | machhwsuo_3 = "10000498RRR.", | ||
| 364 | machhwso_3 = "100004d8RRR.", | ||
| 365 | nmachhwso_3 = "100004dcRRR.", | ||
| 366 | macchwuo_3 = "10000518RRR.", | ||
| 367 | macchwo_3 = "10000558RRR.", | ||
| 368 | nmacchwo_3 = "1000055cRRR.", | ||
| 369 | macchwsuo_3 = "10000598RRR.", | ||
| 370 | macchwso_3 = "100005d8RRR.", | ||
| 371 | nmacchwso_3 = "100005dcRRR.", | ||
| 372 | maclhwo_3 = "10000758RRR.", | ||
| 373 | nmaclhwo_3 = "1000075cRRR.", | ||
| 374 | maclhwsuo_3 = "10000798RRR.", | ||
| 375 | maclhwso_3 = "100007d8RRR.", | ||
| 376 | nmaclhwso_3 = "100007dcRRR.", | ||
| 377 | |||
| 378 | vaddubm_3 = "10000000VVV", | ||
| 379 | vmaxub_3 = "10000002VVV", | ||
| 380 | vrlb_3 = "10000004VVV", | ||
| 381 | vcmpequb_3 = "10000006VVV", | ||
| 382 | vmuloub_3 = "10000008VVV", | ||
| 383 | vaddfp_3 = "1000000aVVV", | ||
| 384 | vmrghb_3 = "1000000cVVV", | ||
| 385 | vpkuhum_3 = "1000000eVVV", | ||
| 386 | vmhaddshs_4 = "10000020VVVV", | ||
| 387 | vmhraddshs_4 = "10000021VVVV", | ||
| 388 | vmladduhm_4 = "10000022VVVV", | ||
| 389 | vmsumubm_4 = "10000024VVVV", | ||
| 390 | vmsummbm_4 = "10000025VVVV", | ||
| 391 | vmsumuhm_4 = "10000026VVVV", | ||
| 392 | vmsumuhs_4 = "10000027VVVV", | ||
| 393 | vmsumshm_4 = "10000028VVVV", | ||
| 394 | vmsumshs_4 = "10000029VVVV", | ||
| 395 | vsel_4 = "1000002aVVVV", | ||
| 396 | vperm_4 = "1000002bVVVV", | ||
| 397 | vsldoi_4 = "1000002cVVVP", | ||
| 398 | vpermxor_4 = "1000002dVVVV", | ||
| 399 | vmaddfp_4 = "1000002eVVVV~", | ||
| 400 | vnmsubfp_4 = "1000002fVVVV~", | ||
| 401 | vaddeuqm_4 = "1000003cVVVV", | ||
| 402 | vaddecuq_4 = "1000003dVVVV", | ||
| 403 | vsubeuqm_4 = "1000003eVVVV", | ||
| 404 | vsubecuq_4 = "1000003fVVVV", | ||
| 405 | vadduhm_3 = "10000040VVV", | ||
| 406 | vmaxuh_3 = "10000042VVV", | ||
| 407 | vrlh_3 = "10000044VVV", | ||
| 408 | vcmpequh_3 = "10000046VVV", | ||
| 409 | vmulouh_3 = "10000048VVV", | ||
| 410 | vsubfp_3 = "1000004aVVV", | ||
| 411 | vmrghh_3 = "1000004cVVV", | ||
| 412 | vpkuwum_3 = "1000004eVVV", | ||
| 413 | vadduwm_3 = "10000080VVV", | ||
| 414 | vmaxuw_3 = "10000082VVV", | ||
| 415 | vrlw_3 = "10000084VVV", | ||
| 416 | vcmpequw_3 = "10000086VVV", | ||
| 417 | vmulouw_3 = "10000088VVV", | ||
| 418 | vmuluwm_3 = "10000089VVV", | ||
| 419 | vmrghw_3 = "1000008cVVV", | ||
| 420 | vpkuhus_3 = "1000008eVVV", | ||
| 421 | vaddudm_3 = "100000c0VVV", | ||
| 422 | vmaxud_3 = "100000c2VVV", | ||
| 423 | vrld_3 = "100000c4VVV", | ||
| 424 | vcmpeqfp_3 = "100000c6VVV", | ||
| 425 | vcmpequd_3 = "100000c7VVV", | ||
| 426 | vpkuwus_3 = "100000ceVVV", | ||
| 427 | vadduqm_3 = "10000100VVV", | ||
| 428 | vmaxsb_3 = "10000102VVV", | ||
| 429 | vslb_3 = "10000104VVV", | ||
| 430 | vmulosb_3 = "10000108VVV", | ||
| 431 | vrefp_2 = "1000010aV-V", | ||
| 432 | vmrglb_3 = "1000010cVVV", | ||
| 433 | vpkshus_3 = "1000010eVVV", | ||
| 434 | vaddcuq_3 = "10000140VVV", | ||
| 435 | vmaxsh_3 = "10000142VVV", | ||
| 436 | vslh_3 = "10000144VVV", | ||
| 437 | vmulosh_3 = "10000148VVV", | ||
| 438 | vrsqrtefp_2 = "1000014aV-V", | ||
| 439 | vmrglh_3 = "1000014cVVV", | ||
| 440 | vpkswus_3 = "1000014eVVV", | ||
| 441 | vaddcuw_3 = "10000180VVV", | ||
| 442 | vmaxsw_3 = "10000182VVV", | ||
| 443 | vslw_3 = "10000184VVV", | ||
| 444 | vmulosw_3 = "10000188VVV", | ||
| 445 | vexptefp_2 = "1000018aV-V", | ||
| 446 | vmrglw_3 = "1000018cVVV", | ||
| 447 | vpkshss_3 = "1000018eVVV", | ||
| 448 | vmaxsd_3 = "100001c2VVV", | ||
| 449 | vsl_3 = "100001c4VVV", | ||
| 450 | vcmpgefp_3 = "100001c6VVV", | ||
| 451 | vlogefp_2 = "100001caV-V", | ||
| 452 | vpkswss_3 = "100001ceVVV", | ||
| 453 | vadduhs_3 = "10000240VVV", | ||
| 454 | vminuh_3 = "10000242VVV", | ||
| 455 | vsrh_3 = "10000244VVV", | ||
| 456 | vcmpgtuh_3 = "10000246VVV", | ||
| 457 | vmuleuh_3 = "10000248VVV", | ||
| 458 | vrfiz_2 = "1000024aV-V", | ||
| 459 | vsplth_3 = "1000024cVV3", | ||
| 460 | vupkhsh_2 = "1000024eV-V", | ||
| 461 | vminuw_3 = "10000282VVV", | ||
| 462 | vminud_3 = "100002c2VVV", | ||
| 463 | vcmpgtud_3 = "100002c7VVV", | ||
| 464 | vrfim_2 = "100002caV-V", | ||
| 465 | vcmpgtsb_3 = "10000306VVV", | ||
| 466 | vcfux_3 = "1000030aVVA~", | ||
| 467 | vaddshs_3 = "10000340VVV", | ||
| 468 | vminsh_3 = "10000342VVV", | ||
| 469 | vsrah_3 = "10000344VVV", | ||
| 470 | vcmpgtsh_3 = "10000346VVV", | ||
| 471 | vmulesh_3 = "10000348VVV", | ||
| 472 | vcfsx_3 = "1000034aVVA~", | ||
| 473 | vspltish_2 = "1000034cVS", | ||
| 474 | vupkhpx_2 = "1000034eV-V", | ||
| 475 | vaddsws_3 = "10000380VVV", | ||
| 476 | vminsw_3 = "10000382VVV", | ||
| 477 | vsraw_3 = "10000384VVV", | ||
| 478 | vcmpgtsw_3 = "10000386VVV", | ||
| 479 | vmulesw_3 = "10000388VVV", | ||
| 480 | vctuxs_3 = "1000038aVVA~", | ||
| 481 | vspltisw_2 = "1000038cVS", | ||
| 482 | vminsd_3 = "100003c2VVV", | ||
| 483 | vsrad_3 = "100003c4VVV", | ||
| 484 | vcmpbfp_3 = "100003c6VVV", | ||
| 485 | vcmpgtsd_3 = "100003c7VVV", | ||
| 486 | vctsxs_3 = "100003caVVA~", | ||
| 487 | vupklpx_2 = "100003ceV-V", | ||
| 488 | vsububm_3 = "10000400VVV", | ||
| 489 | ["bcdadd._4"] = "10000401VVVy.", | ||
| 490 | vavgub_3 = "10000402VVV", | ||
| 491 | vand_3 = "10000404VVV", | ||
| 492 | ["vcmpequb._3"] = "10000406VVV", | ||
| 493 | vmaxfp_3 = "1000040aVVV", | ||
| 494 | vsubuhm_3 = "10000440VVV", | ||
| 495 | ["bcdsub._4"] = "10000441VVVy.", | ||
| 496 | vavguh_3 = "10000442VVV", | ||
| 497 | vandc_3 = "10000444VVV", | ||
| 498 | ["vcmpequh._3"] = "10000446VVV", | ||
| 499 | vminfp_3 = "1000044aVVV", | ||
| 500 | vpkudum_3 = "1000044eVVV", | ||
| 501 | vsubuwm_3 = "10000480VVV", | ||
| 502 | vavguw_3 = "10000482VVV", | ||
| 503 | vor_3 = "10000484VVV", | ||
| 504 | ["vcmpequw._3"] = "10000486VVV", | ||
| 505 | vpmsumw_3 = "10000488VVV", | ||
| 506 | ["vcmpeqfp._3"] = "100004c6VVV", | ||
| 507 | ["vcmpequd._3"] = "100004c7VVV", | ||
| 508 | vpkudus_3 = "100004ceVVV", | ||
| 509 | vavgsb_3 = "10000502VVV", | ||
| 510 | vavgsh_3 = "10000542VVV", | ||
| 511 | vorc_3 = "10000544VVV", | ||
| 512 | vbpermq_3 = "1000054cVVV", | ||
| 513 | vpksdus_3 = "1000054eVVV", | ||
| 514 | vavgsw_3 = "10000582VVV", | ||
| 515 | vsld_3 = "100005c4VVV", | ||
| 516 | ["vcmpgefp._3"] = "100005c6VVV", | ||
| 517 | vpksdss_3 = "100005ceVVV", | ||
| 518 | vsububs_3 = "10000600VVV", | ||
| 519 | mfvscr_1 = "10000604V--", | ||
| 520 | vsum4ubs_3 = "10000608VVV", | ||
| 521 | vsubuhs_3 = "10000640VVV", | ||
| 522 | mtvscr_1 = "10000644--V", | ||
| 523 | ["vcmpgtuh._3"] = "10000646VVV", | ||
| 524 | vsum4shs_3 = "10000648VVV", | ||
| 525 | vupkhsw_2 = "1000064eV-V", | ||
| 526 | vsubuws_3 = "10000680VVV", | ||
| 527 | vshasigmaw_4 = "10000682VVYp", | ||
| 528 | veqv_3 = "10000684VVV", | ||
| 529 | vsum2sws_3 = "10000688VVV", | ||
| 530 | vmrgow_3 = "1000068cVVV", | ||
| 531 | vshasigmad_4 = "100006c2VVYp", | ||
| 532 | vsrd_3 = "100006c4VVV", | ||
| 533 | ["vcmpgtud._3"] = "100006c7VVV", | ||
| 534 | vupklsw_2 = "100006ceV-V", | ||
| 535 | vupkslw_2 = "100006ceV-V", | ||
| 536 | vsubsbs_3 = "10000700VVV", | ||
| 537 | vclzb_2 = "10000702V-V", | ||
| 538 | vpopcntb_2 = "10000703V-V", | ||
| 539 | ["vcmpgtsb._3"] = "10000706VVV", | ||
| 540 | vsum4sbs_3 = "10000708VVV", | ||
| 541 | vsubshs_3 = "10000740VVV", | ||
| 542 | vclzh_2 = "10000742V-V", | ||
| 543 | vpopcnth_2 = "10000743V-V", | ||
| 544 | ["vcmpgtsh._3"] = "10000746VVV", | ||
| 545 | vsubsws_3 = "10000780VVV", | ||
| 546 | vclzw_2 = "10000782V-V", | ||
| 547 | vpopcntw_2 = "10000783V-V", | ||
| 548 | ["vcmpgtsw._3"] = "10000786VVV", | ||
| 549 | vsumsws_3 = "10000788VVV", | ||
| 550 | vmrgew_3 = "1000078cVVV", | ||
| 551 | vclzd_2 = "100007c2V-V", | ||
| 552 | vpopcntd_2 = "100007c3V-V", | ||
| 553 | ["vcmpbfp._3"] = "100007c6VVV", | ||
| 554 | ["vcmpgtsd._3"] = "100007c7VVV", | ||
| 555 | |||
| 300 | -- Primary opcode 19: | 556 | -- Primary opcode 19: |
| 301 | mcrf_2 = "4c000000XX", | 557 | mcrf_2 = "4c000000XX", |
| 302 | isync_0 = "4c00012c", | 558 | isync_0 = "4c00012c", |
| @@ -316,6 +572,8 @@ local map_op = { | |||
| 316 | bclrl_2 = "4c000021AA", | 572 | bclrl_2 = "4c000021AA", |
| 317 | bcctr_2 = "4c000420AA", | 573 | bcctr_2 = "4c000420AA", |
| 318 | bcctrl_2 = "4c000421AA", | 574 | bcctrl_2 = "4c000421AA", |
| 575 | bctar_2 = "4c000460AA", | ||
| 576 | bctarl_2 = "4c000461AA", | ||
| 319 | blr_0 = "4e800020", | 577 | blr_0 = "4e800020", |
| 320 | blrl_0 = "4e800021", | 578 | blrl_0 = "4e800021", |
| 321 | bctr_0 = "4e800420", | 579 | bctr_0 = "4e800420", |
| @@ -327,6 +585,7 @@ local map_op = { | |||
| 327 | cmpd_3 = "7c200000XRR", | 585 | cmpd_3 = "7c200000XRR", |
| 328 | cmpd_2 = "7c200000-RR", | 586 | cmpd_2 = "7c200000-RR", |
| 329 | tw_3 = "7c000008ARR", | 587 | tw_3 = "7c000008ARR", |
| 588 | lvsl_3 = "7c00000cVRR", | ||
| 330 | subfc_3 = "7c000010RRR.", | 589 | subfc_3 = "7c000010RRR.", |
| 331 | subc_3 = "7c000010RRR~.", | 590 | subc_3 = "7c000010RRR~.", |
| 332 | mulhdu_3 = "7c000012RRR.", | 591 | mulhdu_3 = "7c000012RRR.", |
| @@ -351,50 +610,68 @@ local map_op = { | |||
| 351 | cmplw_2 = "7c000040-RR", | 610 | cmplw_2 = "7c000040-RR", |
| 352 | cmpld_3 = "7c200040XRR", | 611 | cmpld_3 = "7c200040XRR", |
| 353 | cmpld_2 = "7c200040-RR", | 612 | cmpld_2 = "7c200040-RR", |
| 613 | lvsr_3 = "7c00004cVRR", | ||
| 354 | subf_3 = "7c000050RRR.", | 614 | subf_3 = "7c000050RRR.", |
| 355 | sub_3 = "7c000050RRR~.", | 615 | sub_3 = "7c000050RRR~.", |
| 616 | lbarx_3 = "7c000068RR0R", | ||
| 356 | ldux_3 = "7c00006aRR0R", | 617 | ldux_3 = "7c00006aRR0R", |
| 357 | dcbst_2 = "7c00006c-RR", | 618 | dcbst_2 = "7c00006c-RR", |
| 358 | lwzux_3 = "7c00006eRR0R", | 619 | lwzux_3 = "7c00006eRR0R", |
| 359 | cntlzd_2 = "7c000074RR~", | 620 | cntlzd_2 = "7c000074RR~", |
| 360 | andc_3 = "7c000078RR~R.", | 621 | andc_3 = "7c000078RR~R.", |
| 361 | td_3 = "7c000088ARR", | 622 | td_3 = "7c000088ARR", |
| 623 | lvewx_3 = "7c00008eVRR", | ||
| 362 | mulhd_3 = "7c000092RRR.", | 624 | mulhd_3 = "7c000092RRR.", |
| 625 | addg6s_3 = "7c000094RRR", | ||
| 363 | mulhw_3 = "7c000096RRR.", | 626 | mulhw_3 = "7c000096RRR.", |
| 627 | dlmzb_3 = "7c00009cRR~R.", | ||
| 364 | ldarx_3 = "7c0000a8RR0R", | 628 | ldarx_3 = "7c0000a8RR0R", |
| 365 | dcbf_2 = "7c0000ac-RR", | 629 | dcbf_2 = "7c0000ac-RR", |
| 366 | lbzx_3 = "7c0000aeRR0R", | 630 | lbzx_3 = "7c0000aeRR0R", |
| 631 | lvx_3 = "7c0000ceVRR", | ||
| 367 | neg_2 = "7c0000d0RR.", | 632 | neg_2 = "7c0000d0RR.", |
| 633 | lharx_3 = "7c0000e8RR0R", | ||
| 368 | lbzux_3 = "7c0000eeRR0R", | 634 | lbzux_3 = "7c0000eeRR0R", |
| 369 | popcntb_2 = "7c0000f4RR~", | 635 | popcntb_2 = "7c0000f4RR~", |
| 370 | not_2 = "7c0000f8RR~%.", | 636 | not_2 = "7c0000f8RR~%.", |
| 371 | nor_3 = "7c0000f8RR~R.", | 637 | nor_3 = "7c0000f8RR~R.", |
| 638 | stvebx_3 = "7c00010eVRR", | ||
| 372 | subfe_3 = "7c000110RRR.", | 639 | subfe_3 = "7c000110RRR.", |
| 373 | sube_3 = "7c000110RRR~.", | 640 | sube_3 = "7c000110RRR~.", |
| 374 | adde_3 = "7c000114RRR.", | 641 | adde_3 = "7c000114RRR.", |
| 375 | stdx_3 = "7c00012aRR0R", | 642 | stdx_3 = "7c00012aRR0R", |
| 376 | stwcx_3 = "7c00012cRR0R.", | 643 | ["stwcx._3"] = "7c00012dRR0R.", |
| 377 | stwx_3 = "7c00012eRR0R", | 644 | stwx_3 = "7c00012eRR0R", |
| 378 | prtyw_2 = "7c000134RR~", | 645 | prtyw_2 = "7c000134RR~", |
| 646 | stvehx_3 = "7c00014eVRR", | ||
| 379 | stdux_3 = "7c00016aRR0R", | 647 | stdux_3 = "7c00016aRR0R", |
| 648 | ["stqcx._3"] = "7c00016dR:R0R.", | ||
| 380 | stwux_3 = "7c00016eRR0R", | 649 | stwux_3 = "7c00016eRR0R", |
| 381 | prtyd_2 = "7c000174RR~", | 650 | prtyd_2 = "7c000174RR~", |
| 651 | stvewx_3 = "7c00018eVRR", | ||
| 382 | subfze_2 = "7c000190RR.", | 652 | subfze_2 = "7c000190RR.", |
| 383 | addze_2 = "7c000194RR.", | 653 | addze_2 = "7c000194RR.", |
| 384 | stdcx_3 = "7c0001acRR0R.", | 654 | ["stdcx._3"] = "7c0001adRR0R.", |
| 385 | stbx_3 = "7c0001aeRR0R", | 655 | stbx_3 = "7c0001aeRR0R", |
| 656 | stvx_3 = "7c0001ceVRR", | ||
| 386 | subfme_2 = "7c0001d0RR.", | 657 | subfme_2 = "7c0001d0RR.", |
| 387 | mulld_3 = "7c0001d2RRR.", | 658 | mulld_3 = "7c0001d2RRR.", |
| 388 | addme_2 = "7c0001d4RR.", | 659 | addme_2 = "7c0001d4RR.", |
| 389 | mullw_3 = "7c0001d6RRR.", | 660 | mullw_3 = "7c0001d6RRR.", |
| 390 | dcbtst_2 = "7c0001ec-RR", | 661 | dcbtst_2 = "7c0001ec-RR", |
| 391 | stbux_3 = "7c0001eeRR0R", | 662 | stbux_3 = "7c0001eeRR0R", |
| 663 | bpermd_3 = "7c0001f8RR~R", | ||
| 664 | lvepxl_3 = "7c00020eVRR", | ||
| 392 | add_3 = "7c000214RRR.", | 665 | add_3 = "7c000214RRR.", |
| 666 | lqarx_3 = "7c000228R:R0R", | ||
| 393 | dcbt_2 = "7c00022c-RR", | 667 | dcbt_2 = "7c00022c-RR", |
| 394 | lhzx_3 = "7c00022eRR0R", | 668 | lhzx_3 = "7c00022eRR0R", |
| 669 | cdtbcd_2 = "7c000234RR~", | ||
| 395 | eqv_3 = "7c000238RR~R.", | 670 | eqv_3 = "7c000238RR~R.", |
| 671 | lvepx_3 = "7c00024eVRR", | ||
| 396 | eciwx_3 = "7c00026cRR0R", | 672 | eciwx_3 = "7c00026cRR0R", |
| 397 | lhzux_3 = "7c00026eRR0R", | 673 | lhzux_3 = "7c00026eRR0R", |
| 674 | cbcdtd_2 = "7c000274RR~", | ||
| 398 | xor_3 = "7c000278RR~R.", | 675 | xor_3 = "7c000278RR~R.", |
| 399 | mfspefscr_1 = "7c0082a6R", | 676 | mfspefscr_1 = "7c0082a6R", |
| 400 | mfxer_1 = "7c0102a6R", | 677 | mfxer_1 = "7c0102a6R", |
| @@ -404,8 +681,12 @@ local map_op = { | |||
| 404 | lhax_3 = "7c0002aeRR0R", | 681 | lhax_3 = "7c0002aeRR0R", |
| 405 | mftb_1 = "7c0c42e6R", | 682 | mftb_1 = "7c0c42e6R", |
| 406 | mftbu_1 = "7c0d42e6R", | 683 | mftbu_1 = "7c0d42e6R", |
| 684 | lvxl_3 = "7c0002ceVRR", | ||
| 407 | lwaux_3 = "7c0002eaRR0R", | 685 | lwaux_3 = "7c0002eaRR0R", |
| 408 | lhaux_3 = "7c0002eeRR0R", | 686 | lhaux_3 = "7c0002eeRR0R", |
| 687 | popcntw_2 = "7c0002f4RR~", | ||
| 688 | divdeu_3 = "7c000312RRR.", | ||
| 689 | divweu_3 = "7c000316RRR.", | ||
| 409 | sthx_3 = "7c00032eRR0R", | 690 | sthx_3 = "7c00032eRR0R", |
| 410 | orc_3 = "7c000338RR~R.", | 691 | orc_3 = "7c000338RR~R.", |
| 411 | ecowx_3 = "7c00036cRR0R", | 692 | ecowx_3 = "7c00036cRR0R", |
| @@ -420,10 +701,14 @@ local map_op = { | |||
| 420 | mtctr_1 = "7c0903a6R", | 701 | mtctr_1 = "7c0903a6R", |
| 421 | dcbi_2 = "7c0003ac-RR", | 702 | dcbi_2 = "7c0003ac-RR", |
| 422 | nand_3 = "7c0003b8RR~R.", | 703 | nand_3 = "7c0003b8RR~R.", |
| 704 | dsn_2 = "7c0003c6-RR", | ||
| 705 | stvxl_3 = "7c0003ceVRR", | ||
| 423 | divd_3 = "7c0003d2RRR.", | 706 | divd_3 = "7c0003d2RRR.", |
| 424 | divw_3 = "7c0003d6RRR.", | 707 | divw_3 = "7c0003d6RRR.", |
| 708 | popcntd_2 = "7c0003f4RR~", | ||
| 425 | cmpb_3 = "7c0003f8RR~R.", | 709 | cmpb_3 = "7c0003f8RR~R.", |
| 426 | mcrxr_1 = "7c000400X", | 710 | mcrxr_1 = "7c000400X", |
| 711 | lbdx_3 = "7c000406RRR", | ||
| 427 | subfco_3 = "7c000410RRR.", | 712 | subfco_3 = "7c000410RRR.", |
| 428 | subco_3 = "7c000410RRR~.", | 713 | subco_3 = "7c000410RRR~.", |
| 429 | addco_3 = "7c000414RRR.", | 714 | addco_3 = "7c000414RRR.", |
| @@ -433,16 +718,20 @@ local map_op = { | |||
| 433 | lfsx_3 = "7c00042eFR0R", | 718 | lfsx_3 = "7c00042eFR0R", |
| 434 | srw_3 = "7c000430RR~R.", | 719 | srw_3 = "7c000430RR~R.", |
| 435 | srd_3 = "7c000436RR~R.", | 720 | srd_3 = "7c000436RR~R.", |
| 721 | lhdx_3 = "7c000446RRR", | ||
| 436 | subfo_3 = "7c000450RRR.", | 722 | subfo_3 = "7c000450RRR.", |
| 437 | subo_3 = "7c000450RRR~.", | 723 | subo_3 = "7c000450RRR~.", |
| 438 | lfsux_3 = "7c00046eFR0R", | 724 | lfsux_3 = "7c00046eFR0R", |
| 725 | lwdx_3 = "7c000486RRR", | ||
| 439 | lswi_3 = "7c0004aaRR0A", | 726 | lswi_3 = "7c0004aaRR0A", |
| 440 | sync_0 = "7c0004ac", | 727 | sync_0 = "7c0004ac", |
| 441 | lwsync_0 = "7c2004ac", | 728 | lwsync_0 = "7c2004ac", |
| 442 | ptesync_0 = "7c4004ac", | 729 | ptesync_0 = "7c4004ac", |
| 443 | lfdx_3 = "7c0004aeFR0R", | 730 | lfdx_3 = "7c0004aeFR0R", |
| 731 | lddx_3 = "7c0004c6RRR", | ||
| 444 | nego_2 = "7c0004d0RR.", | 732 | nego_2 = "7c0004d0RR.", |
| 445 | lfdux_3 = "7c0004eeFR0R", | 733 | lfdux_3 = "7c0004eeFR0R", |
| 734 | stbdx_3 = "7c000506RRR", | ||
| 446 | subfeo_3 = "7c000510RRR.", | 735 | subfeo_3 = "7c000510RRR.", |
| 447 | subeo_3 = "7c000510RRR~.", | 736 | subeo_3 = "7c000510RRR~.", |
| 448 | addeo_3 = "7c000514RRR.", | 737 | addeo_3 = "7c000514RRR.", |
| @@ -450,27 +739,42 @@ local map_op = { | |||
| 450 | stswx_3 = "7c00052aRR0R", | 739 | stswx_3 = "7c00052aRR0R", |
| 451 | stwbrx_3 = "7c00052cRR0R", | 740 | stwbrx_3 = "7c00052cRR0R", |
| 452 | stfsx_3 = "7c00052eFR0R", | 741 | stfsx_3 = "7c00052eFR0R", |
| 742 | sthdx_3 = "7c000546RRR", | ||
| 743 | ["stbcx._3"] = "7c00056dRRR", | ||
| 453 | stfsux_3 = "7c00056eFR0R", | 744 | stfsux_3 = "7c00056eFR0R", |
| 745 | stwdx_3 = "7c000586RRR", | ||
| 454 | subfzeo_2 = "7c000590RR.", | 746 | subfzeo_2 = "7c000590RR.", |
| 455 | addzeo_2 = "7c000594RR.", | 747 | addzeo_2 = "7c000594RR.", |
| 456 | stswi_3 = "7c0005aaRR0A", | 748 | stswi_3 = "7c0005aaRR0A", |
| 749 | ["sthcx._3"] = "7c0005adRRR", | ||
| 457 | stfdx_3 = "7c0005aeFR0R", | 750 | stfdx_3 = "7c0005aeFR0R", |
| 751 | stddx_3 = "7c0005c6RRR", | ||
| 458 | subfmeo_2 = "7c0005d0RR.", | 752 | subfmeo_2 = "7c0005d0RR.", |
| 459 | mulldo_3 = "7c0005d2RRR.", | 753 | mulldo_3 = "7c0005d2RRR.", |
| 460 | addmeo_2 = "7c0005d4RR.", | 754 | addmeo_2 = "7c0005d4RR.", |
| 461 | mullwo_3 = "7c0005d6RRR.", | 755 | mullwo_3 = "7c0005d6RRR.", |
| 462 | dcba_2 = "7c0005ec-RR", | 756 | dcba_2 = "7c0005ec-RR", |
| 463 | stfdux_3 = "7c0005eeFR0R", | 757 | stfdux_3 = "7c0005eeFR0R", |
| 758 | stvepxl_3 = "7c00060eVRR", | ||
| 464 | addo_3 = "7c000614RRR.", | 759 | addo_3 = "7c000614RRR.", |
| 465 | lhbrx_3 = "7c00062cRR0R", | 760 | lhbrx_3 = "7c00062cRR0R", |
| 761 | lfdpx_3 = "7c00062eF:RR", | ||
| 466 | sraw_3 = "7c000630RR~R.", | 762 | sraw_3 = "7c000630RR~R.", |
| 467 | srad_3 = "7c000634RR~R.", | 763 | srad_3 = "7c000634RR~R.", |
| 764 | lfddx_3 = "7c000646FRR", | ||
| 765 | stvepx_3 = "7c00064eVRR", | ||
| 468 | srawi_3 = "7c000670RR~A.", | 766 | srawi_3 = "7c000670RR~A.", |
| 469 | sradi_3 = "7c000674RR~H.", | 767 | sradi_3 = "7c000674RR~H.", |
| 470 | eieio_0 = "7c0006ac", | 768 | eieio_0 = "7c0006ac", |
| 471 | lfiwax_3 = "7c0006aeFR0R", | 769 | lfiwax_3 = "7c0006aeFR0R", |
| 770 | divdeuo_3 = "7c000712RRR.", | ||
| 771 | divweuo_3 = "7c000716RRR.", | ||
| 472 | sthbrx_3 = "7c00072cRR0R", | 772 | sthbrx_3 = "7c00072cRR0R", |
| 773 | stfdpx_3 = "7c00072eF:RR", | ||
| 473 | extsh_2 = "7c000734RR~.", | 774 | extsh_2 = "7c000734RR~.", |
| 775 | stfddx_3 = "7c000746FRR", | ||
| 776 | divdeo_3 = "7c000752RRR.", | ||
| 777 | divweo_3 = "7c000756RRR.", | ||
| 474 | extsb_2 = "7c000774RR~.", | 778 | extsb_2 = "7c000774RR~.", |
| 475 | divduo_3 = "7c000792RRR.", | 779 | divduo_3 = "7c000792RRR.", |
| 476 | divwou_3 = "7c000796RRR.", | 780 | divwou_3 = "7c000796RRR.", |
| @@ -481,6 +785,40 @@ local map_op = { | |||
| 481 | divwo_3 = "7c0007d6RRR.", | 785 | divwo_3 = "7c0007d6RRR.", |
| 482 | dcbz_2 = "7c0007ec-RR", | 786 | dcbz_2 = "7c0007ec-RR", |
| 483 | 787 | ||
| 788 | ["tbegin._1"] = "7c00051d1", | ||
| 789 | ["tbegin._0"] = "7c00051d", | ||
| 790 | ["tend._1"] = "7c00055dY", | ||
| 791 | ["tend._0"] = "7c00055d", | ||
| 792 | ["tendall._0"] = "7e00055d", | ||
| 793 | tcheck_1 = "7c00059cX", | ||
| 794 | ["tsr._1"] = "7c0005dd1", | ||
| 795 | ["tsuspend._0"] = "7c0005dd", | ||
| 796 | ["tresume._0"] = "7c2005dd", | ||
| 797 | ["tabortwc._3"] = "7c00061dARR", | ||
| 798 | ["tabortdc._3"] = "7c00065dARR", | ||
| 799 | ["tabortwci._3"] = "7c00069dARS", | ||
| 800 | ["tabortdci._3"] = "7c0006ddARS", | ||
| 801 | ["tabort._1"] = "7c00071d-R-", | ||
| 802 | ["treclaim._1"] = "7c00075d-R", | ||
| 803 | ["trechkpt._0"] = "7c0007dd", | ||
| 804 | |||
| 805 | lxsiwzx_3 = "7c000018QRR", | ||
| 806 | lxsiwax_3 = "7c000098QRR", | ||
| 807 | mfvsrd_2 = "7c000066-Rq", | ||
| 808 | mfvsrwz_2 = "7c0000e6-Rq", | ||
| 809 | stxsiwx_3 = "7c000118QRR", | ||
| 810 | mtvsrd_2 = "7c000166QR", | ||
| 811 | mtvsrwa_2 = "7c0001a6QR", | ||
| 812 | lxvdsx_3 = "7c000298QRR", | ||
| 813 | lxsspx_3 = "7c000418QRR", | ||
| 814 | lxsdx_3 = "7c000498QRR", | ||
| 815 | stxsspx_3 = "7c000518QRR", | ||
| 816 | stxsdx_3 = "7c000598QRR", | ||
| 817 | lxvw4x_3 = "7c000618QRR", | ||
| 818 | lxvd2x_3 = "7c000698QRR", | ||
| 819 | stxvw4x_3 = "7c000718QRR", | ||
| 820 | stxvd2x_3 = "7c000798QRR", | ||
| 821 | |||
| 484 | -- Primary opcode 30: | 822 | -- Primary opcode 30: |
| 485 | rldicl_4 = "78000000RR~HM.", | 823 | rldicl_4 = "78000000RR~HM.", |
| 486 | rldicr_4 = "78000004RR~HM.", | 824 | rldicr_4 = "78000004RR~HM.", |
| @@ -489,6 +827,34 @@ local map_op = { | |||
| 489 | rldcl_4 = "78000010RR~RM.", | 827 | rldcl_4 = "78000010RR~RM.", |
| 490 | rldcr_4 = "78000012RR~RM.", | 828 | rldcr_4 = "78000012RR~RM.", |
| 491 | 829 | ||
| 830 | rotldi_3 = op_alias("rldicl_4", function(p) | ||
| 831 | p[4] = "0" | ||
| 832 | end), | ||
| 833 | rotrdi_3 = op_alias("rldicl_4", function(p) | ||
| 834 | p[3] = "64-("..p[3]..")"; p[4] = "0" | ||
| 835 | end), | ||
| 836 | rotld_3 = op_alias("rldcl_4", function(p) | ||
| 837 | p[4] = "0" | ||
| 838 | end), | ||
| 839 | sldi_3 = op_alias("rldicr_4", function(p) | ||
| 840 | p[4] = "63-("..p[3]..")" | ||
| 841 | end), | ||
| 842 | srdi_3 = op_alias("rldicl_4", function(p) | ||
| 843 | p[4] = p[3]; p[3] = "64-("..p[3]..")" | ||
| 844 | end), | ||
| 845 | clrldi_3 = op_alias("rldicl_4", function(p) | ||
| 846 | p[4] = p[3]; p[3] = "0" | ||
| 847 | end), | ||
| 848 | clrrdi_3 = op_alias("rldicr_4", function(p) | ||
| 849 | p[4] = "63-("..p[3]..")"; p[3] = "0" | ||
| 850 | end), | ||
| 851 | |||
| 852 | -- Primary opcode 56: | ||
| 853 | lq_2 = "e0000000R:D", -- NYI: displacement must be divisible by 8. | ||
| 854 | |||
| 855 | -- Primary opcode 57: | ||
| 856 | lfdp_2 = "e4000000F:D", -- NYI: displacement must be divisible by 4. | ||
| 857 | |||
| 492 | -- Primary opcode 59: | 858 | -- Primary opcode 59: |
| 493 | fdivs_3 = "ec000024FFF.", | 859 | fdivs_3 = "ec000024FFF.", |
| 494 | fsubs_3 = "ec000028FFF.", | 860 | fsubs_3 = "ec000028FFF.", |
| @@ -501,6 +867,200 @@ local map_op = { | |||
| 501 | fmadds_4 = "ec00003aFFFF~.", | 867 | fmadds_4 = "ec00003aFFFF~.", |
| 502 | fnmsubs_4 = "ec00003cFFFF~.", | 868 | fnmsubs_4 = "ec00003cFFFF~.", |
| 503 | fnmadds_4 = "ec00003eFFFF~.", | 869 | fnmadds_4 = "ec00003eFFFF~.", |
| 870 | fcfids_2 = "ec00069cF-F.", | ||
| 871 | fcfidus_2 = "ec00079cF-F.", | ||
| 872 | |||
| 873 | dadd_3 = "ec000004FFF.", | ||
| 874 | dqua_4 = "ec000006FFFZ.", | ||
| 875 | dmul_3 = "ec000044FFF.", | ||
| 876 | drrnd_4 = "ec000046FFFZ.", | ||
| 877 | dscli_3 = "ec000084FF6.", | ||
| 878 | dquai_4 = "ec000086SF~FZ.", | ||
| 879 | dscri_3 = "ec0000c4FF6.", | ||
| 880 | drintx_4 = "ec0000c61F~FZ.", | ||
| 881 | dcmpo_3 = "ec000104XFF", | ||
| 882 | dtstex_3 = "ec000144XFF", | ||
| 883 | dtstdc_3 = "ec000184XF6", | ||
| 884 | dtstdg_3 = "ec0001c4XF6", | ||
| 885 | drintn_4 = "ec0001c61F~FZ.", | ||
| 886 | dctdp_2 = "ec000204F-F.", | ||
| 887 | dctfix_2 = "ec000244F-F.", | ||
| 888 | ddedpd_3 = "ec000284ZF~F.", | ||
| 889 | dxex_2 = "ec0002c4F-F.", | ||
| 890 | dsub_3 = "ec000404FFF.", | ||
| 891 | ddiv_3 = "ec000444FFF.", | ||
| 892 | dcmpu_3 = "ec000504XFF", | ||
| 893 | dtstsf_3 = "ec000544XFF", | ||
| 894 | drsp_2 = "ec000604F-F.", | ||
| 895 | dcffix_2 = "ec000644F-F.", | ||
| 896 | denbcd_3 = "ec000684YF~F.", | ||
| 897 | diex_3 = "ec0006c4FFF.", | ||
| 898 | |||
| 899 | -- Primary opcode 60: | ||
| 900 | xsaddsp_3 = "f0000000QQQ", | ||
| 901 | xsmaddasp_3 = "f0000008QQQ", | ||
| 902 | xxsldwi_4 = "f0000010QQQz", | ||
| 903 | xsrsqrtesp_2 = "f0000028Q-Q", | ||
| 904 | xssqrtsp_2 = "f000002cQ-Q", | ||
| 905 | xxsel_4 = "f0000030QQQQ", | ||
| 906 | xssubsp_3 = "f0000040QQQ", | ||
| 907 | xsmaddmsp_3 = "f0000048QQQ", | ||
| 908 | xxpermdi_4 = "f0000050QQQz", | ||
| 909 | xsresp_2 = "f0000068Q-Q", | ||
| 910 | xsmulsp_3 = "f0000080QQQ", | ||
| 911 | xsmsubasp_3 = "f0000088QQQ", | ||
| 912 | xxmrghw_3 = "f0000090QQQ", | ||
| 913 | xsdivsp_3 = "f00000c0QQQ", | ||
| 914 | xsmsubmsp_3 = "f00000c8QQQ", | ||
| 915 | xsadddp_3 = "f0000100QQQ", | ||
| 916 | xsmaddadp_3 = "f0000108QQQ", | ||
| 917 | xscmpudp_3 = "f0000118XQQ", | ||
| 918 | xscvdpuxws_2 = "f0000120Q-Q", | ||
| 919 | xsrdpi_2 = "f0000124Q-Q", | ||
| 920 | xsrsqrtedp_2 = "f0000128Q-Q", | ||
| 921 | xssqrtdp_2 = "f000012cQ-Q", | ||
| 922 | xssubdp_3 = "f0000140QQQ", | ||
| 923 | xsmaddmdp_3 = "f0000148QQQ", | ||
| 924 | xscmpodp_3 = "f0000158XQQ", | ||
| 925 | xscvdpsxws_2 = "f0000160Q-Q", | ||
| 926 | xsrdpiz_2 = "f0000164Q-Q", | ||
| 927 | xsredp_2 = "f0000168Q-Q", | ||
| 928 | xsmuldp_3 = "f0000180QQQ", | ||
| 929 | xsmsubadp_3 = "f0000188QQQ", | ||
| 930 | xxmrglw_3 = "f0000190QQQ", | ||
| 931 | xsrdpip_2 = "f00001a4Q-Q", | ||
| 932 | xstsqrtdp_2 = "f00001a8X-Q", | ||
| 933 | xsrdpic_2 = "f00001acQ-Q", | ||
| 934 | xsdivdp_3 = "f00001c0QQQ", | ||
| 935 | xsmsubmdp_3 = "f00001c8QQQ", | ||
| 936 | xsrdpim_2 = "f00001e4Q-Q", | ||
| 937 | xstdivdp_3 = "f00001e8XQQ", | ||
| 938 | xvaddsp_3 = "f0000200QQQ", | ||
| 939 | xvmaddasp_3 = "f0000208QQQ", | ||
| 940 | xvcmpeqsp_3 = "f0000218QQQ", | ||
| 941 | xvcvspuxws_2 = "f0000220Q-Q", | ||
| 942 | xvrspi_2 = "f0000224Q-Q", | ||
| 943 | xvrsqrtesp_2 = "f0000228Q-Q", | ||
| 944 | xvsqrtsp_2 = "f000022cQ-Q", | ||
| 945 | xvsubsp_3 = "f0000240QQQ", | ||
| 946 | xvmaddmsp_3 = "f0000248QQQ", | ||
| 947 | xvcmpgtsp_3 = "f0000258QQQ", | ||
| 948 | xvcvspsxws_2 = "f0000260Q-Q", | ||
| 949 | xvrspiz_2 = "f0000264Q-Q", | ||
| 950 | xvresp_2 = "f0000268Q-Q", | ||
| 951 | xvmulsp_3 = "f0000280QQQ", | ||
| 952 | xvmsubasp_3 = "f0000288QQQ", | ||
| 953 | xxspltw_3 = "f0000290QQg~", | ||
| 954 | xvcmpgesp_3 = "f0000298QQQ", | ||
| 955 | xvcvuxwsp_2 = "f00002a0Q-Q", | ||
| 956 | xvrspip_2 = "f00002a4Q-Q", | ||
| 957 | xvtsqrtsp_2 = "f00002a8X-Q", | ||
| 958 | xvrspic_2 = "f00002acQ-Q", | ||
| 959 | xvdivsp_3 = "f00002c0QQQ", | ||
| 960 | xvmsubmsp_3 = "f00002c8QQQ", | ||
| 961 | xvcvsxwsp_2 = "f00002e0Q-Q", | ||
| 962 | xvrspim_2 = "f00002e4Q-Q", | ||
| 963 | xvtdivsp_3 = "f00002e8XQQ", | ||
| 964 | xvadddp_3 = "f0000300QQQ", | ||
| 965 | xvmaddadp_3 = "f0000308QQQ", | ||
| 966 | xvcmpeqdp_3 = "f0000318QQQ", | ||
| 967 | xvcvdpuxws_2 = "f0000320Q-Q", | ||
| 968 | xvrdpi_2 = "f0000324Q-Q", | ||
| 969 | xvrsqrtedp_2 = "f0000328Q-Q", | ||
| 970 | xvsqrtdp_2 = "f000032cQ-Q", | ||
| 971 | xvsubdp_3 = "f0000340QQQ", | ||
| 972 | xvmaddmdp_3 = "f0000348QQQ", | ||
| 973 | xvcmpgtdp_3 = "f0000358QQQ", | ||
| 974 | xvcvdpsxws_2 = "f0000360Q-Q", | ||
| 975 | xvrdpiz_2 = "f0000364Q-Q", | ||
| 976 | xvredp_2 = "f0000368Q-Q", | ||
| 977 | xvmuldp_3 = "f0000380QQQ", | ||
| 978 | xvmsubadp_3 = "f0000388QQQ", | ||
| 979 | xvcmpgedp_3 = "f0000398QQQ", | ||
| 980 | xvcvuxwdp_2 = "f00003a0Q-Q", | ||
| 981 | xvrdpip_2 = "f00003a4Q-Q", | ||
| 982 | xvtsqrtdp_2 = "f00003a8X-Q", | ||
| 983 | xvrdpic_2 = "f00003acQ-Q", | ||
| 984 | xvdivdp_3 = "f00003c0QQQ", | ||
| 985 | xvmsubmdp_3 = "f00003c8QQQ", | ||
| 986 | xvcvsxwdp_2 = "f00003e0Q-Q", | ||
| 987 | xvrdpim_2 = "f00003e4Q-Q", | ||
| 988 | xvtdivdp_3 = "f00003e8XQQ", | ||
| 989 | xsnmaddasp_3 = "f0000408QQQ", | ||
| 990 | xxland_3 = "f0000410QQQ", | ||
| 991 | xscvdpsp_2 = "f0000424Q-Q", | ||
| 992 | xscvdpspn_2 = "f000042cQ-Q", | ||
| 993 | xsnmaddmsp_3 = "f0000448QQQ", | ||
| 994 | xxlandc_3 = "f0000450QQQ", | ||
| 995 | xsrsp_2 = "f0000464Q-Q", | ||
| 996 | xsnmsubasp_3 = "f0000488QQQ", | ||
| 997 | xxlor_3 = "f0000490QQQ", | ||
| 998 | xscvuxdsp_2 = "f00004a0Q-Q", | ||
| 999 | xsnmsubmsp_3 = "f00004c8QQQ", | ||
| 1000 | xxlxor_3 = "f00004d0QQQ", | ||
| 1001 | xscvsxdsp_2 = "f00004e0Q-Q", | ||
| 1002 | xsmaxdp_3 = "f0000500QQQ", | ||
| 1003 | xsnmaddadp_3 = "f0000508QQQ", | ||
| 1004 | xxlnor_3 = "f0000510QQQ", | ||
| 1005 | xscvdpuxds_2 = "f0000520Q-Q", | ||
| 1006 | xscvspdp_2 = "f0000524Q-Q", | ||
| 1007 | xscvspdpn_2 = "f000052cQ-Q", | ||
| 1008 | xsmindp_3 = "f0000540QQQ", | ||
| 1009 | xsnmaddmdp_3 = "f0000548QQQ", | ||
| 1010 | xxlorc_3 = "f0000550QQQ", | ||
| 1011 | xscvdpsxds_2 = "f0000560Q-Q", | ||
| 1012 | xsabsdp_2 = "f0000564Q-Q", | ||
| 1013 | xscpsgndp_3 = "f0000580QQQ", | ||
| 1014 | xsnmsubadp_3 = "f0000588QQQ", | ||
| 1015 | xxlnand_3 = "f0000590QQQ", | ||
| 1016 | xscvuxddp_2 = "f00005a0Q-Q", | ||
| 1017 | xsnabsdp_2 = "f00005a4Q-Q", | ||
| 1018 | xsnmsubmdp_3 = "f00005c8QQQ", | ||
| 1019 | xxleqv_3 = "f00005d0QQQ", | ||
| 1020 | xscvsxddp_2 = "f00005e0Q-Q", | ||
| 1021 | xsnegdp_2 = "f00005e4Q-Q", | ||
| 1022 | xvmaxsp_3 = "f0000600QQQ", | ||
| 1023 | xvnmaddasp_3 = "f0000608QQQ", | ||
| 1024 | ["xvcmpeqsp._3"] = "f0000618QQQ", | ||
| 1025 | xvcvspuxds_2 = "f0000620Q-Q", | ||
| 1026 | xvcvdpsp_2 = "f0000624Q-Q", | ||
| 1027 | xvminsp_3 = "f0000640QQQ", | ||
| 1028 | xvnmaddmsp_3 = "f0000648QQQ", | ||
| 1029 | ["xvcmpgtsp._3"] = "f0000658QQQ", | ||
| 1030 | xvcvspsxds_2 = "f0000660Q-Q", | ||
| 1031 | xvabssp_2 = "f0000664Q-Q", | ||
| 1032 | xvcpsgnsp_3 = "f0000680QQQ", | ||
| 1033 | xvnmsubasp_3 = "f0000688QQQ", | ||
| 1034 | ["xvcmpgesp._3"] = "f0000698QQQ", | ||
| 1035 | xvcvuxdsp_2 = "f00006a0Q-Q", | ||
| 1036 | xvnabssp_2 = "f00006a4Q-Q", | ||
| 1037 | xvnmsubmsp_3 = "f00006c8QQQ", | ||
| 1038 | xvcvsxdsp_2 = "f00006e0Q-Q", | ||
| 1039 | xvnegsp_2 = "f00006e4Q-Q", | ||
| 1040 | xvmaxdp_3 = "f0000700QQQ", | ||
| 1041 | xvnmaddadp_3 = "f0000708QQQ", | ||
| 1042 | ["xvcmpeqdp._3"] = "f0000718QQQ", | ||
| 1043 | xvcvdpuxds_2 = "f0000720Q-Q", | ||
| 1044 | xvcvspdp_2 = "f0000724Q-Q", | ||
| 1045 | xvmindp_3 = "f0000740QQQ", | ||
| 1046 | xvnmaddmdp_3 = "f0000748QQQ", | ||
| 1047 | ["xvcmpgtdp._3"] = "f0000758QQQ", | ||
| 1048 | xvcvdpsxds_2 = "f0000760Q-Q", | ||
| 1049 | xvabsdp_2 = "f0000764Q-Q", | ||
| 1050 | xvcpsgndp_3 = "f0000780QQQ", | ||
| 1051 | xvnmsubadp_3 = "f0000788QQQ", | ||
| 1052 | ["xvcmpgedp._3"] = "f0000798QQQ", | ||
| 1053 | xvcvuxddp_2 = "f00007a0Q-Q", | ||
| 1054 | xvnabsdp_2 = "f00007a4Q-Q", | ||
| 1055 | xvnmsubmdp_3 = "f00007c8QQQ", | ||
| 1056 | xvcvsxddp_2 = "f00007e0Q-Q", | ||
| 1057 | xvnegdp_2 = "f00007e4Q-Q", | ||
| 1058 | |||
| 1059 | -- Primary opcode 61: | ||
| 1060 | stfdp_2 = "f4000000F:D", -- NYI: displacement must be divisible by 4. | ||
| 1061 | |||
| 1062 | -- Primary opcode 62: | ||
| 1063 | stq_2 = "f8000002R:D", -- NYI: displacement must be divisible by 8. | ||
| 504 | 1064 | ||
| 505 | -- Primary opcode 63: | 1065 | -- Primary opcode 63: |
| 506 | fdiv_3 = "fc000024FFF.", | 1066 | fdiv_3 = "fc000024FFF.", |
| @@ -526,8 +1086,12 @@ local map_op = { | |||
| 526 | frsp_2 = "fc000018F-F.", | 1086 | frsp_2 = "fc000018F-F.", |
| 527 | fctiw_2 = "fc00001cF-F.", | 1087 | fctiw_2 = "fc00001cF-F.", |
| 528 | fctiwz_2 = "fc00001eF-F.", | 1088 | fctiwz_2 = "fc00001eF-F.", |
| 1089 | ftdiv_2 = "fc000100X-F.", | ||
| 1090 | fctiwu_2 = "fc00011cF-F.", | ||
| 1091 | fctiwuz_2 = "fc00011eF-F.", | ||
| 529 | mtfsfi_2 = "fc00010cAA", -- NYI: upshift. | 1092 | mtfsfi_2 = "fc00010cAA", -- NYI: upshift. |
| 530 | fnabs_2 = "fc000110F-F.", | 1093 | fnabs_2 = "fc000110F-F.", |
| 1094 | ftsqrt_2 = "fc000140X-F.", | ||
| 531 | fabs_2 = "fc000210F-F.", | 1095 | fabs_2 = "fc000210F-F.", |
| 532 | frin_2 = "fc000310F-F.", | 1096 | frin_2 = "fc000310F-F.", |
| 533 | friz_2 = "fc000350F-F.", | 1097 | friz_2 = "fc000350F-F.", |
| @@ -537,7 +1101,38 @@ local map_op = { | |||
| 537 | -- NYI: mtfsf, mtfsb0, mtfsb1. | 1101 | -- NYI: mtfsf, mtfsb0, mtfsb1. |
| 538 | fctid_2 = "fc00065cF-F.", | 1102 | fctid_2 = "fc00065cF-F.", |
| 539 | fctidz_2 = "fc00065eF-F.", | 1103 | fctidz_2 = "fc00065eF-F.", |
| 1104 | fmrgow_3 = "fc00068cFFF", | ||
| 540 | fcfid_2 = "fc00069cF-F.", | 1105 | fcfid_2 = "fc00069cF-F.", |
| 1106 | fctidu_2 = "fc00075cF-F.", | ||
| 1107 | fctiduz_2 = "fc00075eF-F.", | ||
| 1108 | fmrgew_3 = "fc00078cFFF", | ||
| 1109 | fcfidu_2 = "fc00079cF-F.", | ||
| 1110 | |||
| 1111 | daddq_3 = "fc000004F:F:F:.", | ||
| 1112 | dquaq_4 = "fc000006F:F:F:Z.", | ||
| 1113 | dmulq_3 = "fc000044F:F:F:.", | ||
| 1114 | drrndq_4 = "fc000046F:F:F:Z.", | ||
| 1115 | dscliq_3 = "fc000084F:F:6.", | ||
| 1116 | dquaiq_4 = "fc000086SF:~F:Z.", | ||
| 1117 | dscriq_3 = "fc0000c4F:F:6.", | ||
| 1118 | drintxq_4 = "fc0000c61F:~F:Z.", | ||
| 1119 | dcmpoq_3 = "fc000104XF:F:", | ||
| 1120 | dtstexq_3 = "fc000144XF:F:", | ||
| 1121 | dtstdcq_3 = "fc000184XF:6", | ||
| 1122 | dtstdgq_3 = "fc0001c4XF:6", | ||
| 1123 | drintnq_4 = "fc0001c61F:~F:Z.", | ||
| 1124 | dctqpq_2 = "fc000204F:-F:.", | ||
| 1125 | dctfixq_2 = "fc000244F:-F:.", | ||
| 1126 | ddedpdq_3 = "fc000284ZF:~F:.", | ||
| 1127 | dxexq_2 = "fc0002c4F:-F:.", | ||
| 1128 | dsubq_3 = "fc000404F:F:F:.", | ||
| 1129 | ddivq_3 = "fc000444F:F:F:.", | ||
| 1130 | dcmpuq_3 = "fc000504XF:F:", | ||
| 1131 | dtstsfq_3 = "fc000544XF:F:", | ||
| 1132 | drdpq_2 = "fc000604F:-F:.", | ||
| 1133 | dcffixq_2 = "fc000644F:-F:.", | ||
| 1134 | denbcdq_3 = "fc000684YF:~F:.", | ||
| 1135 | diexq_3 = "fc0006c4F:FF:.", | ||
| 541 | 1136 | ||
| 542 | -- Primary opcode 4, SPE APU extension: | 1137 | -- Primary opcode 4, SPE APU extension: |
| 543 | evaddw_3 = "10000200RRR", | 1138 | evaddw_3 = "10000200RRR", |
| @@ -822,7 +1417,7 @@ local map_op = { | |||
| 822 | do | 1417 | do |
| 823 | local t = {} | 1418 | local t = {} |
| 824 | for k,v in pairs(map_op) do | 1419 | for k,v in pairs(map_op) do |
| 825 | if sub(v, -1) == "." then | 1420 | if type(v) == "string" and sub(v, -1) == "." then |
| 826 | local v2 = sub(v, 1, 7)..char(byte(v, 8)+1)..sub(v, 9, -2) | 1421 | local v2 = sub(v, 1, 7)..char(byte(v, 8)+1)..sub(v, 9, -2) |
| 827 | t[sub(k, 1, -3).."."..sub(k, -2)] = v2 | 1422 | t[sub(k, 1, -3).."."..sub(k, -2)] = v2 |
| 828 | end | 1423 | end |
| @@ -884,6 +1479,24 @@ local function parse_fpr(expr) | |||
| 884 | werror("bad register name `"..expr.."'") | 1479 | werror("bad register name `"..expr.."'") |
| 885 | end | 1480 | end |
| 886 | 1481 | ||
| 1482 | local function parse_vr(expr) | ||
| 1483 | local r = match(expr, "^v([1-3]?[0-9])$") | ||
| 1484 | if r then | ||
| 1485 | r = tonumber(r) | ||
| 1486 | if r <= 31 then return r end | ||
| 1487 | end | ||
| 1488 | werror("bad register name `"..expr.."'") | ||
| 1489 | end | ||
| 1490 | |||
| 1491 | local function parse_vs(expr) | ||
| 1492 | local r = match(expr, "^vs([1-6]?[0-9])$") | ||
| 1493 | if r then | ||
| 1494 | r = tonumber(r) | ||
| 1495 | if r <= 63 then return r end | ||
| 1496 | end | ||
| 1497 | werror("bad register name `"..expr.."'") | ||
| 1498 | end | ||
| 1499 | |||
| 887 | local function parse_cr(expr) | 1500 | local function parse_cr(expr) |
| 888 | local r = match(expr, "^cr([0-7])$") | 1501 | local r = match(expr, "^cr([0-7])$") |
| 889 | if r then return tonumber(r) end | 1502 | if r then return tonumber(r) end |
| @@ -900,8 +1513,30 @@ local function parse_cond(expr) | |||
| 900 | werror("bad condition bit name `"..expr.."'") | 1513 | werror("bad condition bit name `"..expr.."'") |
| 901 | end | 1514 | end |
| 902 | 1515 | ||
| 1516 | local parse_ctx = {} | ||
| 1517 | |||
| 1518 | local loadenv = setfenv and function(s) | ||
| 1519 | local code = loadstring(s, "") | ||
| 1520 | if code then setfenv(code, parse_ctx) end | ||
| 1521 | return code | ||
| 1522 | end or function(s) | ||
| 1523 | return load(s, "", nil, parse_ctx) | ||
| 1524 | end | ||
| 1525 | |||
| 1526 | -- Try to parse simple arithmetic, too, since some basic ops are aliases. | ||
| 1527 | local function parse_number(n) | ||
| 1528 | local x = tonumber(n) | ||
| 1529 | if x then return x end | ||
| 1530 | local code = loadenv("return "..n) | ||
| 1531 | if code then | ||
| 1532 | local ok, y = pcall(code) | ||
| 1533 | if ok then return y end | ||
| 1534 | end | ||
| 1535 | return nil | ||
| 1536 | end | ||
| 1537 | |||
| 903 | local function parse_imm(imm, bits, shift, scale, signed) | 1538 | local function parse_imm(imm, bits, shift, scale, signed) |
| 904 | local n = tonumber(imm) | 1539 | local n = parse_number(imm) |
| 905 | if n then | 1540 | if n then |
| 906 | local m = sar(n, scale) | 1541 | local m = sar(n, scale) |
| 907 | if shl(m, scale) == n then | 1542 | if shl(m, scale) == n then |
| @@ -914,7 +1549,8 @@ local function parse_imm(imm, bits, shift, scale, signed) | |||
| 914 | end | 1549 | end |
| 915 | end | 1550 | end |
| 916 | werror("out of range immediate `"..imm.."'") | 1551 | werror("out of range immediate `"..imm.."'") |
| 917 | elseif match(imm, "^r([1-3]?[0-9])$") or | 1552 | elseif match(imm, "^[rfv]([1-3]?[0-9])$") or |
| 1553 | match(imm, "^vs([1-6]?[0-9])$") or | ||
| 918 | match(imm, "^([%w_]+):(r[1-3]?[0-9])$") then | 1554 | match(imm, "^([%w_]+):(r[1-3]?[0-9])$") then |
| 919 | werror("expected immediate operand, got register") | 1555 | werror("expected immediate operand, got register") |
| 920 | else | 1556 | else |
| @@ -924,11 +1560,11 @@ local function parse_imm(imm, bits, shift, scale, signed) | |||
| 924 | end | 1560 | end |
| 925 | 1561 | ||
| 926 | local function parse_shiftmask(imm, isshift) | 1562 | local function parse_shiftmask(imm, isshift) |
| 927 | local n = tonumber(imm) | 1563 | local n = parse_number(imm) |
| 928 | if n then | 1564 | if n then |
| 929 | if shr(n, 6) == 0 then | 1565 | if shr(n, 6) == 0 then |
| 930 | local lsb = band(imm, 31) | 1566 | local lsb = band(n, 31) |
| 931 | local msb = imm - lsb | 1567 | local msb = n - lsb |
| 932 | return isshift and (shl(lsb, 11)+shr(msb, 4)) or (shl(lsb, 6)+msb) | 1568 | return isshift and (shl(lsb, 11)+shr(msb, 4)) or (shl(lsb, 6)+msb) |
| 933 | end | 1569 | end |
| 934 | werror("out of range immediate `"..imm.."'") | 1570 | werror("out of range immediate `"..imm.."'") |
| @@ -936,7 +1572,8 @@ local function parse_shiftmask(imm, isshift) | |||
| 936 | match(imm, "^([%w_]+):(r[1-3]?[0-9])$") then | 1572 | match(imm, "^([%w_]+):(r[1-3]?[0-9])$") then |
| 937 | werror("expected immediate operand, got register") | 1573 | werror("expected immediate operand, got register") |
| 938 | else | 1574 | else |
| 939 | werror("NYI: parameterized 64 bit shift/mask") | 1575 | waction("IMMSH", isshift and 1 or 0, imm) |
| 1576 | return 0; | ||
| 940 | end | 1577 | end |
| 941 | end | 1578 | end |
| 942 | 1579 | ||
| @@ -1011,7 +1648,7 @@ end | |||
| 1011 | ------------------------------------------------------------------------------ | 1648 | ------------------------------------------------------------------------------ |
| 1012 | 1649 | ||
| 1013 | -- Handle opcodes defined with template strings. | 1650 | -- Handle opcodes defined with template strings. |
| 1014 | map_op[".template__"] = function(params, template, nparams) | 1651 | op_template = function(params, template, nparams) |
| 1015 | if not params then return sub(template, 9) end | 1652 | if not params then return sub(template, 9) end |
| 1016 | local op = tonumber(sub(template, 1, 8), 16) | 1653 | local op = tonumber(sub(template, 1, 8), 16) |
| 1017 | local n, rs = 1, 26 | 1654 | local n, rs = 1, 26 |
| @@ -1027,6 +1664,15 @@ map_op[".template__"] = function(params, template, nparams) | |||
| 1027 | rs = rs - 5; op = op + shl(parse_gpr(params[n]), rs); n = n + 1 | 1664 | rs = rs - 5; op = op + shl(parse_gpr(params[n]), rs); n = n + 1 |
| 1028 | elseif p == "F" then | 1665 | elseif p == "F" then |
| 1029 | rs = rs - 5; op = op + shl(parse_fpr(params[n]), rs); n = n + 1 | 1666 | rs = rs - 5; op = op + shl(parse_fpr(params[n]), rs); n = n + 1 |
| 1667 | elseif p == "V" then | ||
| 1668 | rs = rs - 5; op = op + shl(parse_vr(params[n]), rs); n = n + 1 | ||
| 1669 | elseif p == "Q" then | ||
| 1670 | local vs = parse_vs(params[n]); n = n + 1; rs = rs - 5 | ||
| 1671 | local sh = rs == 6 and 2 or 3 + band(shr(rs, 1), 3) | ||
| 1672 | op = op + shl(band(vs, 31), rs) + shr(band(vs, 32), sh) | ||
| 1673 | elseif p == "q" then | ||
| 1674 | local vs = parse_vs(params[n]); n = n + 1 | ||
| 1675 | op = op + shl(band(vs, 31), 21) + shr(band(vs, 32), 5) | ||
| 1030 | elseif p == "A" then | 1676 | elseif p == "A" then |
| 1031 | rs = rs - 5; op = op + parse_imm(params[n], 5, rs, 0, false); n = n + 1 | 1677 | rs = rs - 5; op = op + parse_imm(params[n], 5, rs, 0, false); n = n + 1 |
| 1032 | elseif p == "S" then | 1678 | elseif p == "S" then |
| @@ -1047,6 +1693,26 @@ map_op[".template__"] = function(params, template, nparams) | |||
| 1047 | rs = rs - 5; op = op + shl(parse_cond(params[n]), rs); n = n + 1 | 1693 | rs = rs - 5; op = op + shl(parse_cond(params[n]), rs); n = n + 1 |
| 1048 | elseif p == "X" then | 1694 | elseif p == "X" then |
| 1049 | rs = rs - 5; op = op + shl(parse_cr(params[n]), rs+2); n = n + 1 | 1695 | rs = rs - 5; op = op + shl(parse_cr(params[n]), rs+2); n = n + 1 |
| 1696 | elseif p == "1" then | ||
| 1697 | rs = rs - 5; op = op + parse_imm(params[n], 1, rs, 0, false); n = n + 1 | ||
| 1698 | elseif p == "g" then | ||
| 1699 | rs = rs - 5; op = op + parse_imm(params[n], 2, rs, 0, false); n = n + 1 | ||
| 1700 | elseif p == "3" then | ||
| 1701 | rs = rs - 5; op = op + parse_imm(params[n], 3, rs, 0, false); n = n + 1 | ||
| 1702 | elseif p == "P" then | ||
| 1703 | rs = rs - 5; op = op + parse_imm(params[n], 4, rs, 0, false); n = n + 1 | ||
| 1704 | elseif p == "p" then | ||
| 1705 | op = op + parse_imm(params[n], 4, rs, 0, false); n = n + 1 | ||
| 1706 | elseif p == "6" then | ||
| 1707 | rs = rs - 6; op = op + parse_imm(params[n], 6, rs, 0, false); n = n + 1 | ||
| 1708 | elseif p == "Y" then | ||
| 1709 | rs = rs - 5; op = op + parse_imm(params[n], 1, rs+4, 0, false); n = n + 1 | ||
| 1710 | elseif p == "y" then | ||
| 1711 | rs = rs - 5; op = op + parse_imm(params[n], 1, rs+3, 0, false); n = n + 1 | ||
| 1712 | elseif p == "Z" then | ||
| 1713 | rs = rs - 5; op = op + parse_imm(params[n], 2, rs+3, 0, false); n = n + 1 | ||
| 1714 | elseif p == "z" then | ||
| 1715 | rs = rs - 5; op = op + parse_imm(params[n], 2, rs+2, 0, false); n = n + 1 | ||
| 1050 | elseif p == "W" then | 1716 | elseif p == "W" then |
| 1051 | op = op + parse_cr(params[n]); n = n + 1 | 1717 | op = op + parse_cr(params[n]); n = n + 1 |
| 1052 | elseif p == "G" then | 1718 | elseif p == "G" then |
| @@ -1071,6 +1737,8 @@ map_op[".template__"] = function(params, template, nparams) | |||
| 1071 | local lo = band(op, mm) | 1737 | local lo = band(op, mm) |
| 1072 | local hi = band(op, shl(mm, 5)) | 1738 | local hi = band(op, shl(mm, 5)) |
| 1073 | op = op - lo - hi + shl(lo, 5) + shr(hi, 5) | 1739 | op = op - lo - hi + shl(lo, 5) + shr(hi, 5) |
| 1740 | elseif p == ":" then | ||
| 1741 | if band(shr(op, rs), 1) ~= 0 then werror("register pair expected") end | ||
| 1074 | elseif p == "-" then | 1742 | elseif p == "-" then |
| 1075 | rs = rs - 5 | 1743 | rs = rs - 5 |
| 1076 | elseif p == "." then | 1744 | elseif p == "." then |
| @@ -1082,6 +1750,8 @@ map_op[".template__"] = function(params, template, nparams) | |||
| 1082 | wputpos(pos, op) | 1750 | wputpos(pos, op) |
| 1083 | end | 1751 | end |
| 1084 | 1752 | ||
| 1753 | map_op[".template__"] = op_template | ||
| 1754 | |||
| 1085 | ------------------------------------------------------------------------------ | 1755 | ------------------------------------------------------------------------------ |
| 1086 | 1756 | ||
| 1087 | -- Pseudo-opcode to mark the position where the action list is to be emitted. | 1757 | -- Pseudo-opcode to mark the position where the action list is to be emitted. |
