lopcodes.h 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. /*
  2. ** $Id: lopcodes.h,v 1.24 1999/02/09 15:58:45 roberto Exp roberto $
  3. ** Opcodes for Lua virtual machine
  4. ** See Copyright Notice in lua.h
  5. */
  6. #ifndef lopcodes_h
  7. #define lopcodes_h
  8. /*
  9. ** NOTICE: variants of the same opcode must be consecutive: First, those
  10. ** with word parameter, then with byte parameter.
  11. */
  12. typedef enum {
  13. /* name parm before after side effect
  14. -----------------------------------------------------------------------------*/
  15. ENDCODE,/* - - - */
  16. RETCODE,/* b - - */
  17. PUSHNIL,/* b - nil_0...nil_b */
  18. POP,/* b - - TOP-=b */
  19. POPDUP,/* b v v TOP-=b */
  20. PUSHNUMBERW,/* w - (float)w */
  21. PUSHNUMBER,/* b - (float)b */
  22. PUSHNUMBERNEGW,/* w - (float)-w */
  23. PUSHNUMBERNEG,/* b - (float)-b */
  24. PUSHCONSTANTW,/*w - CNST[w] */
  25. PUSHCONSTANT,/* b - CNST[b] */
  26. PUSHUPVALUE,/* b - Closure[b] */
  27. PUSHLOCAL,/* b - LOC[b] */
  28. GETGLOBALW,/* w - VAR[CNST[w]] */
  29. GETGLOBAL,/* b - VAR[CNST[b]] */
  30. GETTABLE,/* - i t t[i] */
  31. GETDOTTEDW,/* w t t[CNST[w]] */
  32. GETDOTTED,/* b t t[CNST[b]] */
  33. PUSHSELFW,/* w t t t[CNST[w]] */
  34. PUSHSELF,/* b t t t[CNST[b]] */
  35. CREATEARRAYW,/* w - newarray(size = w) */
  36. CREATEARRAY,/* b - newarray(size = b) */
  37. SETLOCAL,/* b x - LOC[b]=x */
  38. SETLOCALDUP,/* b x x LOC[b]=x */
  39. SETGLOBALW,/* w x - VAR[CNST[w]]=x */
  40. SETGLOBAL,/* b x - VAR[CNST[b]]=x */
  41. SETGLOBALDUPW,/*w x x VAR[CNST[w]]=x */
  42. SETGLOBALDUP,/* b x x VAR[CNST[b]]=x */
  43. SETTABLEPOP,/* - v i t - t[i]=v */
  44. SETTABLEPOPDUP,/* - v i t v t[i]=v */
  45. SETTABLE,/* b v a_b...a_1 i t a_b...a_1 i t t[i]=v */
  46. SETTABLEDUP,/* b v a_b...a_1 i t v a_b...a_1 i t t[i]=v */
  47. SETLISTW,/* w c v_c...v_1 t - t[i+w*FPF]=v_i */
  48. SETLIST,/* b c v_c...v_1 t - t[i+b*FPF]=v_i */
  49. SETMAP,/* b v_b k_b ...v_0 k_0 t t t[k_i]=v_i */
  50. NEQOP,/* - y x (x~=y)? 1 : nil */
  51. EQOP,/* - y x (x==y)? 1 : nil */
  52. LTOP,/* - y x (x<y)? 1 : nil */
  53. LEOP,/* - y x (x<y)? 1 : nil */
  54. GTOP,/* - y x (x>y)? 1 : nil */
  55. GEOP,/* - y x (x>=y)? 1 : nil */
  56. ADDOP,/* - y x x+y */
  57. SUBOP,/* - y x x-y */
  58. MULTOP,/* - y x x*y */
  59. DIVOP,/* - y x x/y */
  60. POWOP,/* - y x x^y */
  61. CONCOP,/* - y x x..y */
  62. MINUSOP,/* - x -x */
  63. NOTOP,/* - x (x==nil)? 1 : nil */
  64. ONTJMPW,/* w x (x!=nil)? x : - (x!=nil)? PC+=w */
  65. ONTJMP,/* b x (x!=nil)? x : - (x!=nil)? PC+=b */
  66. ONFJMPW,/* w x (x==nil)? x : - (x==nil)? PC+=w */
  67. ONFJMP,/* b x (x==nil)? x : - (x==nil)? PC+=b */
  68. JMPW,/* w - - PC+=w */
  69. JMP,/* b - - PC+=b */
  70. IFFJMPW,/* w x - (x==nil)? PC+=w */
  71. IFFJMP,/* b x - (x==nil)? PC+=b */
  72. IFTUPJMPW,/* w x - (x!=nil)? PC-=w */
  73. IFTUPJMP,/* b x - (x!=nil)? PC-=b */
  74. IFFUPJMPW,/* w x - (x==nil)? PC-=w */
  75. IFFUPJMP,/* b x - (x==nil)? PC-=b */
  76. CLOSUREW,/* w c v_c...v_1 closure(CNST[w], v_c...v_1) */
  77. CLOSURE,/* b c v_c...v_1 closure(CNST[b], v_c...v_1) */
  78. CALLFUNC,/* b c v_c...v_1 f r_b...r_1 f(v1,...,v_c) */
  79. SETLINEW,/* w - - LINE=w */
  80. SETLINE,/* b - - LINE=b */
  81. LONGARG /* b (add b*(1<<16) to arg of next instruction) */
  82. } OpCode;
  83. #define RFIELDS_PER_FLUSH 32 /* records (SETMAP) */
  84. #define LFIELDS_PER_FLUSH 64 /* FPF - lists (SETLIST) */
  85. #define ZEROVARARG 64
  86. /* maximum value of an arg of 3 bytes; must fit in an "int" */
  87. #if MAX_INT < (1<<24)
  88. #define MAX_ARG MAX_INT
  89. #else
  90. #define MAX_ARG ((1<<24)-1)
  91. #endif
  92. /* maximum value of a word of 2 bytes; cannot be bigger than MAX_ARG */
  93. #if MAX_ARG < (1<<16)
  94. #define MAX_WORD MAX_ARG
  95. #else
  96. #define MAX_WORD ((1<<16)-1)
  97. #endif
  98. /* maximum value of a byte */
  99. #define MAX_BYTE ((1<<8)-1)
  100. #endif