/* ** $Id: lopcodes.h,v 1.44 2000/03/03 18:53:17 roberto Exp roberto $ ** Opcodes for Lua virtual machine ** See Copyright Notice in lua.h */ #ifndef lopcodes_h #define lopcodes_h /*=========================================================================== We assume that instructions are unsigned numbers with 4 bytes. All instructions have an opcode in the 8 bits. Moreover, an instruction can have 0, 1, or 2 arguments. There are 4 types of Instructions: type 0: no arguments type 1: 1 unsigned argument in the higher 24 bits (called `U') type 2: 1 signed argument in the higher 24 bits (`S') type 3: 1st unsigned argument in the higher 16 bits (`A') 2nd unsigned argument in the middle 8 bits (`B') The signed argument is represented in excess 2^23; that is, the real value is the usigned value minus 2^23. ===========================================================================*/ #define SIZE_INSTRUCTION 32 #define SIZE_OP 8 #define SIZE_U (SIZE_INSTRUCTION-SIZE_OP) #define POS_U SIZE_OP #define SIZE_S (SIZE_INSTRUCTION-SIZE_OP) #define POS_S SIZE_OP #define SIZE_B 8 #define POS_B SIZE_OP #define SIZE_A (SIZE_INSTRUCTION-(SIZE_OP+SIZE_B)) #define POS_A (SIZE_OP+SIZE_B) #define EXCESS_S (1<<(SIZE_S-1)) /* == 2^23 */ /* creates a mask with `n' 1 bits at position `p' */ #define MASK1(n,p) ((~((~(Instruction)0)<>POS_U)) #define GETARG_S(i) ((int)((i)>>POS_S)-EXCESS_S) #define GETARG_A(i) ((int)((i)>>POS_A)) #define GETARG_B(i) ((int)(((i)>>POS_B) & MASK1(SIZE_B,0))) #define SET_OPCODE(i,o) ((i) = (((i)&MASK0(SIZE_OP,0)) | (Instruction)(o))) #define SETARG_U(i,u) ((i) = (((i)&MASK0(SIZE_U,POS_U)) | \ ((Instruction)(u)<y)? PC+=s */ IFGEJMP,/* J y x - (x>=y)? PC+=s */ IFTJMP,/* J x - (x!=nil)? PC+=s */ IFFJMP,/* J x - (x==nil)? PC+=s */ ONTJMP,/* J x (x!=nil)? x : - (x!=nil)? PC+=s */ ONFJMP,/* J x (x==nil)? x : - (x==nil)? PC+=s */ JMP,/* J - - PC+=s */ PUSHNILJMP,/* - - nil PC++; */ CLOSURE,/* A B v_b-v_1 closure(CNST[a], v_1-v_b) */ SETLINE/* U - - LINE=u */ } OpCode; #define ISJUMP(o) (IFNEQJMP <= (o) && (o) <= JMP) #define RFIELDS_PER_FLUSH 32 /* records (SETMAP) */ #define LFIELDS_PER_FLUSH 64 /* FPF - lists (SETLIST) (<=MAXARG_B) */ #endif