mirror of
https://github.com/SEPPDROID/Digital-Research-Source-Code.git
synced 2025-10-24 08:54:17 +00:00
419 lines
9.6 KiB
C
419 lines
9.6 KiB
C
/*
|
|
Copyright 1982
|
|
Alcyon Corporation
|
|
8716 Production Ave.
|
|
San Diego, Ca. 92121
|
|
*/
|
|
|
|
|
|
char null[]=0;
|
|
#define SSIZE 8 /* chars per symbol */
|
|
|
|
/*operator tree node for unary and binary operators*/
|
|
struct tnode {
|
|
int t_op; /*operator*/
|
|
int t_type; /*data type of result*/
|
|
int t_su; /*Sethy-Ullman number*/
|
|
int t_ssp;
|
|
struct tnode *t_left; /*left sub-tree*/
|
|
struct tnode *t_right; /*right sub-tree (undefined if unary)*/
|
|
};
|
|
|
|
/*constant terminal node*/
|
|
struct conode {
|
|
int t_op; /*operator*/
|
|
int t_type; /*type*/
|
|
int t_su; /*Sethy-Ullman number*/
|
|
int t_ssp;
|
|
int t_value; /*value or label number*/
|
|
};
|
|
|
|
struct lconode {
|
|
int t_op; /*operator*/
|
|
int t_type; /*type*/
|
|
int t_su; /*Sethy-Ullman number*/
|
|
int t_ssp;
|
|
long t_lvalue; /*value or label number*/
|
|
};
|
|
|
|
/*local symbol terminal node*/
|
|
struct symnode {
|
|
int t_op; /*operator*/
|
|
int t_type; /*symbol data type*/
|
|
int t_su; /*Sethy-Ullman number*/
|
|
int t_ssp;
|
|
int t_sc; /*storage class*/
|
|
int t_offset; /*register offset*/
|
|
int t_reg; /*register number*/
|
|
int t_label; /*label number if static*/
|
|
};
|
|
|
|
/*external symbol reference node*/
|
|
struct extnode {
|
|
int t_op; /*operator*/
|
|
int t_type; /*symbol data type*/
|
|
int t_su; /*Sethy-Ullman number*/
|
|
int t_ssp;
|
|
int t_sc; /*storage class*/
|
|
int t_offset; /*register offset*/
|
|
int t_reg; /*register number*/
|
|
char t_symbol[SSIZE]; /*symbol name*/
|
|
};
|
|
|
|
/*68000 special - indexed symbol node*/
|
|
/*this is used to generate a An(off,Xn.type) address*/
|
|
struct indexnode {
|
|
int t_op;
|
|
int t_type;
|
|
int t_su;
|
|
int t_ssp;
|
|
int t_sc;
|
|
int t_offset;
|
|
int t_reg;
|
|
int t_xreg;
|
|
int t_xtype;
|
|
};
|
|
|
|
int lflag=0;
|
|
int dflag=0;
|
|
int mflag=0;
|
|
int cflag=0;
|
|
int eflag=0;
|
|
int fflag=0;
|
|
int oflag=0;
|
|
int lineno=0;
|
|
int naregs=0;
|
|
int ndregs=0;
|
|
int errcnt=0;
|
|
int stacksize=0;
|
|
|
|
char *tnalloc();
|
|
char *snalloc();
|
|
char *cenalloc();
|
|
char *xnalloc();
|
|
char *talloc();
|
|
char *cnalloc();
|
|
char *lcnalloc();
|
|
char *fpcnalloc();
|
|
char *canon();
|
|
char *commute();
|
|
char *constant();
|
|
char *match();
|
|
char *addptree();
|
|
char *fixbfield();
|
|
char *coffset();
|
|
char *tcopy();
|
|
|
|
#define wallign(add) ((add+1)&(~1))
|
|
#define array(type) ((type&SUPTYP)==ARRAY)
|
|
#define function(type) ((type&SUPTYP)==FUNCTION)
|
|
#define pointer(type) ((type&SUPTYP)==POINTER)
|
|
#define notarray(type) ((type&SUPTYP)!=ARRAY)
|
|
#define notfunction(type) ((type&SUPTYP)!=FUNCTION)
|
|
#define notpointer(type) ((type&SUPTYP)!=POINTER)
|
|
#define isfloat(type) (type==FLOAT)
|
|
#define btype(type) (type&TYPE)
|
|
#define suptype(type) (type&SUPTYP)
|
|
#define alltype(type) (type&(SUPTYP|TYPE))
|
|
#define asgop(op) ((opinfo[op]&OPASSIGN)!=0)
|
|
#define relop(op) ((opinfo[op]&OPREL)!=0)
|
|
#define lintegral(op) ((opinfo[op]&OPLWORD)!=0)
|
|
#define rintegral(op) ((opinfo[op]&OPRWORD)!=0)
|
|
#define rasop(op) ((opinfo[op]&OPRAS)!=0)
|
|
#define binop(op) ((opinfo[op]&OPBIN)!=0)
|
|
#define unaryop(op) ((opinfo[op]&(OPBIN|OPTERM))==0)
|
|
#define leafop(op) ((opinfo[op]&OPTERM)!=0)
|
|
#define notleafop(op) ((opinfo[op]&OPTERM)==0)
|
|
#define lvalop(op) ((opinfo[op]&OPLVAL)!=0)
|
|
#define oppriority(op) (opinfo[op]&OPPRI)
|
|
#define commop(op) ((opinfo[op]&OPCOM)!=0)
|
|
#define convop(op) ((opinfo[op]&OPCONVS)!=0)
|
|
#define notconvop(op) ((opinfo[op]&OPCONVS)==0)
|
|
#define max(a,b) (a>b?a:b)
|
|
#define min(a,b) (a<b?a:b)
|
|
|
|
#define QUICKVAL 8
|
|
#define LEP 14
|
|
#define FORCC 1
|
|
#define FOREFF 2
|
|
#define FORSTACK 3
|
|
#define FORCREG 4
|
|
#define FORSP 5
|
|
#define FORREG 4
|
|
#define HICREG 2
|
|
#define NCREGS 3
|
|
#define AREGLO 8
|
|
#define IMMED 1
|
|
#define NOTIMMED 0
|
|
#define NOTLOFFSET 0
|
|
|
|
/* one line routines turned into defines [vlh] for speed */
|
|
|
|
/*outgoto - output "bra L[labno]"*/
|
|
#define outgoto(lab) if (lab>0) printf("bra L%d\n",lab)
|
|
/*outlab - output "L[labno]:"*/
|
|
#define outlab(lab) if (lab>0) printf("L%d:",lab)
|
|
|
|
/*outext - output register sign extension*/
|
|
#define outext(reg) printf("ext.l R%d\n",reg)
|
|
/*outuext - output unsigned to long register extension*/
|
|
#define outuext(reg) printf("swap R%d\nclr R%d\nswap R%d\n",reg,reg,reg)
|
|
/*outswap - output swap register instruction*/
|
|
#define outswap(reg) printf("swap R%d\n",reg)
|
|
/*outaddr - output "add [type] R1 R2" instruction*/
|
|
#define outaddr(r1,r2,tp) outrr("add",r1,r2,(tp))
|
|
/*outccsave - ouput instruction to move cc's to register*/
|
|
#define outccsave(reg) printf("move sr,R%d\n",reg)
|
|
/*outccrestore - output instruction to restore cc's from register*/
|
|
#define outccrestore(reg) printf("move R%d,ccr\n",reg)
|
|
/*basetype - get the btype info sans unsigned*/
|
|
#define basetype(type) ((type==UNSIGNED) ? INT : type)
|
|
#define unsign(type) ((type) == UNSIGNED)
|
|
#define longorptr(type) (type==LONG || (type&SUPTYP))
|
|
#define unorptr(type) (type==UNSIGNED || (type&SUPTYP))
|
|
#define dreg(reg) ((reg) & (~AREGLO))
|
|
#define areg(reg) ((reg) | AREGLO)
|
|
#define isareg(reg) ((reg) >= AREGLO)
|
|
#define isdreg(reg) ((reg) < AREGLO)
|
|
#define isreg(tp) ((tp)->t_op == SYMBOL && (tp)->t_sc == REGISTER)
|
|
|
|
/*
|
|
* intermediate code operators
|
|
* 0=>EOF, special operator
|
|
*/
|
|
#define EOF 0
|
|
|
|
/*1-59=>operators that generate code (entries in code gen optab)*/
|
|
#define ADD 1
|
|
#define SUB 2
|
|
#define MULT 3
|
|
#define DIV 4
|
|
#define MOD 5
|
|
#define RSH 6
|
|
#define LSH 7
|
|
#define AND 8
|
|
#define OR 9
|
|
#define XOR 10
|
|
#define NOT 11
|
|
#define UMINUS 12
|
|
#define COMPL 13
|
|
#define PREDEC 14
|
|
#define PREINC 15
|
|
#define POSTDEC 16
|
|
#define POSTINC 17
|
|
#define ASSIGN 18
|
|
#define EQADD 19
|
|
#define EQSUB 20
|
|
#define EQMULT 21
|
|
#define EQDIV 22
|
|
#define EQMOD 23
|
|
#define EQRSH 24
|
|
#define EQLSH 25
|
|
#define EQAND 26
|
|
#define EQOR 27
|
|
#define EQXOR 28
|
|
#define FJSR 29
|
|
#define EQUALS 30
|
|
#define NEQUALS 31
|
|
#define GREAT 32
|
|
#define GREATEQ 33
|
|
#define LESS 34
|
|
#define LESSEQ 35
|
|
#define INT2L 36
|
|
#define LONG2I 37
|
|
|
|
/*machine dependent operators that generate code*/
|
|
#define BTST 38
|
|
#define LOAD 39
|
|
#define LMULT 40
|
|
#define LDIV 41
|
|
#define LMOD 42
|
|
#define LEQMULT 43
|
|
#define LEQDIV 44
|
|
#define LEQMOD 45
|
|
#define EQADDR 46
|
|
#define EQNOT 47
|
|
#define EQNEG 48
|
|
#define DOCAST 49
|
|
|
|
#define STASSIGN 50 /*[vlh]*/
|
|
#define LONG2F 51 /*[vlh] 3.4*/
|
|
#define FLOAT2L 52 /*[vlh] 3.4*/
|
|
#define INT2F 53 /*[vlh] 3.4*/
|
|
#define FLOAT2I 54 /*[vlh] 3.4*/
|
|
#define LCGENOP 55 /*change if adding more operators...*/
|
|
|
|
/*intermediate code operators that do not generate code*/
|
|
#define ADDR 60
|
|
#define INDR 61
|
|
#define LAND 62
|
|
#define LOR 63
|
|
#define QMARK 64
|
|
#define COLON 65
|
|
#define COMMA 66
|
|
#define CINT 67
|
|
#define CLONG 68
|
|
#define SYMBOL 69
|
|
#define AUTOINC 70
|
|
#define AUTODEC 71
|
|
#define CALL 72
|
|
#define NACALL 73
|
|
#define BFIELD 74
|
|
#define IFGOTO 75
|
|
#define INIT 76
|
|
#define CFORREG 77
|
|
#define DCLONG 78
|
|
#define CFLOAT 79 /*[vlh] 3.4*/
|
|
|
|
/*operators local to parser*/
|
|
#define CAST 80
|
|
#define SEMI 81
|
|
#define LCURBR 82
|
|
#define RCURBR 83
|
|
#define LBRACK 84
|
|
#define RBRACK 85
|
|
#define LPAREN 86
|
|
#define RPAREN 87
|
|
#define STRING 88
|
|
#define RESWORD 89
|
|
#define APTR 90
|
|
#define PERIOD 91
|
|
#define SIZEOF 92
|
|
#define MPARENS 93
|
|
#define FRETURN 94
|
|
#define STACKEND 100
|
|
|
|
/*data types*/
|
|
#define TYPELESS 0
|
|
#define CHAR 1
|
|
#define SHORT 2
|
|
#define INT 3
|
|
#define LONG 4
|
|
#define UCHAR 5
|
|
#define USHORT 6
|
|
#define UNSIGNED 7
|
|
#define ULONG 8
|
|
#define FLOAT 9
|
|
#define DOUBLE 10
|
|
|
|
/*data types local to parser*/
|
|
#define STRUCT 11
|
|
#define FRSTRUCT 12
|
|
#define LLABEL 13
|
|
|
|
/*type flags and definitions*/
|
|
#define TYPE 017
|
|
#define SUPTYP 060
|
|
#define ALLTYPE 077
|
|
#define POINTER 020
|
|
#define FUNCTION 040
|
|
#define ARRAY 060
|
|
#define SUTYPLEN 2
|
|
|
|
/*data registers*/
|
|
#define DREG0 0
|
|
#define DREG2 2
|
|
#define DREG3 3
|
|
#define DREG4 4
|
|
#define DREG5 5
|
|
#define DREG6 6
|
|
#define DREG7 7
|
|
#define AREG3 11
|
|
#define AREG4 12
|
|
#define AREG5 13
|
|
|
|
/*storage classes*/
|
|
#define AUTO 1
|
|
#define REGISTER 2
|
|
#define EXTERNAL 3
|
|
#define STATIC 4
|
|
#define REGOFF 5
|
|
#define EXTOFF 6
|
|
#define STATOFF 7
|
|
#define INDEXED 8
|
|
|
|
/*exclusively code generator storage classes*/
|
|
#define CINDR 9
|
|
#define CLINDR 10
|
|
#define CFINDR 11 /* [vlh] 3.4 */
|
|
|
|
/*exclusively parser storage classes*/
|
|
#define STRPROTO 9
|
|
#define PDECLIST 10
|
|
#define PARMLIST 11
|
|
#define BFIELDCL 12
|
|
#define UNELCL 13
|
|
#define STELCL 14
|
|
|
|
|
|
/*opinfo table bits*/
|
|
#define OPPRI 077
|
|
#define OPBIN 0100
|
|
#define OPLVAL 0200
|
|
#define OPREL 0400
|
|
#define OPASSIGN 01000
|
|
#define OPLWORD 02000
|
|
#define OPRWORD 04000
|
|
#define OPCOM 010000
|
|
#define OPRAS 020000
|
|
#define OPTERM 040000
|
|
#define OPCONVS 0100000
|
|
|
|
/*68000 definitions*/
|
|
#define PTRSIZE 4
|
|
#define INTSIZE 2
|
|
#define LONGSIZE 4
|
|
#define TRUE 1
|
|
#define FALSE 0
|
|
#define TABC '\t' /* tab character */
|
|
#define EOLC '\n' /* end of line character */
|
|
#define BITSPBYTE 8
|
|
|
|
/*operator class priorities*/
|
|
#define TRMPRI 0 /* terminal nodes */
|
|
#define RPNPRI 1 /* ) and ] */
|
|
#define CALPRI 2 /* in-stack call, ( or [ */
|
|
#define COLPRI 3 /* init or case priority for : or , */
|
|
#define STKPRI 4 /* priority of end of stack */
|
|
#define COMPRI 5 /* normal priority for , */
|
|
#define ASGPRI 6 /* =, +=, -=, *=, /=, %=, ... */
|
|
#define QMKPRI 7 /* ?: */
|
|
#define LORPRI 8 /* || */
|
|
#define LNDPRI 9 /* && */
|
|
#define ORPRI 10 /* |, ! */
|
|
#define ANDPRI 11 /* & */
|
|
#define EQLPRI 12 /* ==, != */
|
|
#define RELPRI 13 /* >, <, >=, <= */
|
|
#define SHFPRI 14 /* <<, >> */
|
|
#define ADDPRI 15 /* +, - */
|
|
#define MULPRI 16 /* *, /, % */
|
|
#define UNOPRI 17 /* ++, --, &, *, -, ~, sizeof */
|
|
#define LPNPRI 18 /* ., ->, [, (, function call */
|
|
#define PSTPRI 19 /* in-stack post--, post++ */
|
|
|
|
struct io_buf {
|
|
int io_fd;
|
|
int io_nc;
|
|
char *io_p;
|
|
char io_b[512];
|
|
};
|
|
struct { int hiword; int loword; };
|
|
#define EXPSIZE 1024
|
|
int exprarea[EXPSIZE]=0;
|
|
|
|
/* v6io buffer declaration */
|
|
#define BLEN 512
|
|
|
|
struct iobuf {
|
|
int fildes;
|
|
int nunused;
|
|
char *xfree;
|
|
char buff[BLEN];
|
|
};
|
|
struct io_buf ibuf={0}, obuf={0};
|
|
int bol=0;
|
|
int errflg=0;
|
|
int level=0;
|
|
int onepass=0;
|
|
char *opap=0;
|