summaryrefslogtreecommitdiff
path: root/src/lj_crecord.c
diff options
context:
space:
mode:
authorMike Pall <mike>2011-07-23 16:29:47 +0200
committerMike Pall <mike>2011-07-23 16:29:47 +0200
commitd001d7b7ce0126558e4b442aa1d0cd88fee43570 (patch)
treec6d3964c8042e8088d7dac4a429ab446fcde167e /src/lj_crecord.c
parentb261d0ec046d3b20bc37826344be3049a144de24 (diff)
downloadluajit-d001d7b7ce0126558e4b442aa1d0cd88fee43570.tar.gz
luajit-d001d7b7ce0126558e4b442aa1d0cd88fee43570.tar.bz2
luajit-d001d7b7ce0126558e4b442aa1d0cd88fee43570.zip
FFI: Treat function ctypes like pointers in comparisons.
Diffstat (limited to 'src/lj_crecord.c')
-rw-r--r--src/lj_crecord.c4
1 files changed, 4 insertions, 0 deletions
diff --git a/src/lj_crecord.c b/src/lj_crecord.c
index 743137de..180f255c 100644
--- a/src/lj_crecord.c
+++ b/src/lj_crecord.c
@@ -969,6 +969,10 @@ void LJ_FASTCALL recff_cdata_arith(jit_State *J, RecordFFData *rd)
969 tr = emitir(IRT(IR_FLOAD, t), tr, IRFL_CDATA_INT64); 969 tr = emitir(IRT(IR_FLOAD, t), tr, IRFL_CDATA_INT64);
970 lj_needsplit(J); 970 lj_needsplit(J);
971 goto ok; 971 goto ok;
972 } else if (ctype_isfunc(ct->info)) {
973 tr = emitir(IRT(IR_FLOAD, IRT_PTR), tr, IRFL_CDATA_PTR);
974 ct = ctype_get(cts,
975 lj_ctype_intern(cts, CTINFO(CT_PTR, CTALIGN_PTR|id), CTSIZE_PTR));
972 } else { 976 } else {
973 tr = emitir(IRT(IR_ADD, IRT_PTR), tr, lj_ir_kintp(J, sizeof(GCcdata))); 977 tr = emitir(IRT(IR_ADD, IRT_PTR), tr, lj_ir_kintp(J, sizeof(GCcdata)));
974 } 978 }