summaryrefslogtreecommitdiff
path: root/src/opcode.h
diff options
context:
space:
mode:
Diffstat (limited to 'src/opcode.h')
-rw-r--r--src/opcode.h155
1 files changed, 81 insertions, 74 deletions
diff --git a/src/opcode.h b/src/opcode.h
index d42ff3ee..381efbc8 100644
--- a/src/opcode.h
+++ b/src/opcode.h
@@ -1,6 +1,6 @@
/*
** TeCGraf - PUC-Rio
-** $Id: opcode.h,v 3.20 1996/03/15 13:13:13 roberto Exp $
+** $Id: opcode.h,v 3.24 1996/11/01 12:46:59 roberto Exp $
*/
#ifndef opcode_h
@@ -15,59 +15,83 @@
#define FIELDS_PER_FLUSH 40
-typedef enum
-{
- PUSHNIL,
- PUSH0, PUSH1, PUSH2,
- PUSHBYTE,
- PUSHWORD,
- PUSHFLOAT,
- PUSHSTRING,
- PUSHFUNCTION,
- PUSHLOCAL0, PUSHLOCAL1, PUSHLOCAL2, PUSHLOCAL3, PUSHLOCAL4,
- PUSHLOCAL5, PUSHLOCAL6, PUSHLOCAL7, PUSHLOCAL8, PUSHLOCAL9,
- PUSHLOCAL,
- PUSHGLOBAL,
- PUSHINDEXED,
- PUSHSELF,
- STORELOCAL0, STORELOCAL1, STORELOCAL2, STORELOCAL3, STORELOCAL4,
- STORELOCAL5, STORELOCAL6, STORELOCAL7, STORELOCAL8, STORELOCAL9,
- STORELOCAL,
- STOREGLOBAL,
- STOREINDEXED0,
- STOREINDEXED,
- STORELIST0,
- STORELIST,
- STORERECORD,
- ADJUST0,
- ADJUST,
- CREATEARRAY,
- EQOP,
- LTOP,
- LEOP,
- GTOP,
- GEOP,
- ADDOP,
- SUBOP,
- MULTOP,
- DIVOP,
- POWOP,
- CONCOP,
- MINUSOP,
- NOTOP,
- ONTJMP,
- ONFJMP,
- JMP,
- UPJMP,
- IFFJMP,
- IFFUPJMP,
- POP,
- CALLFUNC,
- RETCODE0,
- RETCODE,
- SETLINE
+typedef enum {
+/* name parm before after side effect
+-----------------------------------------------------------------------------*/
+
+PUSHNIL,/* - nil */
+PUSH0,/* - 0.0 */
+PUSH1,/* - 1.0 */
+PUSH2,/* - 2.0 */
+PUSHBYTE,/* b - (float)b */
+PUSHWORD,/* w - (float)w */
+PUSHFLOAT,/* f - f */
+PUSHSTRING,/* w - STR[w] */
+PUSHFUNCTION,/* p - FUN(p) */
+PUSHLOCAL0,/* - LOC[0] */
+PUSHLOCAL1,/* - LOC[1] */
+PUSHLOCAL2,/* - LOC[2] */
+PUSHLOCAL3,/* - LOC[3] */
+PUSHLOCAL4,/* - LOC[4] */
+PUSHLOCAL5,/* - LOC[5] */
+PUSHLOCAL6,/* - LOC[6] */
+PUSHLOCAL7,/* - LOC[7] */
+PUSHLOCAL8,/* - LOC[8] */
+PUSHLOCAL9,/* - LOC[9] */
+PUSHLOCAL,/* w - LOC[w] */
+PUSHGLOBAL,/* w - VAR[w] */
+PUSHINDEXED,/* i t t[i] */
+PUSHSELF,/* w t t t[STR[w]] */
+STORELOCAL0,/* x - LOC[0]=x */
+STORELOCAL1,/* x - LOC[1]=x */
+STORELOCAL2,/* x - LOC[2]=x */
+STORELOCAL3,/* x - LOC[3]=x */
+STORELOCAL4,/* x - LOC[4]=x */
+STORELOCAL5,/* x - LOC[5]=x */
+STORELOCAL6,/* x - LOC[6]=x */
+STORELOCAL7,/* x - LOC[7]=x */
+STORELOCAL8,/* x - LOC[8]=x */
+STORELOCAL9,/* x - LOC[9]=x */
+STORELOCAL,/* w x - LOC[w]=x */
+STOREGLOBAL,/* w x - VAR[w]=x */
+STOREINDEXED0,/* v i t - t[i]=v */
+STOREINDEXED,/* b v a_b...a_1 i t a_b...a_1 i t t[i]=v */
+STORELIST0,/* w v_w...v_1 t - t[i]=v_i */
+STORELIST,/* w n v_w...v_1 t - t[i+n*FPF]=v_i */
+STORERECORD,/* n
+ w_n...w_1 v_n...v_1 t - t[STR[w_i]]=v_i */
+ADJUST0,/* - - TOP=BASE */
+ADJUST,/* b - - TOP=BASE+b */
+CREATEARRAY,/* w - newarray(size = w) */
+EQOP,/* y x (x==y)? 1 : nil */
+LTOP,/* y x (x<y)? 1 : nil */
+LEOP,/* y x (x<y)? 1 : nil */
+GTOP,/* y x (x>y)? 1 : nil */
+GEOP,/* y x (x>=y)? 1 : nil */
+ADDOP,/* y x x+y */
+SUBOP,/* y x x-y */
+MULTOP,/* y x x*y */
+DIVOP,/* y x x/y */
+POWOP,/* y x x^y */
+CONCOP,/* y x x..y */
+MINUSOP,/* x -x */
+NOTOP,/* x (x==nil)? 1 : nil */
+ONTJMP,/* w x - (x!=nil)? PC+=w */
+ONFJMP,/* w x - (x==nil)? PC+=w */
+JMP,/* w - - PC+=w */
+UPJMP,/* w - - PC-=w */
+IFFJMP,/* w x - (x==nil)? PC+=w */
+IFFUPJMP,/* w x - (x==nil)? PC-=w */
+POP,/* x - */
+CALLFUNC,/* n m v_n...v_1 f r_m...r_1 f(v1,...,v_n) */
+RETCODE0,
+RETCODE,/* b - - */
+SETLINE,/* w - - LINE=w */
+VARARGS/* b v_n...v_1 {v_1...v_n;n=n} */
+
} OpCode;
+
#define MULT_RET 255
@@ -103,32 +127,15 @@ typedef struct Object
#define s_tag(i) (tag(&s_object(i)))
#define s_nvalue(i) (nvalue(&s_object(i)))
#define s_svalue(i) (svalue(&s_object(i)))
+#define s_tsvalue(i) (tsvalue(&s_object(i)))
#define s_avalue(i) (avalue(&s_object(i)))
#define s_fvalue(i) (fvalue(&s_object(i)))
#define s_uvalue(i) (uvalue(&s_object(i)))
-typedef union
-{
- struct {Byte c1; Byte c2;} m;
- Word w;
-} CodeWord;
-#define get_word(code,pc) {code.m.c1 = *pc++; code.m.c2 = *pc++;}
-
-typedef union
-{
- struct {Byte c1; Byte c2; Byte c3; Byte c4;} m;
- float f;
-} CodeFloat;
-#define get_float(code,pc) {code.m.c1 = *pc++; code.m.c2 = *pc++;\
- code.m.c3 = *pc++; code.m.c4 = *pc++;}
-
-typedef union
-{
- struct {Byte c1; Byte c2; Byte c3; Byte c4;} m;
- TFunc *tf;
-} CodeCode;
-#define get_code(code,pc) {code.m.c1 = *pc++; code.m.c2 = *pc++;\
- code.m.c3 = *pc++; code.m.c4 = *pc++;}
+#define get_word(code,pc) {memcpy(&code, pc, sizeof(Word)); pc+=sizeof(Word);}
+#define get_float(code,pc){memcpy(&code, pc, sizeof(real)); pc+=sizeof(real);}
+#define get_code(code,pc) {memcpy(&code, pc, sizeof(TFunc *)); \
+ pc+=sizeof(TFunc *);}
/* Exported functions */