summaryrefslogtreecommitdiff
path: root/src/lj_meta.c
diff options
context:
space:
mode:
authorMike Pall <mike>2011-01-17 01:09:43 +0100
committerMike Pall <mike>2011-01-17 01:09:43 +0100
commitb2ff889c6e2bd637a906b7b81641faf5682f771e (patch)
treea3e8195dac416c9d1b0acb5e278e4aea8dedfabb /src/lj_meta.c
parent335232b0f1c173e91ed3f1cad73ee0f5f47bee03 (diff)
downloadluajit2-b2ff889c6e2bd637a906b7b81641faf5682f771e.tar.gz
FFI: Don't swap operands for cdata __eq metamethod call.
Diffstat (limited to 'src/lj_meta.c')
-rw-r--r--src/lj_meta.c11
1 files changed, 4 insertions, 7 deletions
diff --git a/src/lj_meta.c b/src/lj_meta.c
index ce851a22..0df1de08 100644
--- a/src/lj_meta.c
+++ b/src/lj_meta.c
@@ -309,13 +309,10 @@ TValue * LJ_FASTCALL lj_meta_equal_cd(lua_State *L, BCIns ins)
int op = (int)bc_op(ins) & ~1;
TValue tv;
cTValue *mo, *o2, *o1 = &L->base[bc_a(ins)];
+ cTValue *o1mm = o1;
if (op == BC_ISEQV) {
- cTValue *o = &L->base[bc_d(ins)];
- if (tviscdata(o1)) {
- o2 = o;
- } else {
- o2 = o1; o1 = o;
- }
+ o2 = &L->base[bc_d(ins)];
+ if (!tviscdata(o1mm)) o1mm = o2;
} else if (op == BC_ISEQS) {
setstrV(L, &tv, gco2str(proto_kgc(curr_proto(L), ~(ptrdiff_t)bc_d(ins))));
o2 = &tv;
@@ -326,7 +323,7 @@ TValue * LJ_FASTCALL lj_meta_equal_cd(lua_State *L, BCIns ins)
setitype(&tv, ~bc_d(ins));
o2 = &tv;
}
- mo = lj_meta_lookup(L, o1, MM_eq);
+ mo = lj_meta_lookup(L, o1mm, MM_eq);
if (LJ_LIKELY(!tvisnil(mo)))
return mmcall(L, cont, mo, o1, o2);
else