mirror of
				https://github.com/SEPPDROID/Digital-Research-Source-Code.git
				synced 2025-10-25 01:14:21 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			253 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			253 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #
 | |
| /*
 | |
| 	Copyright 1981
 | |
| 	Alcyon Corporation
 | |
| 	8474 Commerce Av.
 | |
| 	San Diego, Ca.  92121
 | |
| */
 | |
| 
 | |
| #include "cgen.h"
 | |
| #ifndef	NODEBUG
 | |
| 
 | |
| char invalid[] "INVALID";
 | |
| 
 | |
| char *opname[] {
 | |
| 	invalid,						/*0*/
 | |
| 	"+",							/*1*/
 | |
| 	"-",							/*2*/
 | |
| 	"*",							/*3*/
 | |
| 	"/",							/*4*/
 | |
| 	"%",							/*5*/
 | |
| 	">>",							/*6*/
 | |
| 	"<<",							/*7*/
 | |
| 	"&",							/*8*/
 | |
| 	"|",							/*9*/
 | |
| 	"^",							/*10*/
 | |
| 	"!",							/*11*/
 | |
| 	"U-",							/*12*/
 | |
| 	"~",							/*13*/
 | |
| 	"--p",							/*14*/
 | |
| 	"++p",							/*15*/
 | |
| 	"p--",							/*16*/
 | |
| 	"p++",							/*17*/
 | |
| 	"=",							/*18*/
 | |
| 	"+=",							/*19*/
 | |
| 	"-=",							/*20*/
 | |
| 	"*=",							/*21*/
 | |
| 	"/=",							/*22*/
 | |
| 	"%=",							/*23*/
 | |
| 	">>=",							/*24*/
 | |
| 	"<<=",							/*25*/
 | |
| 	"&=",							/*26*/
 | |
| 	"|=",							/*27*/
 | |
| 	"^=",							/*28*/
 | |
| 	"jsr",							/*29*/
 | |
| 	"==",							/*30*/
 | |
| 	"!=",							/*31*/
 | |
| 	">",							/*32*/
 | |
| 	">=",							/*33*/
 | |
| 	"<",							/*34*/
 | |
| 	"<=",							/*35*/
 | |
| 	"int->long",					/*36*/
 | |
| 	"long->int",					/*37*/
 | |
| 	"btst",							/*38*/
 | |
| 	"load",							/*39*/
 | |
| 	"long*",						/*40*/
 | |
| 	"long/",						/*41*/
 | |
| 	"long%",						/*42*/
 | |
| 	"long*=",						/*43*/
 | |
| 	"long/=",						/*44*/
 | |
| 	"long%=",						/*45*/
 | |
| 	"=addr",						/*46*/
 | |
| 	invalid,						/*47*/
 | |
| 	invalid,						/*48*/
 | |
| 	invalid,						/*49*/
 | |
| 	invalid,						/*50*/
 | |
| 	invalid,						/*51*/
 | |
| 	invalid,						/*52*/
 | |
| 	invalid,						/*53*/
 | |
| 	invalid,						/*54*/
 | |
| 	invalid,						/*55*/
 | |
| 	invalid,						/*56*/
 | |
| 	invalid,						/*57*/
 | |
| 	invalid,						/*58*/
 | |
| 	invalid,						/*59*/
 | |
| 	"U&",							/*60*/
 | |
| 	"U*",							/*61*/
 | |
| 	"&&",							/*62*/
 | |
| 	"||",							/*63*/
 | |
| 	"?",							/*64*/
 | |
| 	":",							/*65*/
 | |
| 	",",							/*66*/
 | |
| 	"cint",							/*67*/
 | |
| 	"clong",						/*68*/
 | |
| 	"symbol",						/*69*/
 | |
| 	"++a",							/*70*/
 | |
| 	"a--",							/*71*/
 | |
| 	"call",							/*72*/
 | |
| 	"call()",						/*73*/
 | |
| 	"bitfield",						/*74*/
 | |
| 	"if",							/*75*/
 | |
| 	"init",							/*76*/
 | |
| 	"loadR0",						/*77*/
 | |
| 	"divlong",						/*78*/
 | |
| };
 | |
| 
 | |
| char *types[] {
 | |
| 	invalid,						/*0=TYPELESS*/
 | |
| 	"char",							/*1=CHAR*/
 | |
| 	invalid,						/*2=SHORT*/
 | |
| 	"int",							/*3=INT*/
 | |
| 	"long",							/*4=LONG*/
 | |
| 	invalid,						/*5=UCHAR*/
 | |
| 	invalid,						/*6=USHORT*/
 | |
| 	"uint",							/*7=UINT*/
 | |
| 	invalid,						/*8=ULONG*/
 | |
| 	invalid,						/*9=FLOAT*/
 | |
| 	invalid,						/*10=DOUBLE*/
 | |
| 	"struct",						/*11=STRUCT*/
 | |
| 	invalid,						/*12=undefined*/
 | |
| 	invalid,						/*13=undefined*/
 | |
| 	invalid,						/*14=undefined*/
 | |
| 	invalid,						/*15=undefined*/
 | |
| };
 | |
| 
 | |
