summaryrefslogtreecommitdiff
path: root/src/lj_opt_mem.c
diff options
context:
space:
mode:
authorMike Pall <mike>2013-11-07 13:29:20 +0100
committerMike Pall <mike>2013-11-07 13:29:20 +0100
commit5a25a735f589d6fafbaa3c234c59fbfe8920a102 (patch)
tree580fbc030fbee4d163827676e907ed73531024a3 /src/lj_opt_mem.c
parent8941b1994e1bb2a82cb8221eb5063bfb6e0ef81b (diff)
downloadluajit2-5a25a735f589d6fafbaa3c234c59fbfe8920a102.tar.gz
Fix type punning alias analysis for constified pointers.
Diffstat (limited to 'src/lj_opt_mem.c')
-rw-r--r--src/lj_opt_mem.c9
1 files changed, 5 insertions, 4 deletions
diff --git a/src/lj_opt_mem.c b/src/lj_opt_mem.c
index 0fd17306..7177ce2c 100644
--- a/src/lj_opt_mem.c
+++ b/src/lj_opt_mem.c
@@ -618,16 +618,17 @@ static AliasRet aa_xref(jit_State *J, IRIns *refa, IRIns *xa, IRIns *xb)
basea = IR(refa->op1);
ofsa = (LJ_64 && irk->o == IR_KINT64) ? (ptrdiff_t)ir_k64(irk)->u64 :
(ptrdiff_t)irk->i;
- if (basea == refb && ofsa != 0)
- return ALIAS_NO; /* base+-ofs vs. base. */
}
if (refb->o == IR_ADD && irref_isk(refb->op2)) {
IRIns *irk = IR(refb->op2);
baseb = IR(refb->op1);
ofsb = (LJ_64 && irk->o == IR_KINT64) ? (ptrdiff_t)ir_k64(irk)->u64 :
(ptrdiff_t)irk->i;
- if (refa == baseb && ofsb != 0)
- return ALIAS_NO; /* base vs. base+-ofs. */
+ }
+ /* Treat constified pointers like base vs. base+offset. */
+ if (basea->o == IR_KPTR && baseb->o == IR_KPTR) {
+ ofsb += (char *)ir_kptr(baseb) - (char *)ir_kptr(basea);
+ baseb = basea;
}
/* This implements (very) strict aliasing rules.
** Different types do NOT alias, except for differences in signedness.