From 722bdbe17d0192baf72978f88069d12a921e9bfb Mon Sep 17 00:00:00 2001 From: Roberto Ierusalimschy Date: Thu, 28 Sep 2017 13:53:29 -0300 Subject: no more 'getBMode'-'getCMode' (imprecise + we will need more space for op mode) + better control of op modes --- lopcodes.c | 116 ++++++++++++++++++++++++++++++------------------------------- 1 file changed, 57 insertions(+), 59 deletions(-) (limited to 'lopcodes.c') diff --git a/lopcodes.c b/lopcodes.c index 9617b720..5051f2a8 100644 --- a/lopcodes.c +++ b/lopcodes.c @@ -1,5 +1,5 @@ /* -** $Id: lopcodes.c,v 1.63 2017/09/19 18:38:14 roberto Exp roberto $ +** $Id: lopcodes.c,v 1.64 2017/09/26 18:14:45 roberto Exp roberto $ ** Opcodes for Lua virtual machine ** See Copyright Notice in lua.h */ @@ -77,64 +77,62 @@ LUAI_DDEF const char *const luaP_opnames[NUM_OPCODES+1] = { }; -#define opmode(t,a,b,c,m) (((t)<<7) | ((a)<<6) | ((b)<<4) | ((c)<<2) | (m)) - LUAI_DDEF const lu_byte luaP_opmodes[NUM_OPCODES] = { -/* T A B C mode opcode */ - opmode(0, 1, OpArgR, OpArgN, iABC) /* OP_MOVE */ - ,opmode(0, 1, OpArgU, OpArgN, iAsBx) /* OP_LOADI */ - ,opmode(0, 1, OpArgU, OpArgN, iAsBx) /* OP_LOADF */ - ,opmode(0, 1, OpArgK, OpArgN, iABx) /* OP_LOADK */ - ,opmode(0, 1, OpArgN, OpArgN, iABx) /* OP_LOADKX */ - ,opmode(0, 1, OpArgU, OpArgU, iABC) /* OP_LOADBOOL */ - ,opmode(0, 1, OpArgU, OpArgN, iABC) /* OP_LOADNIL */ - ,opmode(0, 1, OpArgU, OpArgN, iABC) /* OP_GETUPVAL */ - ,opmode(0, 0, OpArgU, OpArgN, iABC) /* OP_SETUPVAL */ - ,opmode(0, 1, OpArgU, OpArgK, iABC) /* OP_GETTABUP */ - ,opmode(0, 1, OpArgR, OpArgR, iABC) /* OP_GETTABLE */ - ,opmode(0, 1, OpArgR, OpArgU, iABC) /* OP_GETI */ - ,opmode(0, 1, OpArgR, OpArgK, iABC) /* OP_GETFIELD */ - ,opmode(0, 0, OpArgK, OpArgK, iABC) /* OP_SETTABUP */ - ,opmode(0, 0, OpArgR, OpArgK, iABC) /* OP_SETTABLE */ - ,opmode(0, 0, OpArgU, OpArgK, iABC) /* OP_SETI */ - ,opmode(0, 0, OpArgK, OpArgK, iABC) /* OP_SETFIELD */ - ,opmode(0, 1, OpArgU, OpArgU, iABC) /* OP_NEWTABLE */ - ,opmode(0, 1, OpArgR, OpArgK, iABC) /* OP_SELF */ - ,opmode(0, 1, OpArgR, OpArgU, iABC) /* OP_ADDI */ - ,opmode(0, 1, OpArgR, OpArgR, iABC) /* OP_ADD */ - ,opmode(0, 1, OpArgR, OpArgR, iABC) /* OP_SUB */ - ,opmode(0, 1, OpArgR, OpArgR, iABC) /* OP_MUL */ - ,opmode(0, 1, OpArgR, OpArgR, iABC) /* OP_MOD */ - ,opmode(0, 1, OpArgR, OpArgR, iABC) /* OP_POW */ - ,opmode(0, 1, OpArgR, OpArgR, iABC) /* OP_DIV */ - ,opmode(0, 1, OpArgR, OpArgR, iABC) /* OP_IDIV */ - ,opmode(0, 1, OpArgR, OpArgR, iABC) /* OP_BAND */ - ,opmode(0, 1, OpArgR, OpArgR, iABC) /* OP_BOR */ - ,opmode(0, 1, OpArgR, OpArgR, iABC) /* OP_BXOR */ - ,opmode(0, 1, OpArgR, OpArgR, iABC) /* OP_SHL */ - ,opmode(0, 1, OpArgR, OpArgR, iABC) /* OP_SHR */ - ,opmode(0, 1, OpArgR, OpArgN, iABC) /* OP_UNM */ - ,opmode(0, 1, OpArgR, OpArgN, iABC) /* OP_BNOT */ - ,opmode(0, 1, OpArgR, OpArgN, iABC) /* OP_NOT */ - ,opmode(0, 1, OpArgR, OpArgN, iABC) /* OP_LEN */ - ,opmode(0, 1, OpArgR, OpArgR, iABC) /* OP_CONCAT */ - ,opmode(0, 0, OpArgN, OpArgN, iABC) /* OP_CLOSE */ - ,opmode(0, 0, OpArgU, OpArgN, iAsBx) /* OP_JMP */ - ,opmode(1, 0, OpArgR, OpArgR, iABC) /* OP_EQ */ - ,opmode(1, 0, OpArgR, OpArgR, iABC) /* OP_LT */ - ,opmode(1, 0, OpArgR, OpArgR, iABC) /* OP_LE */ - ,opmode(1, 0, OpArgN, OpArgU, iABC) /* OP_TEST */ - ,opmode(1, 1, OpArgR, OpArgU, iABC) /* OP_TESTSET */ - ,opmode(0, 1, OpArgU, OpArgU, iABC) /* OP_CALL */ - ,opmode(0, 1, OpArgU, OpArgU, iABC) /* OP_TAILCALL */ - ,opmode(0, 0, OpArgU, OpArgN, iABC) /* OP_RETURN */ - ,opmode(0, 1, OpArgR, OpArgN, iABx) /* OP_FORLOOP */ - ,opmode(0, 1, OpArgR, OpArgN, iABx) /* OP_FORPREP */ - ,opmode(0, 0, OpArgN, OpArgU, iABC) /* OP_TFORCALL */ - ,opmode(0, 1, OpArgR, OpArgN, iABx) /* OP_TFORLOOP */ - ,opmode(0, 0, OpArgU, OpArgU, iABC) /* OP_SETLIST */ - ,opmode(0, 1, OpArgU, OpArgN, iABx) /* OP_CLOSURE */ - ,opmode(0, 1, OpArgU, OpArgR, iABC) /* OP_VARARG */ - ,opmode(0, 0, OpArgU, OpArgU, iAx) /* OP_EXTRAARG */ +/* 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_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, iAsBx) /* 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_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, 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 */ }; -- cgit v1.2.3-55-g6feb