|
|
1.1 ! root 1: # include "macdefs" ! 2: # include "mac2defs" ! 3: # include "manifest" ! 4: ! 5: # ifdef ONEPASS ! 6: ! 7: /* bunch of stuff for putting the passes together... */ ! 8: # define crslab crs2lab ! 9: # define where where2 ! 10: # define xdebug x2debug ! 11: # define tdebug t2debug ! 12: # define deflab def2lab ! 13: # define edebug e2debug ! 14: # define eprint e2print ! 15: # define filename ftitle ! 16: # define getlab get2lab ! 17: # endif ! 18: ! 19: /* cookies, used as arguments to codgen */ ! 20: ! 21: # define FOREFF 01 /* compute for effects only */ ! 22: # define INAREG 02 /* compute into a register */ ! 23: # define INTAREG 04 /* compute into a scratch register */ ! 24: # define INBREG 010 /* compute into a lvalue register */ ! 25: # define INTBREG 020 /* compute into a scratch lvalue register */ ! 26: # define FORCC 040 /* compute for condition codes only */ ! 27: # define INTEMP 010000 /* compute into a temporary location */ ! 28: # define FORARG 020000 /* compute for an argument of a function */ ! 29: # define FORREW 040000 /* search the table, looking for a rewrite rule */ ! 30: ! 31: /* OP descriptors */ ! 32: /* the ASG operator may be used on some of these */ ! 33: ! 34: # define OPSIMP 010000 /* +, -, &, |, ^ */ ! 35: # define OPCOMM 010002 /* +, &, |, ^ */ ! 36: # define OPMUL 010004 /* *, / */ ! 37: # define OPDIV 010006 /* /, % */ ! 38: # define OPUNARY 010010 /* unary ops */ ! 39: # define OPLEAF 010012 /* leaves */ ! 40: # define OPANY 010014 /* any op... */ ! 41: # define OPLOG 010016 /* logical ops */ ! 42: # define OPFLOAT 010020 /* +, -, *, or / (for floats) */ ! 43: # define OPSHFT 010022 /* <<, >> */ ! 44: # define OPLTYPE 010024 /* leaf type nodes (e.g, NAME, ICON, etc. ) */ ! 45: ! 46: /* match returns */ ! 47: ! 48: # define MNOPE 010000 ! 49: # define MDONE 010001 ! 50: ! 51: /* shapes */ ! 52: ! 53: # define SANY 01 /* same as FOREFF */ ! 54: # define SAREG 02 /* same as INAREG */ ! 55: # define STAREG 04 /* same as INTAREG */ ! 56: # define SBREG 010 /* same as INBREG */ ! 57: # define STBREG 020 /* same as INTBREG */ ! 58: # define SCC 040 /* same as FORCC */ ! 59: # define SNAME 0100 ! 60: # define SCON 0200 ! 61: # define SFLD 0400 ! 62: # define SOREG 01000 ! 63: # define STARNM 02000 ! 64: # define STARREG 04000 ! 65: # define SWADD 040000 ! 66: # define SPECIAL 0100000 ! 67: # define SZERO SPECIAL ! 68: # define SONE (SPECIAL|1) ! 69: # define SMONE (SPECIAL|2) ! 70: # define SCCON (SPECIAL|3) /* -256 <= constant < 256 */ ! 71: # define SSCON (SPECIAL|4) /* -32768 <= constant < 32768 */ ! 72: # define SSOREG (SPECIAL|5) /* non-indexed OREG */ ! 73: ! 74: /* FORARG and INTEMP are carefully not conflicting with shapes */ ! 75: ! 76: /* types */ ! 77: ! 78: # define TCHAR 01 ! 79: # define TSHORT 02 ! 80: # define TINT 04 ! 81: # define TLONG 010 ! 82: # define TFLOAT 020 ! 83: # define TDOUBLE 040 ! 84: # define TPOINT 0100 ! 85: # define TUCHAR 0200 ! 86: # define TUSHORT 0400 ! 87: # define TUNSIGNED 01000 ! 88: # define TULONG 02000 ! 89: # define TPTRTO 04000 /* pointer to one of the above */ ! 90: # define TANY 010000 /* matches anything within reason */ ! 91: # define TSTRUCT 020000 /* structure or union */ ! 92: ! 93: /* reclamation cookies */ ! 94: ! 95: # define RNULL 0 /* clobber result */ ! 96: # define RLEFT 01 ! 97: # define RRIGHT 02 ! 98: # define RESC1 04 ! 99: # define RESC2 010 ! 100: # define RESC3 020 ! 101: # define RESCC 04000 ! 102: # define RNOP 010000 /* DANGER: can cause loops.. */ ! 103: ! 104: /* needs */ ! 105: ! 106: # define NAREG 01 ! 107: # define NACOUNT 03 ! 108: # define NAMASK 017 ! 109: # define NASL 04 /* share left register */ ! 110: # define NASR 010 /* share right register */ ! 111: # define NBREG 020 ! 112: # define NBCOUNT 060 ! 113: # define NBMASK 0360 ! 114: # define NBSL 0100 ! 115: # define NBSR 0200 ! 116: # define NTEMP 0400 ! 117: # define NTMASK 07400 ! 118: # define REWRITE 010000 ! 119: ! 120: ! 121: # define MUSTDO 010000 /* force register requirements */ ! 122: # define NOPREF 020000 /* no preference for register assignment */ ! 123: ! 124: ! 125: /* register allocation */ ! 126: ! 127: extern int rstatus[]; ! 128: extern int busy[]; ! 129: ! 130: extern struct respref { int cform; int mform; } respref[]; ! 131: ! 132: # define isbreg(r) (rstatus[r]&SBREG) ! 133: # define istreg(r) (rstatus[r]&(STBREG|STAREG)) ! 134: # define istnode(p) (p->op==REG && istreg(p->rval)) ! 135: ! 136: # define TBUSY 01000 ! 137: # define REGLOOP(i) for(i=0;i<REGSZ;++i) ! 138: ! 139: # define SETSTO(x,y) (stotree=(x),stocook=(y)) ! 140: extern int stocook; ! 141: # define DELAYS 20 ! 142: extern NODE *deltrees[DELAYS]; ! 143: extern int deli; /* mmmmm */ ! 144: ! 145: extern NODE *stotree; ! 146: extern int callflag; ! 147: ! 148: extern int fregs; ! 149: ! 150: # ifndef ONEPASS ! 151: union ndu { ! 152: ! 153: struct { ! 154: int op; ! 155: int rall; ! 156: TWORD type; ! 157: int su; ! 158: char name[NCHNAM]; ! 159: NODE *left; ! 160: NODE *right; ! 161: }; ! 162: ! 163: struct { ! 164: int op; ! 165: int rall; ! 166: TWORD type; ! 167: int su; ! 168: char name[NCHNAM]; ! 169: CONSZ lval; ! 170: int rval; ! 171: }; ! 172: ! 173: struct { ! 174: int op, rall; ! 175: TWORD type; ! 176: int su; ! 177: int label; /* for use with branching */ ! 178: }; ! 179: ! 180: struct { ! 181: int op, rall; ! 182: TWORD type; ! 183: int su; ! 184: int stsize; /* sizes of structure objects */ ! 185: int stalign; /* alignment of structure objects */ ! 186: }; ! 187: ! 188: }; ! 189: #endif ! 190: ! 191: extern NODE node[]; ! 192: ! 193: extern struct optab { ! 194: int op; ! 195: int visit; ! 196: int lshape; ! 197: int ltype; ! 198: int rshape; ! 199: int rtype; ! 200: int needs; ! 201: int rewrite; ! 202: char * cstring; ! 203: } ! 204: table[]; ! 205: ! 206: extern NODE resc[]; ! 207: ! 208: extern OFFSZ tmpoff; ! 209: extern OFFSZ maxoff; ! 210: extern OFFSZ baseoff; ! 211: extern OFFSZ maxtemp; ! 212: extern int maxtreg; ! 213: extern int ftnno; ! 214: ! 215: extern int nrecur; /* flag to keep track of recursions */ ! 216: ! 217: # define NRECUR (10*TREESZ) ! 218: ! 219: extern NODE ! 220: *talloc(), ! 221: *eread(), ! 222: *tcopy(), ! 223: *getlr(); ! 224: ! 225: extern CONSZ rdin(); ! 226: ! 227: extern int eprint(); ! 228: ! 229: extern char *rnames[]; ! 230: ! 231: extern int lineno; ! 232: extern char filename[]; ! 233: extern int fldshf, fldsz; ! 234: extern int lflag, xdebug, udebug, edebug, odebug, rdebug, radebug, tdebug, sdebug; ! 235: ! 236: #ifndef callchk ! 237: #define callchk(x) allchk() ! 238: #endif ! 239: ! 240: #ifndef PUTCHAR ! 241: # define PUTCHAR(x) putchar(x) ! 242: #endif ! 243: ! 244: /* macros for doing double indexing */ ! 245: # define R2PACK(x,y,z) (0200*((x)+1)+y+040000*z) ! 246: # define R2UPK1(x) ((((x)>>7)-1)&0177) ! 247: # define R2UPK2(x) ((x)&0177) ! 248: # define R2UPK3(x) (x>>14) ! 249: # define R2TEST(x) ((x)>=0200)
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.