From 4676f6599e04d4eaa78c050616e94994e6a36396 Mon Sep 17 00:00:00 2001 From: Roberto Ierusalimschy <roberto@inf.puc-rio.br> Date: Fri, 22 Dec 2017 12:16:46 -0200 Subject: new macros 'isOT'/'isIT' (plus exchanged parameters of OP_VARARG to make it similar to other 'isOT' instructions) --- lopcodes.c | 152 ++++++++++++++++++++++++++++++------------------------------- 1 file changed, 76 insertions(+), 76 deletions(-) (limited to 'lopcodes.c') diff --git a/lopcodes.c b/lopcodes.c index f5896ba0..a5867d23 100644 --- a/lopcodes.c +++ b/lopcodes.c @@ -1,5 +1,5 @@ /* -** $Id: lopcodes.c,v 1.73 2017/12/13 18:32:09 roberto Exp roberto $ +** $Id: lopcodes.c,v 1.74 2017/12/18 17:49:31 roberto Exp $ ** Opcodes for Lua virtual machine ** See Copyright Notice in lua.h */ @@ -97,80 +97,80 @@ LUAI_DDEF const char *const luaP_opnames[NUM_OPCODES+1] = { LUAI_DDEF const lu_byte luaP_opmodes[NUM_OPCODES] = { -/* T A mode opcode */ - opmode(0, 1, iABC) /* OP_MOVE */ - ,opmode(0, 1, iAsBx) /* OP_LOADI */ - ,opmode(0, 1, iAsBx) /* OP_LOADF */ - ,opmode(0, 1, iABx) /* OP_LOADK */ - ,opmode(0, 1, iABx) /* OP_LOADKX */ - ,opmode(0, 1, iABC) /* OP_LOADBOOL */ - ,opmode(0, 1, iABC) /* OP_LOADNIL */ - ,opmode(0, 1, iABC) /* OP_GETUPVAL */ - ,opmode(0, 0, iABC) /* OP_SETUPVAL */ - ,opmode(0, 1, iABC) /* OP_GETTABUP */ - ,opmode(0, 1, iABC) /* OP_GETTABLE */ - ,opmode(0, 1, iABC) /* OP_GETI */ - ,opmode(0, 1, iABC) /* OP_GETFIELD */ - ,opmode(0, 0, iABC) /* OP_SETTABUP */ - ,opmode(0, 0, iABC) /* OP_SETTABLE */ - ,opmode(0, 0, iABC) /* OP_SETI */ - ,opmode(0, 0, iABC) /* OP_SETFIELD */ - ,opmode(0, 1, iABC) /* OP_NEWTABLE */ - ,opmode(0, 1, iABC) /* OP_SELF */ - ,opmode(0, 1, iABC) /* OP_ADDI */ - ,opmode(0, 1, iABC) /* OP_SUBI */ - ,opmode(0, 1, iABC) /* OP_MULI */ - ,opmode(0, 1, iABC) /* OP_MODI */ - ,opmode(0, 1, iABC) /* OP_POWI */ - ,opmode(0, 1, iABC) /* OP_DIVI */ - ,opmode(0, 1, iABC) /* OP_IDIVI */ - ,opmode(0, 1, iABC) /* OP_BANDK */ - ,opmode(0, 1, iABC) /* OP_BORK */ - ,opmode(0, 1, iABC) /* OP_BXORK */ - ,opmode(0, 1, iABC) /* OP_SHRI */ - ,opmode(0, 1, iABC) /* OP_SHLI */ - ,opmode(0, 1, iABC) /* OP_ADD */ - ,opmode(0, 1, iABC) /* OP_SUB */ - ,opmode(0, 1, iABC) /* OP_MUL */ - ,opmode(0, 1, iABC) /* OP_MOD */ - ,opmode(0, 1, iABC) /* OP_POW */ - ,opmode(0, 1, iABC) /* OP_DIV */ - ,opmode(0, 1, iABC) /* OP_IDIV */ - ,opmode(0, 1, iABC) /* OP_BAND */ - ,opmode(0, 1, iABC) /* OP_BOR */ - ,opmode(0, 1, iABC) /* OP_BXOR */ - ,opmode(0, 1, iABC) /* OP_SHL */ - ,opmode(0, 1, iABC) /* OP_SHR */ - ,opmode(0, 1, iABC) /* OP_UNM */ - ,opmode(0, 1, iABC) /* OP_BNOT */ - ,opmode(0, 1, iABC) /* OP_NOT */ - ,opmode(0, 1, iABC) /* OP_LEN */ - ,opmode(0, 1, iABC) /* OP_CONCAT */ - ,opmode(0, 0, iABC) /* OP_CLOSE */ - ,opmode(0, 0, isJ) /* OP_JMP */ - ,opmode(1, 0, iABC) /* OP_EQ */ - ,opmode(1, 0, iABC) /* OP_LT */ - ,opmode(1, 0, iABC) /* OP_LE */ - ,opmode(1, 0, iABC) /* OP_EQK */ - ,opmode(1, 0, iABC) /* OP_EQI */ - ,opmode(1, 0, iABC) /* OP_LTI */ - ,opmode(1, 0, iABC) /* OP_LEI */ - ,opmode(1, 0, iABC) /* OP_TEST */ - ,opmode(1, 1, iABC) /* OP_TESTSET */ - ,opmode(0, 1, iABC) /* OP_CALL */ - ,opmode(0, 1, iABC) /* OP_TAILCALL */ - ,opmode(0, 0, iABC) /* OP_RETURN */ - ,opmode(0, 0, iABC) /* OP_RETURN0 */ - ,opmode(0, 0, iABC) /* OP_RETURN1 */ - ,opmode(0, 1, iABx) /* OP_FORLOOP1 */ - ,opmode(0, 1, iABx) /* OP_FORPREP1 */ - ,opmode(0, 1, iABx) /* OP_FORLOOP */ - ,opmode(0, 1, iABx) /* OP_FORPREP */ - ,opmode(0, 0, iABC) /* OP_TFORCALL */ - ,opmode(0, 1, iABx) /* OP_TFORLOOP */ - ,opmode(0, 0, iABC) /* OP_SETLIST */ - ,opmode(0, 1, iABx) /* OP_CLOSURE */ - ,opmode(0, 1, iABC) /* OP_VARARG */ - ,opmode(0, 0, iAx) /* OP_EXTRAARG */ +/* OT IT T A mode opcode */ + opmode(0, 0, 0, 1, iABC) /* OP_MOVE */ + ,opmode(0, 0, 0, 1, iAsBx) /* OP_LOADI */ + ,opmode(0, 0, 0, 1, iAsBx) /* OP_LOADF */ + ,opmode(0, 0, 0, 1, iABx) /* OP_LOADK */ + ,opmode(0, 0, 0, 1, iABx) /* OP_LOADKX */ + ,opmode(0, 0, 0, 1, iABC) /* OP_LOADBOOL */ + ,opmode(0, 0, 0, 1, iABC) /* OP_LOADNIL */ + ,opmode(0, 0, 0, 1, iABC) /* OP_GETUPVAL */ + ,opmode(0, 0, 0, 0, iABC) /* OP_SETUPVAL */ + ,opmode(0, 0, 0, 1, iABC) /* OP_GETTABUP */ + ,opmode(0, 0, 0, 1, iABC) /* OP_GETTABLE */ + ,opmode(0, 0, 0, 1, iABC) /* OP_GETI */ + ,opmode(0, 0, 0, 1, iABC) /* OP_GETFIELD */ + ,opmode(0, 0, 0, 0, iABC) /* OP_SETTABUP */ + ,opmode(0, 0, 0, 0, iABC) /* OP_SETTABLE */ + ,opmode(0, 0, 0, 0, iABC) /* OP_SETI */ + ,opmode(0, 0, 0, 0, iABC) /* OP_SETFIELD */ + ,opmode(0, 0, 0, 1, iABC) /* OP_NEWTABLE */ + ,opmode(0, 0, 0, 1, iABC) /* OP_SELF */ + ,opmode(0, 0, 0, 1, iABC) /* OP_ADDI */ + ,opmode(0, 0, 0, 1, iABC) /* OP_SUBI */ + ,opmode(0, 0, 0, 1, iABC) /* OP_MULI */ + ,opmode(0, 0, 0, 1, iABC) /* OP_MODI */ + ,opmode(0, 0, 0, 1, iABC) /* OP_POWI */ + ,opmode(0, 0, 0, 1, iABC) /* OP_DIVI */ + ,opmode(0, 0, 0, 1, iABC) /* OP_IDIVI */ + ,opmode(0, 0, 0, 1, iABC) /* OP_BANDK */ + ,opmode(0, 0, 0, 1, iABC) /* OP_BORK */ + ,opmode(0, 0, 0, 1, iABC) /* OP_BXORK */ + ,opmode(0, 0, 0, 1, iABC) /* OP_SHRI */ + ,opmode(0, 0, 0, 1, iABC) /* OP_SHLI */ + ,opmode(0, 0, 0, 1, iABC) /* OP_ADD */ + ,opmode(0, 0, 0, 1, iABC) /* OP_SUB */ + ,opmode(0, 0, 0, 1, iABC) /* OP_MUL */ + ,opmode(0, 0, 0, 1, iABC) /* OP_MOD */ + ,opmode(0, 0, 0, 1, iABC) /* OP_POW */ + ,opmode(0, 0, 0, 1, iABC) /* OP_DIV */ + ,opmode(0, 0, 0, 1, iABC) /* OP_IDIV */ + ,opmode(0, 0, 0, 1, iABC) /* OP_BAND */ + ,opmode(0, 0, 0, 1, iABC) /* OP_BOR */ + ,opmode(0, 0, 0, 1, iABC) /* OP_BXOR */ + ,opmode(0, 0, 0, 1, iABC) /* OP_SHL */ + ,opmode(0, 0, 0, 1, iABC) /* OP_SHR */ + ,opmode(0, 0, 0, 1, iABC) /* OP_UNM */ + ,opmode(0, 0, 0, 1, iABC) /* OP_BNOT */ + ,opmode(0, 0, 0, 1, iABC) /* OP_NOT */ + ,opmode(0, 0, 0, 1, iABC) /* OP_LEN */ + ,opmode(0, 0, 0, 1, iABC) /* OP_CONCAT */ + ,opmode(0, 0, 0, 0, iABC) /* OP_CLOSE */ + ,opmode(0, 0, 0, 0, isJ) /* OP_JMP */ + ,opmode(0, 0, 1, 0, iABC) /* OP_EQ */ + ,opmode(0, 0, 1, 0, iABC) /* OP_LT */ + ,opmode(0, 0, 1, 0, iABC) /* OP_LE */ + ,opmode(0, 0, 1, 0, iABC) /* OP_EQK */ + ,opmode(0, 0, 1, 0, iABC) /* OP_EQI */ + ,opmode(0, 0, 1, 0, iABC) /* OP_LTI */ + ,opmode(0, 0, 1, 0, iABC) /* OP_LEI */ + ,opmode(0, 0, 1, 0, iABC) /* OP_TEST */ + ,opmode(0, 0, 1, 1, iABC) /* OP_TESTSET */ + ,opmode(1, 1, 0, 1, iABC) /* OP_CALL */ + ,opmode(1, 1, 0, 1, iABC) /* OP_TAILCALL */ + ,opmode(0, 1, 0, 0, iABC) /* OP_RETURN */ + ,opmode(0, 0, 0, 0, iABC) /* OP_RETURN0 */ + ,opmode(0, 0, 0, 0, iABC) /* OP_RETURN1 */ + ,opmode(0, 0, 0, 1, iABx) /* OP_FORLOOP1 */ + ,opmode(0, 0, 0, 1, iABx) /* OP_FORPREP1 */ + ,opmode(0, 0, 0, 1, iABx) /* OP_FORLOOP */ + ,opmode(0, 0, 0, 1, iABx) /* OP_FORPREP */ + ,opmode(0, 0, 0, 0, iABC) /* OP_TFORCALL */ + ,opmode(0, 0, 0, 1, iABx) /* OP_TFORLOOP */ + ,opmode(0, 1, 0, 0, iABC) /* OP_SETLIST */ + ,opmode(0, 0, 0, 1, iABx) /* OP_CLOSURE */ + ,opmode(1, 0, 0, 1, iABC) /* OP_VARARG */ + ,opmode(0, 0, 0, 0, iAx) /* OP_EXTRAARG */ }; -- cgit v1.2.3-55-g6feb