mirror of
https://github.com/LuaJIT/LuaJIT.git
synced 2025-02-07 23:24:09 +00:00
x64/LJ_GC64: Fix upvalue write barrier.
This commit is contained in:
parent
5de95edf4c
commit
4da1bb66cd
@ -3412,9 +3412,12 @@ static void build_ins(BuildCtx *ctx, BCOp op, int defop)
|
||||
| ins_next
|
||||
|
|
||||
|2: // Upvalue is black. Check if new value is collectable and white.
|
||||
| sub RD, LJ_TISGCV
|
||||
| cmp RD, LJ_TNUMX - LJ_TISGCV // tvisgcv(v)
|
||||
| mov RD, RA
|
||||
| sar RD, 47
|
||||
| sub RDd, LJ_TISGCV
|
||||
| cmp RDd, LJ_TNUMX - LJ_TISGCV // tvisgcv(v)
|
||||
| jbe <1
|
||||
| cleartp GCOBJ:RA
|
||||
| test byte GCOBJ:RA->gch.marked, LJ_GC_WHITES // iswhite(v)
|
||||
| jz <1
|
||||
| // Crossed a write barrier. Move the barrier forward.
|
||||
@ -3437,8 +3440,8 @@ static void build_ins(BuildCtx *ctx, BCOp op, int defop)
|
||||
| mov UPVAL:RB, [LFUNC:RB+RA*8+offsetof(GCfuncL, uvptr)]
|
||||
| mov STR:RA, [KBASE+RD*8]
|
||||
| mov RD, UPVAL:RB->v
|
||||
| settp STR:RA, LJ_TSTR
|
||||
| mov [RD], STR:RA
|
||||
| settp STR:ITYPE, STR:RA, LJ_TSTR
|
||||
| mov [RD], STR:ITYPE
|
||||
| test byte UPVAL:RB->marked, LJ_GC_BLACK // isblack(uv)
|
||||
| jnz >2
|
||||
|1:
|
||||
@ -3824,7 +3827,7 @@ static void build_ins(BuildCtx *ctx, BCOp op, int defop)
|
||||
| mov L:CARG1, SAVE_L
|
||||
| mov BASE, L:CARG1->base
|
||||
| mov TMPR, rax
|
||||
| movzx RA, PC_RA
|
||||
| movzx RAd, PC_RA
|
||||
| jmp <2 // Must check write barrier for value.
|
||||
|
|
||||
|7: // Possible table write barrier for the value. Skip valiswhite check.
|
||||
|
Loading…
Reference in New Issue
Block a user