mirror of
https://github.com/LuaJIT/LuaJIT.git
synced 2025-02-08 07:34:07 +00:00
PPC: Add return instructions.
This commit is contained in:
parent
fc1866fb6f
commit
00d10711ae
@ -1060,17 +1060,98 @@ static void build_ins(BuildCtx *ctx, BCOp op, int defop)
|
|||||||
/* -- Returns ----------------------------------------------------------- */
|
/* -- Returns ----------------------------------------------------------- */
|
||||||
|
|
||||||
case BC_RETM:
|
case BC_RETM:
|
||||||
| NYI
|
| // RA = results*8, RD = extra_nresults*8
|
||||||
|
| lwz TMP0, SAVE_MULTRES
|
||||||
|
| add RD, RD, TMP0 // SAVE_MULTRES >= 8, so RD >= 8.
|
||||||
|
| // Fall through. Assumes BC_RET follows.
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case BC_RET:
|
case BC_RET:
|
||||||
| NYI
|
| // RA = results*8, RD = (nresults+1)*8
|
||||||
|
| lwz PC, FRAME_PC(BASE)
|
||||||
|
| add RA, BASE, RA
|
||||||
|
| stw RD, SAVE_MULTRES
|
||||||
|
|1:
|
||||||
|
| andi. TMP0, PC, FRAME_TYPE
|
||||||
|
| xori TMP1, PC, FRAME_VARG
|
||||||
|
| bne ->BC_RETV_Z
|
||||||
|
|
|
||||||
|->BC_RET_Z:
|
|->BC_RET_Z:
|
||||||
| NYI
|
| // BASE = base, RA = resultptr, RD = (nresults+1)*8, PC = return
|
||||||
|
| lwz INS, -4(PC)
|
||||||
|
| cmpwi RD, 8
|
||||||
|
| subi TMP2, BASE, 8
|
||||||
|
| decode_RB8 RB, INS
|
||||||
|
| beq >3
|
||||||
|
| li TMP1, 0
|
||||||
|
|2:
|
||||||
|
| addi TMP3, TMP1, 8
|
||||||
|
| evlddx TMP0, RA, TMP1
|
||||||
|
| cmpw TMP3, RD
|
||||||
|
| evstddx TMP0, TMP2, TMP1
|
||||||
|
| beq >3
|
||||||
|
| addi TMP1, TMP3, 8
|
||||||
|
| evlddx TMP0, RA, TMP3
|
||||||
|
| cmpw TMP1, RD
|
||||||
|
| evstddx TMP0, TMP2, TMP3
|
||||||
|
| bne <2
|
||||||
|
|3:
|
||||||
|
|5:
|
||||||
|
| cmplw RB, RD
|
||||||
|
| decode_RA8 RA, INS
|
||||||
|
| bgt >6
|
||||||
|
| sub BASE, TMP2, RA
|
||||||
|
| lwz LFUNC:TMP1, FRAME_FUNC(BASE)
|
||||||
|
| lwz TMP1, LFUNC:TMP1->pc
|
||||||
|
| lwz KBASE, PC2PROTO(k)(TMP1)
|
||||||
|
| ins_next
|
||||||
|
|
|
||||||
|
|6: // Fill up results with nil.
|
||||||
|
| subi TMP1, RD, 8
|
||||||
|
| addi RD, RD, 8
|
||||||
|
| evstddx TISNIL, TMP2, TMP1
|
||||||
|
| b <5
|
||||||
|
|
|
||||||
|
|->BC_RETV_Z: // Non-standard return case.
|
||||||
|
| andi. TMP2, TMP1, FRAME_TYPEP
|
||||||
|
| bne ->vm_return
|
||||||
|
| // Return from vararg function: relocate BASE down.
|
||||||
|
| sub BASE, BASE, TMP1
|
||||||
|
| lwz PC, FRAME_PC(BASE)
|
||||||
|
| b <1
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case BC_RET0: case BC_RET1:
|
case BC_RET0: case BC_RET1:
|
||||||
| NYI
|
| // RA = results*8, RD = (nresults+1)*8
|
||||||
|
| lwz PC, FRAME_PC(BASE)
|
||||||
|
| add RA, BASE, RA
|
||||||
|
| stw RD, SAVE_MULTRES
|
||||||
|
| andi. TMP0, PC, FRAME_TYPE
|
||||||
|
| xori TMP1, PC, FRAME_VARG
|
||||||
|
| bne ->BC_RETV_Z
|
||||||
|
|
|
||||||
|
| lwz INS, -4(PC)
|
||||||
|
| subi TMP2, BASE, 8
|
||||||
|
| decode_RB8 RB, INS
|
||||||
|
if (op == BC_RET1) {
|
||||||
|
| evldd TMP0, 0(RA)
|
||||||
|
| evstdd TMP0, 0(TMP2)
|
||||||
|
}
|
||||||
|
|5:
|
||||||
|
| cmplw RB, RD
|
||||||
|
| decode_RA8 RA, INS
|
||||||
|
| bgt >6
|
||||||
|
| sub BASE, TMP2, RA
|
||||||
|
| lwz LFUNC:TMP1, FRAME_FUNC(BASE)
|
||||||
|
| lwz TMP1, LFUNC:TMP1->pc
|
||||||
|
| lwz KBASE, PC2PROTO(k)(TMP1)
|
||||||
|
| ins_next
|
||||||
|
|
|
||||||
|
|6: // Fill up results with nil.
|
||||||
|
| subi TMP1, RD, 8
|
||||||
|
| addi RD, RD, 8
|
||||||
|
| evstddx TISNIL, TMP2, TMP1
|
||||||
|
| b <5
|
||||||
break;
|
break;
|
||||||
|
|
||||||
/* -- Loops and branches ------------------------------------------------ */
|
/* -- Loops and branches ------------------------------------------------ */
|
||||||
|
Loading…
Reference in New Issue
Block a user