FFI: Don't load PC from non-function object in FFI continuation.

Reported by Yichun Zhang. #743
This commit is contained in:
Mike Pall 2021-09-20 14:39:26 +02:00
parent 98b7d9a3b2
commit 003f68565d
2 changed files with 2 additions and 2 deletions

View File

@ -562,12 +562,12 @@ static void build_subroutines(BuildCtx *ctx)
| cmp CARG1, #1
|.endif
| ldr PC, [CARG4, #-24] // Restore PC from [cont|PC].
| ldr CARG3, LFUNC:CARG3->pc
| add TMP0, RA, RC
| str TISNIL, [TMP0, #-8] // Ensure one valid arg.
|.if FFI
| bls >1
|.endif
| ldr CARG3, LFUNC:CARG3->pc
| ldr KBASE, [CARG3, #PC2PROTO(k)]
| // BASE = base, RA = resultptr, CARG4 = meta base
| br CARG1

View File

@ -728,11 +728,11 @@ static void build_subroutines(BuildCtx *ctx)
| ld PC, -24(RB) // Restore PC from [cont|PC].
| cleartp LFUNC:TMP1
| daddu TMP2, RA, RD
| ld TMP1, LFUNC:TMP1->pc
|.if FFI
| bnez AT, >1
|.endif
|. sd TISNIL, -8(TMP2) // Ensure one valid arg.
| ld TMP1, LFUNC:TMP1->pc
| // BASE = base, RA = resultptr, RB = meta base
| jr TMP0 // Jump to continuation.
|. ld KBASE, PC2PROTO(k)(TMP1)