mirror of
https://github.com/LuaJIT/LuaJIT.git
synced 2025-02-07 15:14:08 +00:00
Fix TDUP load forwarding after table rehash.
Reported by Sergey Kaplun. #980
This commit is contained in:
parent
96fc114a7a
commit
c7db8255e1
@ -154,6 +154,7 @@ static TRef fwd_ahload(jit_State *J, IRRef xref)
|
|||||||
if (ir->o == IR_TNEW || (ir->o == IR_TDUP && irref_isk(xr->op2))) {
|
if (ir->o == IR_TNEW || (ir->o == IR_TDUP && irref_isk(xr->op2))) {
|
||||||
/* A NEWREF with a number key may end up pointing to the array part.
|
/* A NEWREF with a number key may end up pointing to the array part.
|
||||||
** But it's referenced from HSTORE and not found in the ASTORE chain.
|
** But it's referenced from HSTORE and not found in the ASTORE chain.
|
||||||
|
** Or a NEWREF may rehash the table and move unrelated number keys.
|
||||||
** For now simply consider this a conflict without forwarding anything.
|
** For now simply consider this a conflict without forwarding anything.
|
||||||
*/
|
*/
|
||||||
if (xr->o == IR_AREF) {
|
if (xr->o == IR_AREF) {
|
||||||
@ -164,6 +165,11 @@ static TRef fwd_ahload(jit_State *J, IRRef xref)
|
|||||||
goto cselim;
|
goto cselim;
|
||||||
ref2 = newref->prev;
|
ref2 = newref->prev;
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
IRIns *key = IR(xr->op2);
|
||||||
|
if (key->o == IR_KSLOT) key = IR(key->op1);
|
||||||
|
if (irt_isnum(key->t) && J->chain[IR_NEWREF] > tab)
|
||||||
|
goto cselim;
|
||||||
}
|
}
|
||||||
/* NEWREF inhibits CSE for HREF, and dependent FLOADs from HREFK/AREF.
|
/* NEWREF inhibits CSE for HREF, and dependent FLOADs from HREFK/AREF.
|
||||||
** But the above search for conflicting stores was limited by xref.
|
** But the above search for conflicting stores was limited by xref.
|
||||||
|
Loading…
Reference in New Issue
Block a user