mirror of
				https://github.com/SEPPDROID/Digital-Research-Source-Code.git
				synced 2025-10-24 17:04:19 +00:00 
			
		
		
		
	Upload
Digital Research
This commit is contained in:
		| @@ -0,0 +1,418 @@ | ||||
| /* | ||||
| 	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; | ||||
		Reference in New Issue
	
	Block a user