| char *suvals[] {
 | |
| 	"zero",
 | |
| 	"one",
 | |
| 	"quick",
 | |
| 	"small",
 | |
| 	"constant",
 | |
| 	"Areg",
 | |
| 	"Dreg",
 | |
| 	"addressable",
 | |
| 	"loadable",
 | |
| 	"easy",
 | |
| 	"hard",
 | |
| };
 | |
| 
 | |
| int level;
 | |
| 
 | |
| putexpr(name,tp)
 | |
| char *name;
 | |
| struct tnode *tp;
 | |
| {
 | |
| 	printf("%s\n",name);
 | |
| 	putsexpr(tp);
 | |
| }
 | |
| 
 | |
| putsexpr(tp)
 | |
| struct tnode *tp;
 | |
| {
 | |
| 	register struct tnode *ltp;
 | |
| 
 | |
| 	level++;
 | |
| 	ltp = tp->t_left;
 | |
| 	outlevel();
 | |
| 	printf("%s ",opname[tp->t_op]);
 | |
| 	if( tp->t_op == BFIELD || tp->t_op == IFGOTO ) {
 | |
| 		if( tp->t_op == BFIELD )
 | |
| 			printf("off=%d len=%d\n",(tp->t_su>>8)&0377,tp->t_su&0377);
 | |
| 		else
 | |
| 			printf("%s goto L%d\n",tp->t_type?"TRUE":"FALSE",tp->t_su);
 | |
| 		putsexpr(tp->t_left);
 | |
| 		level--;
 | |
| 		return;
 | |
| 	}
 | |
| 	puttsu(tp);
 | |
| 	switch( tp->t_op ) {
 | |
| 
 | |
| 	case DCLONG:
 | |
| 	case CLONG:
 | |
| 		printf(" %x.%x\n",tp->t_lvalue.hiword,tp->t_lvalue.loword);
 | |
| 		break;
 | |
| 
 | |
| 	case CINT:
 | |
| 		printf(" %d\n",tp->t_value);
 | |
| 		break;
 | |
| 
 | |
| 	case AUTODEC:
 | |
| 	case AUTOINC:
 | |
| 		printf(" R%d\n",tp->t_reg);
 | |
| 		break;
 | |
| 
 | |
| 	case SYMBOL:
 | |
| 		switch( tp->t_sc ) {
 | |
| 
 | |
| 		case REGISTER:
 | |
| 			printf(" R%d",tp->t_reg);
 | |
| 			break;
 | |
| 
 | |
| 		case CINDR:
 | |
| 			printf(" %d\n",tp->t_offset);
 | |
| 			break;
 | |
| 
 | |
| 		case CLINDR:
 | |
| 			printf(" %x.%x\n",tp->t_offset,tp->t_ssp);
 | |
| 			break;
 | |
| 
 | |
| 		case REGOFF:
 | |
| 			printf(" %d(R%d)",tp->t_offset,tp->t_reg);
 | |
| 			break;
 | |
| 
 | |
| 		case EXTERNAL:
 | |
| 		case EXTOFF:
 | |
| 			printf(" %s+%d",tp->t_symbol,tp->t_offset);
 | |
| 			if( tp->t_sc == EXTOFF )
 | |
| 				printf("(R%d)",tp->t_reg);
 | |
| 			break;
 | |
| 
 | |
| 		case STATIC:
 | |
| 		case STATOFF:
 | |
| 			printf(" L%d+%d",tp->t_label,tp->t_offset);
 | |
| 			if( tp->t_sc == STATOFF )
 | |
| 				printf("(R%d)",tp->t_reg);
 | |
| 			break;
 | |
| 
 | |
| 		case INDEXED:
 | |
| 			printf(" %d(R%d,R%d)",tp->t_offset,tp->t_reg,tp->t_xreg);
 | |
| 			break;
 | |
| 		}
 | |
| 		putchar('\n');
 | |
| 		break;
 | |
| 
 | |
| 	case IFGOTO:
 | |
| 		putsexpr(tp->t_left);
 | |
| 		break;
 | |
| 
 | |
| 	default:
 | |
| 		putchar('\n');
 | |
| 		putsexpr(tp->t_left);
 | |
| 		if( binop(tp->t_op) )
 | |
| 			putsexpr(tp->t_right);
 | |
| 		break;
 | |
| 	}
 | |
| 	level--;
 | |
| }
 | |
| 
 | |
| outlevel()
 | |
| {
 | |
| 	register int i;
 | |
| 
 | |
| 	for( i = 0; i < level; i++ )
 | |
| 		putchar('\t');
 | |
| }
 | |
| 
 | |
| puttsu(tp)
 | |
| struct tnode *tp;
 | |
| {
 | |
| 	register int i;
 | |
| 
 | |
| 	if( suptype(tp->t_type) )
 | |
| 		putchar('*');
 | |
| 	printf("%s ",types[btype(tp->t_type)]);
 | |
| 	if( tp->t_su != 0 || (tp->t_op == CINT && tp->t_value == 0) ) {
 | |
| 		i = tp->t_su >> 8;
 | |
| 		if( i > 15 || i < 0 )
 | |
| 			printf("INVALID");
 | |
| 		else
 | |
| 			printf("%s",suvals[tp->t_su>>8]);
 | |
| 	}
 | |
| }
 | |
| #endif
 |