mirror of
https://github.com/mortdeus/legacy-cc.git
synced 2024-10-27 17:04:00 +00:00
init
This commit is contained in:
parent
dbb93eacff
commit
d2270d144b
@ -2,3 +2,8 @@ legacy-cc
|
||||
=========
|
||||
|
||||
The earliest versions of the very first c compiler known to exist in the wild written by the late legend himself dmr.
|
||||
|
||||
These are not capable of being compiled today with modern c compilers like gcc. I am only posting these here for the enjoyment and reminiscing of the spark that ignited a soon to be trillion dollar industry. Enjoy. :)
|
||||
|
||||
|
||||
Source: [http://cm.bell-labs.com/cm/cs/who/dmr/primevalC.html]
|
||||
|
581
last1120c/c00.c
Normal file
581
last1120c/c00.c
Normal file
@ -0,0 +1,581 @@
|
||||
/* C compiler
|
||||
|
||||
Copyright 1972 Bell Telephone Laboratories, Inc.
|
||||
|
||||
*/
|
||||
|
||||
ossiz 250;
|
||||
ospace() {} /* fake */
|
||||
|
||||
init(s, t)
|
||||
char s[]; {
|
||||
extern lookup, symbuf, namsiz;
|
||||
char symbuf[], sp[];
|
||||
int np[], i;
|
||||
|
||||
i = namsiz;
|
||||
sp = symbuf;
|
||||
while(i--)
|
||||
if ((*sp++ = *s++)=='\0') --s;
|
||||
np = lookup();
|
||||
*np++ = 1;
|
||||
*np = t;
|
||||
}
|
||||
|
||||
main(argc, argv)
|
||||
int argv[]; {
|
||||
extern init, flush;
|
||||
extern extdef, eof, open, creat;
|
||||
extern fout, fin, error, exit, nerror, tmpfil;
|
||||
|
||||
if(argc<4) {
|
||||
error("Arg count");
|
||||
exit(1);
|
||||
}
|
||||
if((fin=open(argv[1],0))<0) {
|
||||
error("Can't find %s", argv[1]);
|
||||
exit(1);
|
||||
}
|
||||
if((fout=creat(argv[2], 017))<0) {
|
||||
error("Can't create %s", argv[2]);
|
||||
exit(1);
|
||||
}
|
||||
tmpfil = argv[3];
|
||||
init("int", 0);
|
||||
init("char", 1);
|
||||
init("float", 2);
|
||||
init("double", 3);
|
||||
/* init("long", 4); */
|
||||
init("auto", 5);
|
||||
init("extern", 6);
|
||||
init("static", 7);
|
||||
init("goto", 10);
|
||||
init("return", 11);
|
||||
init("if", 12);
|
||||
init("while", 13);
|
||||
init("else", 14);
|
||||
init("switch", 15);
|
||||
init("case", 16);
|
||||
init("break", 17);
|
||||
init("continue", 18);
|
||||
init("do", 19);
|
||||
init("default", 20);
|
||||
while(!eof) {
|
||||
extdef();
|
||||
blkend();
|
||||
}
|
||||
flush();
|
||||
flshw();
|
||||
exit(nerror!=0);
|
||||
}
|
||||
|
||||
lookup() {
|
||||
extern hshtab[], hshsiz, pssiz, symbuf[];
|
||||
extern hshlen, hshused, exit, error, nwps;
|
||||
auto i, j, np[], sp[], rp[];
|
||||
|
||||
i = 0;
|
||||
sp = symbuf;
|
||||
j = nwps;
|
||||
while(j--)
|
||||
i =+ *sp++;
|
||||
if (i<0) i = -i;
|
||||
i =% hshsiz;
|
||||
i =* pssiz;
|
||||
while(*(np = &hshtab[i+4])) {
|
||||
sp = symbuf;
|
||||
j = nwps;
|
||||
while(j--)
|
||||
if (*np++ != *sp++) goto no;
|
||||
return(&hshtab[i]);
|
||||
no: if ((i =+ pssiz) >= hshlen) i = 0;
|
||||
}
|
||||
if(hshused++ > hshsiz) {
|
||||
error("Symbol table overflow");
|
||||
exit(1);
|
||||
}
|
||||
rp = np = &hshtab[i];
|
||||
sp = symbuf;
|
||||
j = 4;
|
||||
while(j--)
|
||||
*np++ = 0;
|
||||
j = nwps;
|
||||
while(j--)
|
||||
*np++ = *sp++;
|
||||
return(rp);
|
||||
}
|
||||
|
||||
symbol() {
|
||||
extern peeksym, peekc, eof, getchar, subseq, error, line;
|
||||
extern csym[], getstr, symbuf, namsiz, lookup[], ctab, cval;
|
||||
auto b, c;
|
||||
char symbuf[], sp[], ctab[];
|
||||
|
||||
if (peeksym>=0) {
|
||||
c = peeksym;
|
||||
peeksym = -1;
|
||||
return(c);
|
||||
}
|
||||
if (peekc) {
|
||||
c = peekc;
|
||||
peekc = 0;
|
||||
} else
|
||||
if (eof)
|
||||
return(0); else
|
||||
c = getchar();
|
||||
loop:
|
||||
switch(ctab[c]) {
|
||||
|
||||
case 125: /* newline */
|
||||
line++;
|
||||
|
||||
case 126: /* white space */
|
||||
c = getchar();
|
||||
goto loop;
|
||||
|
||||
case 0: /* EOF */
|
||||
eof++;
|
||||
return(0);
|
||||
|
||||
case 40: /* + */
|
||||
return(subseq(c,40,30));
|
||||
|
||||
case 41: /* - */
|
||||
return(subseq(c,41,31));
|
||||
|
||||
case 80: /* = */
|
||||
if (subseq(' ',0,1)) return(80);
|
||||
c = symbol();
|
||||
if (c>=40 & c<=49)
|
||||
return(c+30);
|
||||
if (c==80)
|
||||
return(60);
|
||||
peeksym = c;
|
||||
return(80);
|
||||
|
||||
case 63: /* < */
|
||||
if (subseq(c,0,1)) return(46);
|
||||
return(subseq('=',63,62));
|
||||
|
||||
case 65: /* > */
|
||||
if (subseq(c,0,1)) return(45);
|
||||
return(subseq('=',65,64));
|
||||
|
||||
case 34: /* ! */
|
||||
return(subseq('=',34,61));
|
||||
|
||||
case 43: /* / */
|
||||
if (subseq('*',1,0))
|
||||
return(43);
|
||||
com:
|
||||
c = getchar();
|
||||
com1:
|
||||
if (c=='\0') {
|
||||
eof++;
|
||||
error("Nonterminated comment");
|
||||
return(0);
|
||||
}
|
||||
if (c=='\n')
|
||||
line++;
|
||||
if (c!='*')
|
||||
goto com;
|
||||
c = getchar();
|
||||
if (c!='/')
|
||||
goto com1;
|
||||
c = getchar();
|
||||
goto loop;
|
||||
|
||||
case 124: /* number */
|
||||
cval = 0;
|
||||
if (c=='0')
|
||||
b = 8; else
|
||||
b = 10;
|
||||
while(ctab[c]==124) {
|
||||
cval = cval*b + c -'0';
|
||||
c = getchar();
|
||||
}
|
||||
peekc = c;
|
||||
return(21);
|
||||
|
||||
case 122: /* " */
|
||||
return(getstr());
|
||||
|
||||
case 121: /* ' */
|
||||
return(getcc());
|
||||
|
||||
case 123: /* letter */
|
||||
sp = symbuf;
|
||||
while(ctab[c]==123 | ctab[c]==124) {
|
||||
if (sp<symbuf+namsiz) *sp++ = c;
|
||||
c = getchar();
|
||||
}
|
||||
while(sp<symbuf+namsiz)
|
||||
*sp++ = '\0';
|
||||
peekc = c;
|
||||
csym = lookup();
|
||||
if (csym[0]==1) { /* keyword */
|
||||
cval = csym[1];
|
||||
return(19);
|
||||
}
|
||||
return(20);
|
||||
|
||||
case 127: /* unknown */
|
||||
error("Unknown character");
|
||||
c = getchar();
|
||||
goto loop;
|
||||
|
||||
}
|
||||
return(ctab[c]);
|
||||
}
|
||||
|
||||
subseq(c,a,b) {
|
||||
extern getchar, peekc;
|
||||
|
||||
if (!peekc)
|
||||
peekc = getchar();
|
||||
if (peekc != c)
|
||||
return(a);
|
||||
peekc = 0;
|
||||
return(b);
|
||||
}
|
||||
getstr() {
|
||||
extern isn, cval;
|
||||
auto c;
|
||||
|
||||
printf(".data;L%d:.byte ", cval=isn++);
|
||||
while((c=mapch('"')) >= 0)
|
||||
printf("%o,", c);
|
||||
printf("0;.even;.text\n");
|
||||
return(22);
|
||||
}
|
||||
|
||||
getcc()
|
||||
{
|
||||
extern cval, ncpw;
|
||||
auto c, cc;
|
||||
char cp[];
|
||||
|
||||
cval = 0;
|
||||
cp = &cval;
|
||||
cc = 0;
|
||||
while((c=mapch('\'')) >= 0)
|
||||
if(cc++ < ncpw)
|
||||
*cp++ = c;
|
||||
if(cc>ncpw)
|
||||
error("Long character constant");
|
||||
return(21);
|
||||
}
|
||||
|
||||
mapch(c)
|
||||
{
|
||||
extern peekc, line;
|
||||
auto a;
|
||||
|
||||
if((a=getchar())==c)
|
||||
return(-1);
|
||||
switch(a) {
|
||||
|
||||
case '\n':
|
||||
case 0:
|
||||
error("Nonterminated string");
|
||||
peekc = a;
|
||||
return(-1);
|
||||
|
||||
case '\\':
|
||||
switch (a=getchar()) {
|
||||
|
||||
case 't':
|
||||
return('\t');
|
||||
|
||||
case 'n':
|
||||
return('\n');
|
||||
|
||||
case '0':
|
||||
return('\0');
|
||||
|
||||
case 'r':
|
||||
return('\r');
|
||||
|
||||
case '\n':
|
||||
line++;
|
||||
return('\n');
|
||||
}
|
||||
|
||||
}
|
||||
return(a);
|
||||
}
|
||||
|
||||
tree() {
|
||||
extern symbol, block, csym[], ctyp, isn,
|
||||
peeksym, opdope[], build, error, cp[], cmst[],
|
||||
space, ospace, cval, ossiz, exit, errflush, cmsiz;
|
||||
|
||||
auto op[], opst[20], pp[], prst[20], andflg, o,
|
||||
p, ps, os;
|
||||
|
||||
space = ospace;
|
||||
op = opst;
|
||||
pp = prst;
|
||||
cp = cmst;
|
||||
*op = 200; /* stack EOF */
|
||||
*pp = 06;
|
||||
andflg = 0;
|
||||
|
||||
advanc:
|
||||
switch (o=symbol()) {
|
||||
|
||||
/* name */
|
||||
case 20:
|
||||
if (*csym==0)
|
||||
if((peeksym=symbol())==6)
|
||||
*csym = 6; /* extern */
|
||||
else {
|
||||
if(csym[2]==0) /* unseen so far */
|
||||
csym[2] = isn++;
|
||||
}
|
||||
if(*csym==6) /* extern */
|
||||
*cp++ = block(5,20,csym[1],0,*csym,
|
||||
csym[4],csym[5],csym[6],csym[7]);
|
||||
else
|
||||
*cp++ = block(2,20,csym[1],0,*csym,csym[2]);
|
||||
goto tand;
|
||||
|
||||
/* short constant */
|
||||
case 21:
|
||||
case21:
|
||||
*cp++ = block(1,21,ctyp,0,cval);
|
||||
goto tand;
|
||||
|
||||
/* string constant */
|
||||
case 22:
|
||||
*cp++ = block(1,22,17,0,cval);
|
||||
|
||||
tand:
|
||||
if(cp>=cmst+cmsiz) {
|
||||
error("Expression overflow");
|
||||
exit(1);
|
||||
}
|
||||
if (andflg)
|
||||
goto syntax;
|
||||
andflg = 1;
|
||||
goto advanc;
|
||||
|
||||
/* ++, -- */
|
||||
case 30:
|
||||
case 31:
|
||||
if (andflg)
|
||||
o =+ 2;
|
||||
goto oponst;
|
||||
|
||||
/* ! */
|
||||
case 34:
|
||||
if (andflg)
|
||||
goto syntax;
|
||||
goto oponst;
|
||||
|
||||
/* - */
|
||||
case 41:
|
||||
if (!andflg) {
|
||||
peeksym = symbol();
|
||||
if (peeksym==21) {
|
||||
peeksym = -1;
|
||||
cval = -cval;
|
||||
goto case21;
|
||||
}
|
||||
o = 37;
|
||||
}
|
||||
andflg = 0;
|
||||
goto oponst;
|
||||
|
||||
/* & */
|
||||
/* * */
|
||||
case 47:
|
||||
case 42:
|
||||
if (andflg)
|
||||
andflg = 0; else
|
||||
if(o==47)
|
||||
o = 35;
|
||||
else
|
||||
o = 36;
|
||||
goto oponst;
|
||||
|
||||
/* ( */
|
||||
case 6:
|
||||
if (andflg) {
|
||||
o = symbol();
|
||||
if (o==7)
|
||||
o = 101; else {
|
||||
peeksym = o;
|
||||
o = 100;
|
||||
andflg = 0;
|
||||
}
|
||||
}
|
||||
goto oponst;
|
||||
|
||||
/* ) */
|
||||
/* ] */
|
||||
case 5:
|
||||
case 7:
|
||||
if (!andflg)
|
||||
goto syntax;
|
||||
goto oponst;
|
||||
}
|
||||
|
||||
/* binaries */
|
||||
if (!andflg)
|
||||
goto syntax;
|
||||
andflg = 0;
|
||||
|
||||
oponst:
|
||||
p = (opdope[o]>>9) & 077;
|
||||
opon1:
|
||||
ps = *pp;
|
||||
if (p>ps | p==ps & (opdope[o]&0200)!=0) { /* right-assoc */
|
||||
putin:
|
||||
switch (o) {
|
||||
|
||||
case 6: /* ( */
|
||||
case 4: /* [ */
|
||||
case 100: /* call */
|
||||
p = 04;
|
||||
}
|
||||
if(op>=opst+20) { /* opstack size */
|
||||
error("expression overflow");
|
||||
exit(1);
|
||||
}
|
||||
*++op = o;
|
||||
*++pp = p;
|
||||
goto advanc;
|
||||
}
|
||||
--pp;
|
||||
switch (os = *op--) {
|
||||
|
||||
/* EOF */
|
||||
case 200:
|
||||
peeksym = o;
|
||||
return(*--cp);
|
||||
|
||||
/* call */
|
||||
case 100:
|
||||
if (o!=7)
|
||||
goto syntax;
|
||||
build(os);
|
||||
goto advanc;
|
||||
|
||||
/* mcall */
|
||||
case 101:
|
||||
*cp++ = 0; /* 0 arg call */
|
||||
os = 100;
|
||||
goto fbuild;
|
||||
|
||||
/* ( */
|
||||
case 6:
|
||||
if (o!=7)
|
||||
goto syntax;
|
||||
goto advanc;
|
||||
|
||||
/* [ */
|
||||
case 4:
|
||||
if (o!=5)
|
||||
goto syntax;
|
||||
build(4);
|
||||
goto advanc;
|
||||
}
|
||||
fbuild:
|
||||
build(os);
|
||||
goto opon1;
|
||||
|
||||
syntax:
|
||||
error("Expression syntax");
|
||||
errflush(o);
|
||||
return(0);
|
||||
}
|
||||
|
||||
declare(kw) {
|
||||
extern csym[], symbol, paraml[], parame[];
|
||||
extern error, cval, errflush, peeksym, exit;
|
||||
int t[], n, o;
|
||||
|
||||
while((o=symbol())==20) { /* name */
|
||||
if(kw>=5) { /* type or sort? */
|
||||
if(*csym>0)
|
||||
error("%p redeclared", csym[4]);
|
||||
*csym = kw;
|
||||
} else {
|
||||
if ((csym[1]&017)!=0)
|
||||
error("%p redeclared", &csym[4]);
|
||||
csym[1] =| csym[1]&0760 | kw;
|
||||
if (*csym==0)
|
||||
*csym = -2;
|
||||
}
|
||||
while((o=symbol())==4) { /* [ */
|
||||
if((o=symbol())==21) { /* const */
|
||||
if(csym[1]>=020)
|
||||
error("Bad vector");
|
||||
csym[3] = cval;
|
||||
o = symbol();
|
||||
}
|
||||
if (o!=5) /* ] */
|
||||
goto syntax;
|
||||
csym[1] =+ 020;
|
||||
}
|
||||
if(kw==8) { /* parameter */
|
||||
*csym = -1;
|
||||
if (paraml==0)
|
||||
paraml = csym;
|
||||
else
|
||||
*parame = csym;
|
||||
parame = csym;
|
||||
}
|
||||
if (o!=9) /* , */
|
||||
break;
|
||||
}
|
||||
if(o==1 & kw!=8 | o==7 & kw==8)
|
||||
return;
|
||||
syntax:
|
||||
error("Declaration syntax");
|
||||
errflush(o);
|
||||
}
|
||||
|
||||
/* storage */
|
||||
|
||||
regtab 0;
|
||||
efftab 1;
|
||||
cctab 2;
|
||||
sptab 3;
|
||||
symbuf[4];
|
||||
pssiz 8;
|
||||
namsiz 8;
|
||||
nwps 4;
|
||||
hshused 0;
|
||||
hshsiz 100;
|
||||
hshlen 800; /* 8*hshsiz */
|
||||
hshtab[800];
|
||||
space 0;
|
||||
cp 0;
|
||||
cmsiz 40;
|
||||
cmst[40];
|
||||
ctyp 0;
|
||||
isn 1;
|
||||
swsiz 120;
|
||||
swtab[120];
|
||||
swp 0;
|
||||
contlab 0;
|
||||
brklab 0;
|
||||
deflab 0;
|
||||
nreg 4;
|
||||
maprel[] 60,61,64,65,62,63,68,69,66,67;
|
||||
nauto 0;
|
||||
stack 0;
|
||||
peeksym 0177777;
|
||||
peekc 0;
|
||||
eof 0;
|
||||
line 1;
|
||||
csym 0;
|
||||
cval 0;
|
||||
ncpw 2;
|
||||
nerror 0;
|
||||
paraml;
|
||||
parame;
|
||||
tmpfil;
|
||||
|
210
last1120c/c01.c
Normal file
210
last1120c/c01.c
Normal file
@ -0,0 +1,210 @@
|
||||
build(op) {
|
||||
extern cp[], error, block, opdope[], maprel[], chklval;
|
||||
extern chkw, cvtab, lintyp, dcalc;
|
||||
auto p1[], t1, d1, p2[], t2, d2, p3[], t3, d3, t;
|
||||
auto d, dope, lr, cvn;
|
||||
char cvtab[];
|
||||
|
||||
if (op==4) { /* [] */
|
||||
build(40); /* + */
|
||||
op = 36;
|
||||
}
|
||||
dope = opdope[op];
|
||||
if ((dope&01)!=0) {
|
||||
p2 = *--cp;
|
||||
t2 = p2[1];
|
||||
d2 = p2[2];
|
||||
}
|
||||
p1 = *--cp;
|
||||
t1 = p1[1];
|
||||
d1 = p1[2];
|
||||
switch (op) {
|
||||
|
||||
/* , */
|
||||
case 9:
|
||||
*cp++ = block(2, 9, 0, 0, p1, p2);
|
||||
return;
|
||||
|
||||
/* ? */
|
||||
case 90:
|
||||
if (*p2!=8)
|
||||
error("Illegal conditional");
|
||||
goto goon;
|
||||
|
||||
/* call */
|
||||
case 100:
|
||||
*cp++ = block(2,100,t1,24,p1,p2);
|
||||
return;
|
||||
|
||||
/* * */
|
||||
case 36:
|
||||
if ((t1 =- 16)<0) {
|
||||
error("Illegal indirection");
|
||||
t1 =+ 16;
|
||||
}
|
||||
if (*p1!=20 & d1==0)
|
||||
d1 = 1;
|
||||
*cp++ = block(1,36,t1,d1,p1);
|
||||
return;
|
||||
|
||||
/* & unary */
|
||||
case 35:
|
||||
if (*p1 == 36) { /* * */
|
||||
*cp++ = p1[3];
|
||||
return;
|
||||
}
|
||||
if (*p1 == 20) {
|
||||
*cp++ = block(1,p1[3]==5?29:35,t1+16,1,p1);
|
||||
return;
|
||||
}
|
||||
error("Illegal lvalue");
|
||||
}
|
||||
goon:
|
||||
if ((dope&02)!=0) /* lvalue needed on left? */
|
||||
chklval(p1);
|
||||
if ((dope&020)!=0) /* word operand on left? */
|
||||
chkw(p1);
|
||||
if ((dope&040)!=0) /* word operand on right? */
|
||||
chkw(p2);
|
||||
if ((dope&01)!=0) { /* binary op? */
|
||||
cvn = cvtab[9*lintyp(t1)+lintyp(t2)];
|
||||
if ((dope&010)!=0) { /* assignment? */
|
||||
t = t1;
|
||||
lr = 1;
|
||||
cvn =& 07;
|
||||
} else {
|
||||
t = (cvn&0100)!=0? t2:t1;
|
||||
lr = cvn&0200;
|
||||
cvn = (cvn>>3)&07;
|
||||
}
|
||||
if (cvn) {
|
||||
if (cvn==07) {
|
||||
error("Illegal conversion");
|
||||
goto nocv;
|
||||
}
|
||||
cvn =+ (dope&010)!=0? 83:93;
|
||||
if (lr) {
|
||||
t2 = t;
|
||||
d2 = (p2=convert(p2, t, d2, cvn))[2];
|
||||
} else {
|
||||
t1 = t;
|
||||
d1 = (p1=convert(p1, t, d1, cvn))[2];
|
||||
}
|
||||
nocv:; }
|
||||
if (d2>d1 & (dope&0100)!=0) { /* flip commutative? */
|
||||
if ((dope&04)!=0) /* relational? */
|
||||
op = maprel[op-60];
|
||||
d = d1;
|
||||
d1 = d2;
|
||||
d2 = d;
|
||||
d = p1;
|
||||
p1 = p2;
|
||||
p2 = d;
|
||||
d = t1;
|
||||
t1 = t2;
|
||||
t2 = d;
|
||||
}
|
||||
if (d1==d2)
|
||||
d = d1+1; else
|
||||
d = max(d1,d2);
|
||||
if ((dope&04)!=0)
|
||||
t = 0; /* relational is integer */
|
||||
*cp++ = block(2,op,t,d,p1,p2);
|
||||
return;
|
||||
}
|
||||
*cp++ = block(1,op,t1,d1==0?1:d1,p1);
|
||||
}
|
||||
|
||||
convert(p, t, d, cvn)
|
||||
int p[];
|
||||
{
|
||||
auto c;
|
||||
if (*p==21) { /* constant */
|
||||
c = p[3];
|
||||
switch(cvn) {
|
||||
|
||||
case 99: /* c18 */
|
||||
c =<< 1;
|
||||
|
||||
case 98: /* c14 */
|
||||
c =<< 1;
|
||||
|
||||
case 97: /* c12 */
|
||||
c =<< 1;
|
||||
|
||||
p[3] = c;
|
||||
return(p);
|
||||
}
|
||||
}
|
||||
return(block(1, cvn, t, max(1,d), p));
|
||||
}
|
||||
|
||||
chkw(p)
|
||||
int p[]; {
|
||||
extern error;
|
||||
auto t;
|
||||
|
||||
if ((t=p[1])>1 & t<16)
|
||||
error("Integer operand required");
|
||||
return;
|
||||
}
|
||||
|
||||
lintyp(t) {
|
||||
return(t<16? t:(t<32? t-12: 8));
|
||||
}
|
||||
|
||||
error(s, p1, p2) {
|
||||
extern printf, line, fout, flush, putchar, nerror;
|
||||
int f;
|
||||
|
||||
nerror++;
|
||||
flush();
|
||||
f = fout;
|
||||
fout = 1;
|
||||
printf("%d: ", line);
|
||||
printf(s, p1, p2);
|
||||
putchar('\n');
|
||||
fout = f;
|
||||
}
|
||||
|
||||
block(n, op, t, d, p1,p2,p3)
|
||||
int p1[],p2[],p3[]; {
|
||||
extern space[], error, exit, ossiz, ospace[];
|
||||
auto p[], ap[];
|
||||
|
||||
p = space;
|
||||
ap = &op;
|
||||
n =+ 3;
|
||||
if(space+n >= ospace+ossiz) {
|
||||
error("Expression overflow");
|
||||
exit(1);
|
||||
}
|
||||
while(n--)
|
||||
*space++ = *ap++;
|
||||
return(p);
|
||||
}
|
||||
|
||||
chklval(p)
|
||||
int p[]; {
|
||||
extern error;
|
||||
if (*p!=20)
|
||||
if (*p!=36)
|
||||
error("Lvalue required");
|
||||
}
|
||||
|
||||
notcompat(at, st) {
|
||||
|
||||
if (st==0) /* word, byte */
|
||||
return(at>1 & at<16);
|
||||
if (st==1) /* word */
|
||||
return(at>0 & at<16);
|
||||
return((st-2) != at);
|
||||
}
|
||||
|
||||
max(a, b)
|
||||
{
|
||||
if (a>b)
|
||||
return(a);
|
||||
return(b);
|
||||
}
|
||||
|
436
last1120c/c02.c
Normal file
436
last1120c/c02.c
Normal file
@ -0,0 +1,436 @@
|
||||
function() {
|
||||
extern declare, blkhed, blkend;
|
||||
extern printf, statement, peeksym, cval, symbol, retseq;
|
||||
extern paraml;
|
||||
auto o;
|
||||
|
||||
printf(".text; 1:mov r5,-(sp); mov sp,r5\n");
|
||||
declare(8);
|
||||
declist();
|
||||
statement(1);
|
||||
retseq();
|
||||
}
|
||||
|
||||
extdef() {
|
||||
extern eof, function, cval;
|
||||
extern symbol, block, printf, pname, errflush, csym[];
|
||||
extern error;
|
||||
auto o, c, cs[];
|
||||
char s[];
|
||||
|
||||
if(((o=symbol())==0) | o==1) /* EOF */
|
||||
return;
|
||||
if(o!=20)
|
||||
goto syntax;
|
||||
csym[0] = 6;
|
||||
cs = &csym[4];
|
||||
printf(".globl %p\n", cs);
|
||||
s = ".data; %p:1f\n";
|
||||
switch(o=symbol()) {
|
||||
|
||||
case 6: /* ( */
|
||||
printf(s, cs);
|
||||
function();
|
||||
return;
|
||||
|
||||
case 21: /* const */
|
||||
printf(".data; %p: %o\n", cs, cval);
|
||||
if((o=symbol())!=1) /* ; */
|
||||
goto syntax;
|
||||
return;
|
||||
|
||||
case 1: /* ; */
|
||||
printf(".bss; %p: .=.+2\n", cs);
|
||||
return;
|
||||
|
||||
case 4: /* [ */
|
||||
c = 0;
|
||||
if((o=symbol())==21) { /* const */
|
||||
c = cval<<1;
|
||||
o = symbol();
|
||||
}
|
||||
if(o!=5) /* ] */
|
||||
goto syntax;
|
||||
printf(s, cs);
|
||||
if((o=symbol())==1) { /* ; */
|
||||
printf(".bss; 1:.=.+%o\n", c);
|
||||
return;
|
||||
}
|
||||
printf("1:");
|
||||
while(o==21) { /* const */
|
||||
printf("%o\n", cval);
|
||||
c =- 2;
|
||||
if((o=symbol())==1) /* ; */
|
||||
goto done;
|
||||
if(o!=9) /* , */
|
||||
goto syntax;
|
||||
else
|
||||
o = symbol();
|
||||
}
|
||||
goto syntax;
|
||||
done:
|
||||
if(c>0)
|
||||
printf(".=.+%o\n", c);
|
||||
return;
|
||||
|
||||
case 0: /* EOF */
|
||||
return;
|
||||
}
|
||||
|
||||
syntax:
|
||||
error("External definition syntax");
|
||||
errflush(o);
|
||||
statement(0);
|
||||
}
|
||||
|
||||
statement(d) {
|
||||
extern symbol, error, blkhed, eof, peeksym;
|
||||
extern blkend, csym[], rcexpr, block[], tree[], regtab[];
|
||||
extern retseq, jumpc, jump, label, contlab, brklab, cval;
|
||||
extern swp[], isn, pswitch, peekc, slabel;
|
||||
extern efftab[], declare, deflab, errflush, swtab[], swsiz, branch;
|
||||
|
||||
int o, o1, o2, o3, np[];
|
||||
|
||||
stmt:
|
||||
switch(o=symbol()) {
|
||||
|
||||
/* EOF */
|
||||
case 0:
|
||||
error("Unexpected EOF");
|
||||
/* ; */
|
||||
case 1:
|
||||
/* } */
|
||||
case 3:
|
||||
return;
|
||||
|
||||
/* { */
|
||||
case 2: {
|
||||
if(d)
|
||||
blkhed();
|
||||
while (!eof) {
|
||||
if ((o=symbol())==3) /* } */
|
||||
goto bend;
|
||||
peeksym = o;
|
||||
statement(0);
|
||||
}
|
||||
error("Missing '}'");
|
||||
bend:
|
||||
return;
|
||||
}
|
||||
|
||||
/* keyword */
|
||||
case 19:
|
||||
switch(cval) {
|
||||
|
||||
/* goto */
|
||||
case 10:
|
||||
o1 = block(1,102,0,0,tree());
|
||||
rcexpr(o1, regtab);
|
||||
goto semi;
|
||||
|
||||
/* return */
|
||||
case 11:
|
||||
if((peeksym=symbol())==6) /* ( */
|
||||
rcexpr(pexpr(), regtab);
|
||||
retseq();
|
||||
goto semi;
|
||||
|
||||
/* if */
|
||||
case 12:
|
||||
jumpc(pexpr(), o1=isn++, 0);
|
||||
statement(0);
|
||||
if ((o=symbol())==19 & cval==14) { /* else */
|
||||
o2 = isn++;
|
||||
(easystmt()?branch:jump)(o2);
|
||||
label(o1);
|
||||
statement(0);
|
||||
label(o2);
|
||||
return;
|
||||
}
|
||||
peeksym = o;
|
||||
label(o1);
|
||||
return;
|
||||
|
||||
/* while */
|
||||
case 13:
|
||||
o1 = contlab;
|
||||
o2 = brklab;
|
||||
label(contlab = isn++);
|
||||
jumpc(pexpr(), brklab=isn++, 0);
|
||||
o3 = easystmt();
|
||||
statement(0);
|
||||
(o3?branch:jump)(contlab);
|
||||
label(brklab);
|
||||
contlab = o1;
|
||||
brklab = o2;
|
||||
return;
|
||||
|
||||
/* break */
|
||||
case 17:
|
||||
if(brklab==0)
|
||||
error("Nothing to break from");
|
||||
jump(brklab);
|
||||
goto semi;
|
||||
|
||||
/* continue */
|
||||
case 18:
|
||||
if(contlab==0)
|
||||
error("Nothing to continue");
|
||||
jump(contlab);
|
||||
goto semi;
|
||||
|
||||
/* do */
|
||||
case 19:
|
||||
o1 = contlab;
|
||||
o2 = brklab;
|
||||
contlab = isn++;
|
||||
brklab = isn++;
|
||||
label(o3 = isn++);
|
||||
statement(0);
|
||||
label(contlab);
|
||||
contlab = o1;
|
||||
if ((o=symbol())==19 & cval==13) { /* while */
|
||||
jumpc(tree(), o3, 1);
|
||||
label(brklab);
|
||||
brklab = o2;
|
||||
goto semi;
|
||||
}
|
||||
goto syntax;
|
||||
|
||||
/* case */
|
||||
case 16:
|
||||
if ((o=symbol())!=21) /* constant */
|
||||
goto syntax;
|
||||
if ((o=symbol())!=8) /* : */
|
||||
goto syntax;
|
||||
if (swp==0) {
|
||||
error("Case not in switch");
|
||||
goto stmt;
|
||||
}
|
||||
if(swp>=swtab+swsiz) {
|
||||
error("Switch table overflow");
|
||||
} else {
|
||||
*swp++ = isn;
|
||||
*swp++ = cval;
|
||||
label(isn++);
|
||||
}
|
||||
goto stmt;
|
||||
|
||||
/* switch */
|
||||
case 15:
|
||||
o1 = brklab;
|
||||
brklab = isn++;
|
||||
np = pexpr();
|
||||
if (np[1]>1 & np[1]<16)
|
||||
error("Integer required");
|
||||
rcexpr(np, regtab);
|
||||
pswitch();
|
||||
brklab = o1;
|
||||
return;
|
||||
|
||||
/* default */
|
||||
case 20:
|
||||
if (swp==0)
|
||||
error("Default not in switch");
|
||||
if ((o=symbol())!=8) /* : */
|
||||
goto syntax;
|
||||
deflab = isn++;
|
||||
label(deflab);
|
||||
goto stmt;
|
||||
}
|
||||
|
||||
error("Unknown keyword");
|
||||
goto syntax;
|
||||
|
||||
/* name */
|
||||
case 20:
|
||||
if (peekc==':') {
|
||||
peekc = 0;
|
||||
if (csym[0]>0) {
|
||||
error("Redefinition");
|
||||
goto stmt;
|
||||
}
|
||||
csym[0] = 2;
|
||||
csym[1] = 020; /* int[] */
|
||||
if (csym[2]==0)
|
||||
csym[2] = isn++;
|
||||
slabel();
|
||||
goto stmt;
|
||||
}
|
||||
}
|
||||
|
||||
peeksym = o;
|
||||
rcexpr(tree(), efftab);
|
||||
goto semi;
|
||||
|
||||
semi:
|
||||
if ((o=symbol())!=1) /* ; */
|
||||
goto syntax;
|
||||
return;
|
||||
|
||||
syntax:
|
||||
error("Statement syntax");
|
||||
errflush(o);
|
||||
goto stmt;
|
||||
}
|
||||
|
||||
pexpr()
|
||||
{
|
||||
auto o, t;
|
||||
|
||||
if ((o=symbol())!=6) /* ( */
|
||||
goto syntax;
|
||||
t = tree();
|
||||
if ((o=symbol())!=7) /* ) */
|
||||
goto syntax;
|
||||
return(t);
|
||||
syntax:
|
||||
error("Statement syntax");
|
||||
errflush(o);
|
||||
return(0);
|
||||
}
|
||||
|
||||
pswitch() {
|
||||
extern swp[], isn, swtab[], printf, deflab, statement, brklab;
|
||||
extern label;
|
||||
int sswp[], dl, cv, swlab;
|
||||
|
||||
sswp = swp;
|
||||
if (swp==0)
|
||||
swp = swtab;
|
||||
swlab = isn++;
|
||||
printf("jsr pc,bswitch; l%d\n", swlab);
|
||||
dl = deflab;
|
||||
deflab = 0;
|
||||
statement(0);
|
||||
if (!deflab) {
|
||||
deflab = isn++;
|
||||
label(deflab);
|
||||
}
|
||||
printf("L%d:.data;L%d:", brklab, swlab);
|
||||
while(swp>sswp & swp>swtab) {
|
||||
cv = *--swp;
|
||||
printf("%o; l%d\n", cv, *--swp);
|
||||
}
|
||||
printf("L%d; 0\n.text\n", deflab);
|
||||
deflab = dl;
|
||||
swp = sswp;
|
||||
}
|
||||
|
||||
blkhed()
|
||||
{
|
||||
extern symbol, cval, declare, peeksym, paraml[], parame[];
|
||||
extern error, length, rlength, setstk, defvec, isn, defstat;
|
||||
extern stack, hshtab[], hshsiz, pssiz;
|
||||
int o, al, pl, cs[], hl;
|
||||
|
||||
declist();
|
||||
stack = al = -2;
|
||||
pl = 4;
|
||||
while(paraml) {
|
||||
*parame = 0;
|
||||
paraml = *(cs = paraml);
|
||||
cs[2] = pl;
|
||||
*cs = 10;
|
||||
pl =+ rlength(cs[1]);
|
||||
}
|
||||
cs = hshtab;
|
||||
hl = hshsiz;
|
||||
while(hl--) {
|
||||
if (cs[4])
|
||||
switch(cs[0]) {
|
||||
|
||||
/* sort unmentioned */
|
||||
case 0177776: /* -2 */
|
||||
cs[0] = 5; /* auto */
|
||||
|
||||
/* auto */
|
||||
case 5:
|
||||
if (cs[3]) { /* vector */
|
||||
al =- (cs[3]*length(cs[1]-020)+1) & 077776;
|
||||
setstk(al);
|
||||
defvec(al);
|
||||
}
|
||||
cs[2] = al;
|
||||
al =- rlength(cs[1]);
|
||||
goto loop;
|
||||
|
||||
/* parameter */
|
||||
case 10:
|
||||
cs[0] = 5;
|
||||
goto loop;
|
||||
|
||||
/* static */
|
||||
case 7:
|
||||
cs[2] = isn++;
|
||||
defstat(cs);
|
||||
goto loop;
|
||||
|
||||
loop:;
|
||||
}
|
||||
cs = cs+pssiz;
|
||||
}
|
||||
setstk(al);
|
||||
}
|
||||
|
||||
blkend() {
|
||||
extern hshtab[], hshsiz, pssiz, hshused;
|
||||
auto i, hl;
|
||||
|
||||
i = 0;
|
||||
hl = hshsiz;
|
||||
while(hl--) {
|
||||
if(hshtab[i+4])
|
||||
if (hshtab[i]==0)
|
||||
error("%p undefined", &hshtab[i+4]);
|
||||
if(hshtab[i]!=1) { /* not keyword */
|
||||
hshused--;
|
||||
hshtab[i+4] = 0;
|
||||
}
|
||||
i =+ pssiz;
|
||||
}
|
||||
}
|
||||
|
||||
errflush(o) {
|
||||
extern symbol, peeksym, eof;
|
||||
|
||||
while(o>3) /* ; { } */
|
||||
o = symbol();
|
||||
peeksym = o;
|
||||
}
|
||||
|
||||
declist()
|
||||
{
|
||||
extern peeksym, peekc, csym[], cval;
|
||||
auto o;
|
||||
|
||||
while((o=symbol())==19 & cval<10)
|
||||
declare(cval);
|
||||
peeksym = o;
|
||||
}
|
||||
|
||||
easystmt()
|
||||
{
|
||||
extern peeksym, peekc, cval;
|
||||
|
||||
if((peeksym=symbol())==20) /* name */
|
||||
return(peekc!=':'); /* not label */
|
||||
if (peeksym==19) { /* keyword */
|
||||
switch(cval)
|
||||
|
||||
case 10: /* goto */
|
||||
case 11: /* return */
|
||||
case 17: /* break */
|
||||
case 18: /* continue */
|
||||
return(1);
|
||||
return(0);
|
||||
}
|
||||
return(peeksym!=2); /* { */
|
||||
}
|
||||
|
||||
branch(lab)
|
||||
{
|
||||
printf("br L%d\n", lab);
|
||||
}
|
||||
|
189
last1120c/c03.c
Normal file
189
last1120c/c03.c
Normal file
@ -0,0 +1,189 @@
|
||||
jumpc(tree, lbl, cond)
|
||||
int tree[];
|
||||
{
|
||||
extern cctab, block, rcexpr;
|
||||
|
||||
rcexpr(block(1,easystmt()+103,tree,lbl,cond),cctab);
|
||||
}
|
||||
|
||||
rcexpr(tree, table)
|
||||
int tree[], table;
|
||||
{
|
||||
extern space, ospace, putwrd, putchar, line;
|
||||
int c, sp[];
|
||||
|
||||
putchar('#');
|
||||
c = space-ospace;
|
||||
c =/ 2; /* # addresses per word */
|
||||
sp = ospace;
|
||||
|
||||
putwrd(c);
|
||||
putwrd(tree);
|
||||
putwrd(table);
|
||||
putwrd(line);
|
||||
while(c--)
|
||||
putwrd(*sp++);
|
||||
}
|
||||
|
||||
jump(lab) {
|
||||
extern printf;
|
||||
|
||||
printf("jmp\tl%d\n", lab);
|
||||
}
|
||||
|
||||
label(l) {
|
||||
extern printf;
|
||||
|
||||
printf("l%d:", l);
|
||||
}
|
||||
|
||||
retseq() {
|
||||
extern printf;
|
||||
|
||||
printf("jmp\tretrn\n");
|
||||
}
|
||||
|
||||
slabel() {
|
||||
extern csym[], printf;
|
||||
|
||||
printf(".data; l%d: 1f; .text; 1:\n", csym[2]);
|
||||
}
|
||||
|
||||
setstk(a) {
|
||||
extern printf, stack;
|
||||
auto ts;
|
||||
|
||||
ts = a-stack;
|
||||
stack = a;
|
||||
switch(ts) {
|
||||
|
||||
case 0:
|
||||
return;
|
||||
|
||||
case 0177776: /* -2 */
|
||||
printf("tst -(sp)\n");
|
||||
return;
|
||||
|
||||
case 0177774: /* -4 */
|
||||
printf("cmp -(sp),-(sp)\n");
|
||||
return;
|
||||
}
|
||||
printf("add $%o,sp\n", ts);
|
||||
}
|
||||
|
||||
defvec() {
|
||||
extern printf, stack;
|
||||
|
||||
printf("mov\tsp,r0\nmov\tr0,-(sp)\n");
|
||||
stack =- 2;
|
||||
}
|
||||
|
||||
defstat(s)
|
||||
int s[]; {
|
||||
extern printf, length;
|
||||
int len;
|
||||
|
||||
len = length(s[1]);
|
||||
if (s[3])
|
||||
printf(".data; l%d:1f; .bss; 1:.=.+%o; .even; .text\n", s[2],
|
||||
s[3]*len);
|
||||
else
|
||||
printf(".bss; l%d:.=.+%o; .even; .text\n", s[2], len);
|
||||
}
|
||||
|
||||
length(t) {
|
||||
|
||||
if (t<0)
|
||||
t =+ 020;
|
||||
if (t>=020)
|
||||
return(2);
|
||||
switch(t) {
|
||||
|
||||
case 0:
|
||||
return(2);
|
||||
|
||||
case 1:
|
||||
return(1);
|
||||
|
||||
case 2:
|
||||
return(4);
|
||||
|
||||
case 3:
|
||||
return(8);
|
||||
|
||||
case 4:
|
||||
return(4);
|
||||
|
||||
}
|
||||
return(1024);
|
||||
}
|
||||
|
||||
rlength(c) {
|
||||
extern length;
|
||||
auto l;
|
||||
|
||||
return((l=length(c))==1? 2: l);
|
||||
}
|
||||
|
||||
printn(n,b) {
|
||||
extern putchar;
|
||||
auto a;
|
||||
|
||||
if(a=n/b) /* assignment, not test for equality */
|
||||
printn(a, b); /* recursive */
|
||||
putchar(n%b + '0');
|
||||
}
|
||||
|
||||
printf(fmt,x1,x2,x3,x4,x5,x6,x7,x8,x9)
|
||||
char fmt[]; {
|
||||
extern printn, putchar, namsiz, ncpw;
|
||||
char s[];
|
||||
auto adx[], x, c, i[];
|
||||
|
||||
adx = &x1; /* argument pointer */
|
||||
loop:
|
||||
while((c = *fmt++) != '%') {
|
||||
if(c == '\0')
|
||||
return;
|
||||
putchar(c);
|
||||
}
|
||||
x = *adx++;
|
||||
switch (c = *fmt++) {
|
||||
|
||||
case 'd': /* decimal */
|
||||
case 'o': /* octal */
|
||||
if(x < 0) {
|
||||
x = -x;
|
||||
if(x<0) { /* - infinity */
|
||||
if(c=='o')
|
||||
printf("100000");
|
||||
else
|
||||
printf("-32767");
|
||||
goto loop;
|
||||
}
|
||||
putchar('-');
|
||||
}
|
||||
printn(x, c=='o'?8:10);
|
||||
goto loop;
|
||||
|
||||
case 's': /* string */
|
||||
s = x;
|
||||
while(c = *s++)
|
||||
putchar(c);
|
||||
goto loop;
|
||||
|
||||
case 'p':
|
||||
s = x;
|
||||
putchar('_');
|
||||
c = namsiz;
|
||||
while(c--)
|
||||
if(*s)
|
||||
putchar(*s++);
|
||||
goto loop;
|
||||
}
|
||||
putchar('%');
|
||||
fmt--;
|
||||
adx--;
|
||||
goto loop;
|
||||
}
|
||||
|
264
last1120c/c0t.s
Normal file
264
last1120c/c0t.s
Normal file
@ -0,0 +1,264 @@
|
||||
/ word I/O
|
||||
|
||||
.globl _putwrd
|
||||
|
||||
.globl _tmpfil
|
||||
.globl putw
|
||||
.globl fcreat
|
||||
.globl flush
|
||||
|
||||
.data
|
||||
_putwrd: 1f
|
||||
.text
|
||||
1:
|
||||
tst buf
|
||||
bne 1f
|
||||
mov _tmpfil,r0
|
||||
jsr r5,fcreat; buf
|
||||
bec 1f
|
||||
mov $1,r0
|
||||
sys write; botch; ebotch-botch
|
||||
sys exit
|
||||
1:
|
||||
mov 2(sp),r0
|
||||
jsr r5,putw; buf
|
||||
rts pc
|
||||
.globl _flshw
|
||||
.data
|
||||
_flshw: 1f
|
||||
.text
|
||||
1:
|
||||
jsr r5,flush; buf
|
||||
rts pc
|
||||
|
||||
botch: <Temp file?\n\0>; ebotch:
|
||||
.even
|
||||
|
||||
.bss
|
||||
buf: .=.+518.
|
||||
.text
|
||||
|
||||
/ C operator and conversion tables
|
||||
|
||||
.globl _opdope
|
||||
.globl _cvtab
|
||||
|
||||
_opdope:.+2
|
||||
00000 / EOF
|
||||
00000 / ;
|
||||
00000 / {
|
||||
00000 / }
|
||||
36000 / [
|
||||
02000 / ]
|
||||
36000 / (
|
||||
02000 / )
|
||||
14201 / :
|
||||
07001 / ,
|
||||
00000 / 10
|
||||
00000 / 11
|
||||
00000 / 12
|
||||
00000 / 13
|
||||
00000 / 14
|
||||
00000 / 15
|
||||
00000 / 16
|
||||
00000 / 17
|
||||
00000 / 18
|
||||
00000 / 19
|
||||
00000 / name
|
||||
00000 / short constant
|
||||
00000 / string
|
||||
00000 / float
|
||||
00000 / double
|
||||
00000 / 25
|
||||
00000 / 26
|
||||
00000 / 27
|
||||
00000 / 28
|
||||
00000 / 29
|
||||
34202 / ++pre
|
||||
34202 / --pre
|
||||
34202 / ++post
|
||||
34202 / --post
|
||||
34220 / !un
|
||||
34202 / &un
|
||||
34220 / *un
|
||||
34200 / -un
|
||||
34220 / ~un
|
||||
00000 / 39
|
||||
30101 / +
|
||||
30001 / -
|
||||
32101 / *
|
||||
32001 / /
|
||||
32001 / %
|
||||
26061 / >>
|
||||
26061 / <<
|
||||
20161 / &
|
||||
16161 / |
|
||||
16161 / ^
|
||||
00000 / 50
|
||||
00000 / 51
|
||||
00000 / 52
|
||||
00000 / 53
|
||||
00000 / 54
|
||||
00000 / 55
|
||||
00000 / 56
|
||||
00000 / 57
|
||||
00000 / 58
|
||||
00000 / 59
|
||||
22105 / ==
|
||||
22105 / !=
|
||||
24105 / <=
|
||||
24105 / <
|
||||
24105 / >=
|
||||
24105 / >
|
||||
24105 / <p
|
||||
24105 / <=p
|
||||
24105 / >p
|
||||
24105 / >=p
|
||||
12213 / =+
|
||||
12213 / =-
|
||||
12213 / =*
|
||||
12213 / =/
|
||||
12213 / =%
|
||||
12253 / =>>
|
||||
12253 / =<<
|
||||
12253 / =&
|
||||
12253 / =|
|
||||
12253 / =^
|
||||
12213 / =
|
||||
00000 / 81
|
||||
00000 / 82
|
||||
00000 / 83
|
||||
00000 / int -> float
|
||||
00000 / int -> double
|
||||
00000 / float -> int
|
||||
00000 / float -> double
|
||||
00000 / double -> int
|
||||
00000 / double -> float
|
||||
14201 / ?
|
||||
00000 / 91
|
||||
00000 / 92
|
||||
00000 / 93
|
||||
00000 / int -> float
|
||||
00000 / int -> double
|
||||
00000 / float -> double
|
||||
00000 / int -> int[]
|
||||
00000 / int -> float[]
|
||||
00000 / int -> double[]
|
||||
36001 / call
|
||||
36001 / mcall
|
||||
|
||||
_cvtab: .+2
|
||||
.byte 000 / i:i
|
||||
.byte 000 / i:c
|
||||
.byte 113 / i:f
|
||||
.byte 125 / i:d
|
||||
.byte 140 / i:i[]
|
||||
.byte 100 / i:c[]
|
||||
.byte 150 / i:f[]
|
||||
.byte 160 / i:d[]
|
||||
.byte 140 / i:[][]
|
||||
|
||||
.byte 100 / c:i
|
||||
.byte 100 / c:c
|
||||
.byte 113 / c:f
|
||||
.byte 125 / c:d
|
||||
.byte 140 / c:i[]
|
||||
.byte 100 / c:c[]
|
||||
.byte 150 / c:f[]
|
||||
.byte 160 / c:d[]
|
||||
.byte 140 / c[][]
|
||||
|
||||
.byte 211 / f:i
|
||||
.byte 211 / f:c
|
||||
.byte 000 / f:f
|
||||
.byte 136 / f:d
|
||||
.byte 211 / f:i[]
|
||||
.byte 211 / f:c[]
|
||||
.byte 211 / f:f[]
|
||||
.byte 211 / f:d[]
|
||||
.byte 211 / f:[][]
|
||||
|
||||
.byte 222 / d:i
|
||||
.byte 222 / d:c
|
||||
.byte 234 / d:f
|
||||
.byte 000 / d:d
|
||||
.byte 222 / d:i[]
|
||||
.byte 222 / d:c[]
|
||||
.byte 222 / d:f[]
|
||||
.byte 222 / d:d[]
|
||||
.byte 222 / d:[][]
|
||||
|
||||
.byte 240 / i[]:i
|
||||
.byte 240 / i[]:c
|
||||
.byte 113 / i[]:f
|
||||
.byte 125 / i[]:d
|
||||
.byte 000 / i[]:i[]
|
||||
.byte 000 / i[]:c[]
|
||||
.byte 100 / i[]:f[]
|
||||
.byte 100 / i[]:d[]
|
||||
.byte 100 / i[]:[][]
|
||||
|
||||
.byte 000 / c[]:i
|
||||
.byte 000 / c[]:c
|
||||
.byte 113 / c[]:f
|
||||
.byte 125 / c[]:d
|
||||
.byte 200 / c[]:i[]
|
||||
.byte 000 / c[]:c[]
|
||||
.byte 200 / c[]:f[]
|
||||
.byte 200 / c[]:d[]
|
||||
.byte 200 / c[]:[][]
|
||||
|
||||
.byte 250 / f[]:i
|
||||
.byte 250 / f[]:c
|
||||
.byte 113 / f[]:f
|
||||
.byte 125 / f[]:d
|
||||
.byte 000 / f[]:i[]
|
||||
.byte 000 / f[]:c[]
|
||||
.byte 000 / f[]:f[]
|
||||
.byte 100 / f[]:d[]
|
||||
.byte 000 / f[]:[][]
|
||||
|
||||
.byte 260 / d[]:i
|
||||
.byte 260 / d[]:c
|
||||
.byte 113 / d[]:f
|
||||
.byte 125 / d[]:d
|
||||
.byte 000 / d[]:i[]
|
||||
.byte 000 / d[]:c[]
|
||||
.byte 000 / d[]:f[]
|
||||
.byte 000 / d[]:d[]
|
||||
.byte 000 / d[]:[][]
|
||||
|
||||
.byte 240 / [][]:i
|
||||
.byte 240 / [][]:c
|
||||
.byte 113 / [][]:f
|
||||
.byte 125 / [][]:d
|
||||
.byte 000 / [][]:i[]
|
||||
.byte 000 / [][]:c[]
|
||||
.byte 100 / [][]:f[]
|
||||
.byte 100 / [][]:d[]
|
||||
.byte 000 / [][]:[][]
|
||||
|
||||
.even
|
||||
|
||||
/ character type table
|
||||
|
||||
.globl _ctab
|
||||
|
||||
_ctab: .+2
|
||||
.byte 000.,127.,127.,127.,127.,127.,127.,127.
|
||||
.byte 127.,126.,125.,127.,127.,127.,127.,127.
|
||||
.byte 127.,127.,127.,127.,127.,127.,127.,127.
|
||||
.byte 127.,127.,127.,127.,127.,127.,127.,127.
|
||||
.byte 126.,034.,122.,127.,127.,044.,047.,121.
|
||||
.byte 006.,007.,042.,040.,009.,041.,127.,043.
|
||||
.byte 124.,124.,124.,124.,124.,124.,124.,124.
|
||||
.byte 124.,124.,008.,001.,063.,080.,065.,090.
|
||||
.byte 127.,123.,123.,123.,123.,123.,123.,123.
|
||||
.byte 123.,123.,123.,123.,123.,123.,123.,123.
|
||||
.byte 123.,123.,123.,123.,123.,123.,123.,123.
|
||||
.byte 123.,123.,123.,004.,127.,005.,049.,127.
|
||||
.byte 127.,123.,123.,123.,123.,123.,123.,123.
|
||||
.byte 123.,123.,123.,123.,123.,123.,123.,123.
|
||||
.byte 123.,123.,123.,123.,123.,123.,123.,123.
|
||||
.byte 123.,123.,123.,002.,048.,003.,127.,127.
|
||||
|
469
last1120c/c10.c
Normal file
469
last1120c/c10.c
Normal file
@ -0,0 +1,469 @@
|
||||
/*
|
||||
|
||||
C compiler, part 2
|
||||
|
||||
Copyright 1972 Bell Telephone Laboratories, Inc.
|
||||
|
||||
*/
|
||||
|
||||
ospace() {} /* fake */
|
||||
|
||||
waste() /* waste space */
|
||||
{
|
||||
waste(waste(waste),waste(waste),waste(waste));
|
||||
waste(waste(waste),waste(waste),waste(waste));
|
||||
waste(waste(waste),waste(waste),waste(waste));
|
||||
waste(waste(waste),waste(waste),waste(waste));
|
||||
waste(waste(waste),waste(waste),waste(waste));
|
||||
waste(waste(waste),waste(waste),waste(waste));
|
||||
waste(waste(waste),waste(waste),waste(waste));
|
||||
waste(waste(waste),waste(waste),waste(waste));
|
||||
}
|
||||
main(argc, argv)
|
||||
char argv[][];
|
||||
{
|
||||
extern fout, fin, nerror, line;
|
||||
extern getwrd, rcexpr, ospace, tmpfil;
|
||||
extern cctab[], regtab[], efftab[], sptab[];
|
||||
int sp[], c, table[], tabtab[3][], tree;
|
||||
|
||||
if (argc<4) {
|
||||
error("Arg count");
|
||||
exit(1);
|
||||
}
|
||||
if((fin=open(argv[1],0))<0) {
|
||||
error("Cant't find %s", argv[1]);
|
||||
exit(1);
|
||||
}
|
||||
if((fout=creat(argv[3],017))<0) {
|
||||
error("Can't create %s", argv[3]);
|
||||
exit(1);
|
||||
}
|
||||
tmpfil = argv[2];
|
||||
|
||||
tabtab[0] = regtab;
|
||||
tabtab[1] = efftab;
|
||||
tabtab[2] = cctab;
|
||||
tabtab[3] = sptab;
|
||||
while(c=getchar()) {
|
||||
if(c=='#') {
|
||||
sp = ospace;
|
||||
c = getwrd();
|
||||
tree = getwrd();
|
||||
table = tabtab[getwrd()];
|
||||
line = getwrd();
|
||||
while(c--)
|
||||
*sp++ = getwrd();
|
||||
rcexpr(tree, table, 0);
|
||||
} else
|
||||
putchar(c);
|
||||
}
|
||||
flush();
|
||||
exit(nerror!=0);
|
||||
}
|
||||
|
||||
match(tree, table, nreg)
|
||||
int tree[], table[]; {
|
||||
extern opdope[], dcalc, notcompat;
|
||||
int op, d1, d2, t1, t2, p1[], p2[];
|
||||
char mp[];
|
||||
|
||||
if (tree==0)
|
||||
return(0);
|
||||
op = *tree;
|
||||
if (op>=29) /* if not leaf */
|
||||
p1 = tree[3];
|
||||
else
|
||||
p1 = tree;
|
||||
t1 = p1[1];
|
||||
d1 = dcalc(p1, nreg);
|
||||
if ((opdope[op]&01)!=0) { /* binary? */
|
||||
p2 = tree[4];
|
||||
t2 = p2[1];
|
||||
d2 = dcalc(p2, nreg);
|
||||
}
|
||||
while(*table) {
|
||||
if (*table++ == op) goto foundop;
|
||||
table++;
|
||||
}
|
||||
return(0);
|
||||
foundop:
|
||||
table = *table;
|
||||
nxtry:
|
||||
mp = table;
|
||||
if (*mp == 0)
|
||||
return(0);
|
||||
if (d1 > (*mp&077) | (*mp>=0100)&(*p1!=36))
|
||||
goto notyet;
|
||||
if (notcompat(t1, mp[1]))
|
||||
goto notyet;
|
||||
if ((opdope[op]&01)!=0 & p2!=0) {
|
||||
if (d2 > (mp[2]&077) | (mp[2]>=0100)&(*p2!=36))
|
||||
goto notyet;
|
||||
if (notcompat(t2,mp[3]))
|
||||
goto notyet;
|
||||
}
|
||||
now:
|
||||
return(table[2]);
|
||||
notyet:
|
||||
table = table+3;
|
||||
goto nxtry;
|
||||
}
|
||||
|
||||
rcexpr(tree, table, reg)
|
||||
int tree[]; {
|
||||
extern cexpr, regtab, cctab, sptab, printf, error;
|
||||
extern jumpc, cbranch;
|
||||
|
||||
if(tree==0)
|
||||
return;
|
||||
if(*tree >= 103) {
|
||||
(*tree==103?jumpc:cbranch)(tree[1],tree[2],tree[3],0);
|
||||
return;
|
||||
}
|
||||
if (cexpr(tree, table, reg))
|
||||
return;
|
||||
if (table!=regtab)
|
||||
if(cexpr(tree, regtab, reg)) {
|
||||
if (table==sptab)
|
||||
printf("mov r%d,-(sp)\n", reg);
|
||||
if (table==cctab)
|
||||
printf("tst r%d\n", reg);
|
||||
return;
|
||||
}
|
||||
error("No match for op %d", *tree);
|
||||
}
|
||||
|
||||
cexpr(tree, table, reg)
|
||||
int tree[][], table[]; {
|
||||
extern match, nreg, printf, pname, putchar, regtab;
|
||||
extern sptab, cctab, rcexpr, prins, rlength, popstk;
|
||||
extern collcon, isn, label, branch, cbranch, fltmod;
|
||||
int p1[], p2[], c, r, p[], otable[], ctable[], regtab[], cctab[];
|
||||
char string[], match[];
|
||||
|
||||
if ((c = *tree)==100) { /* call */
|
||||
p1 = tree[3];
|
||||
p2 = tree[4];
|
||||
r = 0;
|
||||
if(p2) {
|
||||
while (*p2==9) { /* comma */
|
||||
rcexpr(p2[4], sptab, 0);
|
||||
r =+ rlength((p=p2[4])[1]);
|
||||
p2 = p2[3];
|
||||
}
|
||||
rcexpr(p2, sptab, 0);
|
||||
r =+ rlength(p2[1]);
|
||||
}
|
||||
*tree = 101;
|
||||
tree[2] = r; /* save arg length */
|
||||
}
|
||||
if(c==90) { /* ? */
|
||||
cbranch(tree[3], c=isn++, 0, reg);
|
||||
rcexpr(tree[4][3], table, reg);
|
||||
branch(r=isn++, 0);
|
||||
label(c);
|
||||
rcexpr(tree[4][4], table, reg);
|
||||
label(r);
|
||||
return(1);
|
||||
}
|
||||
if ((string=match(tree, table, nreg-reg))==0)
|
||||
return(0);
|
||||
p1 = tree[3];
|
||||
p2 = tree[4];
|
||||
loop:
|
||||
switch(c = *string++) {
|
||||
|
||||
case '\0':
|
||||
p = tree;
|
||||
if (*p==101 & p[2]>0) {
|
||||
popstk(p[2]);
|
||||
}
|
||||
return(1);
|
||||
|
||||
/* A1 */
|
||||
case 'A':
|
||||
p = tree[3];
|
||||
goto adr;
|
||||
|
||||
/* A2 */
|
||||
case 'B':
|
||||
p = tree[4];
|
||||
goto adr;
|
||||
|
||||
/* A */
|
||||
case 'O':
|
||||
p = tree;
|
||||
adr:
|
||||
pname(p);
|
||||
goto loop;
|
||||
|
||||
/* I */
|
||||
case 'M':
|
||||
if ((c = *string)=='\'')
|
||||
string++; else
|
||||
c = 0;
|
||||
prins(*tree, c);
|
||||
goto loop;
|
||||
|
||||
/* B1 */
|
||||
case 'C':
|
||||
p = tree[3];
|
||||
goto pbyte;
|
||||
|
||||
/* BF */
|
||||
case 'P':
|
||||
p = tree;
|
||||
goto pb1;
|
||||
|
||||
/* B2 */
|
||||
case 'D':
|
||||
p = tree[4];
|
||||
pbyte:
|
||||
if (p[1]==1) /* char type? */
|
||||
putchar('b');
|
||||
pb1:
|
||||
if (isfloat(p))
|
||||
putchar('f');
|
||||
goto loop;
|
||||
|
||||
/* BE */
|
||||
case 'L':
|
||||
if (tree[3][1]==1 | tree[4][1]==1)
|
||||
putchar('b');
|
||||
goto loop;
|
||||
|
||||
/* C1 */
|
||||
case 'E':
|
||||
p = p1[3];
|
||||
goto const;
|
||||
|
||||
/* C2 */
|
||||
case 'F':
|
||||
p = p2[3];
|
||||
const:
|
||||
printf("%o", p);
|
||||
goto loop;
|
||||
|
||||
/* F */
|
||||
case 'G':
|
||||
p = p1;
|
||||
goto subtre;
|
||||
|
||||
/* S */
|
||||
case 'K':
|
||||
p = p2;
|
||||
goto subtre;
|
||||
|
||||
/* H */
|
||||
case 'H':
|
||||
p = tree;
|
||||
|
||||
subtre:
|
||||
ctable = regtab;
|
||||
r = reg;
|
||||
c = *string++ - 'A';
|
||||
if ((c&02)!=0)
|
||||
ctable = sptab;
|
||||
if ((c&04)!=0)
|
||||
ctable = cctab;
|
||||
if((c&010)!=0)
|
||||
r = reg+1;
|
||||
if((c&01)!=0)
|
||||
if(*p==36) {
|
||||
p = p[3];
|
||||
if(collcon(p) & ctable!=sptab)
|
||||
p = p[3];
|
||||
}
|
||||
rcexpr(p, ctable, r);
|
||||
goto loop;
|
||||
|
||||
/* R */
|
||||
case 'I':
|
||||
r = reg;
|
||||
goto preg;
|
||||
|
||||
/* R1 */
|
||||
case 'J':
|
||||
r = reg+1;
|
||||
preg:
|
||||
printf("r%d", r);
|
||||
goto loop;
|
||||
|
||||
case '#':
|
||||
p = p1[3];
|
||||
goto nmbr;
|
||||
|
||||
case '"':
|
||||
p = p2[3];
|
||||
goto nmbr;
|
||||
case '~':
|
||||
p = tree[3];
|
||||
|
||||
nmbr:
|
||||
if(collcon(p)) {
|
||||
c = *p;
|
||||
if(r = (p=p[4])[3])
|
||||
printf("%o", c==40?r:-r);
|
||||
}
|
||||
goto loop;
|
||||
|
||||
/* M */
|
||||
case 'N':
|
||||
if ((c=isfloat(tree, &string))==fltmod)
|
||||
goto loop;
|
||||
printf((fltmod=c)==2?"setf\n":"setd\n");
|
||||
goto loop;
|
||||
|
||||
/* Z */
|
||||
case 'Z':
|
||||
printf("$%o", p1[4]);
|
||||
goto loop;
|
||||
}
|
||||
putchar(c);
|
||||
goto loop;
|
||||
}
|
||||
|
||||
pname(p)
|
||||
int p[][][]; {
|
||||
extern putchar, printf, error;
|
||||
char np[];
|
||||
int i;
|
||||
|
||||
loop:
|
||||
switch(*p) {
|
||||
|
||||
case 21: /* const */
|
||||
printf("$%o", p[3]);
|
||||
return;
|
||||
|
||||
case 22: /* string */
|
||||
printf("$l%d", p[3]);
|
||||
return;
|
||||
|
||||
case 20: /* name */
|
||||
switch(p[3]) {
|
||||
|
||||
case 5: /* auto, param */
|
||||
printf("%o(r5)", p[4]);
|
||||
return;
|
||||
|
||||
/* extern */
|
||||
case 6:
|
||||
printf("%p", &p[4]);
|
||||
return;
|
||||
|
||||
}
|
||||
printf("L%d", p[4]);
|
||||
return;
|
||||
|
||||
case 35: /* & */
|
||||
putchar('$');
|
||||
p = p[3];
|
||||
goto loop;
|
||||
|
||||
case 36: /* * */
|
||||
putchar('*');
|
||||
p = p[3];
|
||||
goto loop;
|
||||
}
|
||||
error("pname called illegally");
|
||||
}
|
||||
|
||||
dcalc(p, nreg)
|
||||
int p[]; {
|
||||
int op, t;
|
||||
|
||||
if (p==0)
|
||||
return(0);
|
||||
op = *p;
|
||||
switch (op) {
|
||||
|
||||
case 20: /* name */
|
||||
case 22: /* string */
|
||||
case 23: /* float */
|
||||
case 24: /* double */
|
||||
return(12);
|
||||
|
||||
case 21: /* short constant */
|
||||
return(p[3]==0? 4:8);
|
||||
|
||||
case 35: /* & */
|
||||
return(12);
|
||||
|
||||
case 36: /* * */
|
||||
if ((op=dcalc(p[3], nreg))<16)
|
||||
return(16);
|
||||
}
|
||||
|
||||
def:
|
||||
return(p[2]<=nreg? 20: 24);
|
||||
}
|
||||
|
||||
notcompat(at, st) {
|
||||
|
||||
if (st==0) /* word, byte */
|
||||
return(at>1 & at<16);
|
||||
if (st==1) /* word */
|
||||
return(at>0 & at<16);
|
||||
st =- 2;
|
||||
if (st==2 & at==3)
|
||||
at = 2;
|
||||
return(st != at);
|
||||
}
|
||||
|
||||
prins(op, c) {
|
||||
extern instab[], printf;
|
||||
int insp[];
|
||||
|
||||
insp = instab;
|
||||
while(*insp) {
|
||||
if (*insp++ == op) {
|
||||
if ((c = insp[c!=0])==0)
|
||||
goto err;
|
||||
printf("%s", c);
|
||||
return;
|
||||
} else
|
||||
insp = insp + 2;
|
||||
}
|
||||
err:
|
||||
error("No match' for op %d", op);
|
||||
}
|
||||
|
||||
collcon(p)
|
||||
int p[]; {
|
||||
int p1[];
|
||||
|
||||
if(*p==40 | *p==41)
|
||||
if(*(p1=p[4])==21)
|
||||
return(1);
|
||||
return(0);
|
||||
}
|
||||
|
||||
isfloat(t, s)
|
||||
int t[];
|
||||
char s[][];
|
||||
{
|
||||
extern opdope[];
|
||||
int rt;
|
||||
|
||||
rt = **s - '0';
|
||||
if (rt==2 | rt==4) {
|
||||
(*s)++;
|
||||
return(rt>2?3:2);
|
||||
}
|
||||
if ((opdope[t[0]]&010)!=0) /* relational */
|
||||
t = t[3];
|
||||
if ((rt=t[1])>=2 & rt<=3)
|
||||
return(rt);
|
||||
return(0);
|
||||
}
|
||||
|
||||
nreg 4;
|
||||
isn 10000;
|
||||
namsiz 8;
|
||||
line;
|
||||
tmpfil;
|
||||
nerror;
|
||||
fltmod;
|
||||
|
251
last1120c/c11.c
Normal file
251
last1120c/c11.c
Normal file
@ -0,0 +1,251 @@
|
||||
jumpc(tree, lbl, cond)
|
||||
int tree[]; {
|
||||
extern jump, cctab[], rcexpr, isn, label, branch, cbranch;
|
||||
int l1, l2;
|
||||
|
||||
if (tree==0)
|
||||
return;
|
||||
switch(*tree) {
|
||||
|
||||
/* & */
|
||||
case 47:
|
||||
if (cond) {
|
||||
cbranch(tree[3], l1=isn++, 0, 0);
|
||||
cbranch(tree[4], l1, 0, 0);
|
||||
jump(lbl);
|
||||
label(l1);
|
||||
} else {
|
||||
cbranch(tree[3], l1=isn++, 0, 0);
|
||||
cbranch(tree[4], l2=isn++, 1, 0);
|
||||
label(l1);
|
||||
jump(lbl);
|
||||
label(l2);
|
||||
}
|
||||
return;
|
||||
|
||||
/* | */
|
||||
case 48:
|
||||
if (cond) {
|
||||
cbranch(tree[3], l1=isn++, 1, 0);
|
||||
cbranch(tree[4], l2=isn++, 0, 0);
|
||||
label(l1);
|
||||
jump(lbl);
|
||||
label(l2);
|
||||
} else {
|
||||
cbranch(tree[3], l1=isn++, 1, 0);
|
||||
cbranch(tree[4], l1, 1, 0);
|
||||
jump(lbl);
|
||||
label(l1);
|
||||
}
|
||||
return;
|
||||
|
||||
/* ! */
|
||||
case 34:
|
||||
jumpc(tree[3], lbl, !cond);
|
||||
return;
|
||||
}
|
||||
rcexpr(tree, cctab, 0);
|
||||
branch(l1=isn++, *tree, cond);
|
||||
jump(lbl);
|
||||
label(l1);
|
||||
return;
|
||||
}
|
||||
|
||||
cbranch(tree, lbl, cond, reg)
|
||||
int tree[]; {
|
||||
extern branch, cctab[], rcexpr, isn, label;
|
||||
int l1;
|
||||
|
||||
if (tree==0)
|
||||
return;
|
||||
switch(*tree) {
|
||||
|
||||
/* & */
|
||||
case 47:
|
||||
if (cond) {
|
||||
cbranch(tree[3], l1=isn++, 0, reg);
|
||||
cbranch(tree[4], lbl, 1, reg);
|
||||
label(l1);
|
||||
} else {
|
||||
cbranch(tree[3], lbl, 0, reg);
|
||||
cbranch(tree[4], lbl, 0, reg);
|
||||
}
|
||||
return;
|
||||
|
||||
/* | */
|
||||
case 48:
|
||||
if (cond) {
|
||||
cbranch(tree[3], lbl, 1, reg);
|
||||
cbranch(tree[4], lbl, 1, reg);
|
||||
} else {
|
||||
cbranch(tree[3], l1=isn++, 1, reg);
|
||||
cbranch(tree[4], lbl, 0, reg);
|
||||
label(l1);
|
||||
}
|
||||
return;
|
||||
|
||||
/* ! */
|
||||
case 34:
|
||||
cbranch(tree[3], lbl, !cond, reg);
|
||||
return;
|
||||
}
|
||||
rcexpr(tree, cctab, reg);
|
||||
branch(lbl, *tree, !cond);
|
||||
return;
|
||||
}
|
||||
|
||||
|
||||
branch(lbl, op, c) {
|
||||
extern printf, prins, opdope[];
|
||||
|
||||
if(op) {
|
||||
if((opdope[op]&04)==0)
|
||||
op = 61;
|
||||
prins(op,c);
|
||||
} else
|
||||
printf("br");
|
||||
printf("\tl%d\n", lbl);
|
||||
}
|
||||
|
||||
jump(lab) {
|
||||
extern printf;
|
||||
|
||||
printf("jmp\tl%d\n", lab);
|
||||
}
|
||||
|
||||
label(l) {
|
||||
extern printf;
|
||||
|
||||
printf("l%d:", l);
|
||||
}
|
||||
|
||||
|
||||
popstk(a) {
|
||||
extern printf;
|
||||
|
||||
switch(a) {
|
||||
|
||||
case 0:
|
||||
return;
|
||||
|
||||
case 2:
|
||||
printf("tst (sp)+\n");
|
||||
return;
|
||||
|
||||
case 4:
|
||||
printf("cmp (sp)+,(sp)+\n");
|
||||
return;
|
||||
}
|
||||
printf("add $%o,sp\n", a);
|
||||
}
|
||||
|
||||
length(t) {
|
||||
|
||||
if (t<0)
|
||||
t =+ 020;
|
||||
if (t>=020)
|
||||
return(2);
|
||||
switch(t) {
|
||||
|
||||
case 0:
|
||||
return(2);
|
||||
|
||||
case 1:
|
||||
return(1);
|
||||
|
||||
case 2:
|
||||
return(4);
|
||||
|
||||
case 3:
|
||||
return(8);
|
||||
|
||||
case 4:
|
||||
return(4);
|
||||
|
||||
}
|
||||
return(1024);
|
||||
}
|
||||
|
||||
rlength(c) {
|
||||
extern length;
|
||||
auto l;
|
||||
|
||||
return((l=length(c))==1? 2: l);
|
||||
}
|
||||
|
||||
printn(n,b) {
|
||||
extern putchar;
|
||||
auto a;
|
||||
|
||||
if(a=n/b) /* assignment, not test for equality */
|
||||
printn(a, b); /* recursive */
|
||||
putchar(n%b + '0');
|
||||
}
|
||||
|
||||
printf(fmt,x1,x2,x3,x4,x5,x6,x7,x8,x9)
|
||||
char fmt[]; {
|
||||
extern printn, putchar, namsiz, ncpw;
|
||||
char s[];
|
||||
auto adx[], x, c, i[];
|
||||
|
||||
adx = &x1; /* argument pointer */
|
||||
loop:
|
||||
while((c = *fmt++) != '%') {
|
||||
if(c == '\0')
|
||||
return;
|
||||
putchar(c);
|
||||
}
|
||||
x = *adx++;
|
||||
switch (c = *fmt++) {
|
||||
|
||||
case 'd': /* decimal */
|
||||
case 'o': /* octal */
|
||||
if(x < 0) {
|
||||
x = -x;
|
||||
if(x<0) { /* - infinity */
|
||||
if(c=='o')
|
||||
printf("100000");
|
||||
else
|
||||
printf("-32767");
|
||||
goto loop;
|
||||
}
|
||||
putchar('-');
|
||||
}
|
||||
printn(x, c=='o'?8:10);
|
||||
goto loop;
|
||||
|
||||
case 's': /* string */
|
||||
s = x;
|
||||
while(c = *s++)
|
||||
putchar(c);
|
||||
goto loop;
|
||||
|
||||
case 'p':
|
||||
s = x;
|
||||
putchar('_');
|
||||
c = namsiz;
|
||||
while(c--)
|
||||
if(*s)
|
||||
putchar(*s++);
|
||||
goto loop;
|
||||
}
|
||||
putchar('%');
|
||||
fmt--;
|
||||
adx--;
|
||||
goto loop;
|
||||
}
|
||||
|
||||
error(s, p1, p2) {
|
||||
extern printf, line, fout, flush, putchar, nerror;
|
||||
int f;
|
||||
|
||||
nerror++;
|
||||
flush();
|
||||
f = fout;
|
||||
fout = 1;
|
||||
printf("%d: ", line);
|
||||
printf(s, p1, p2);
|
||||
putchar('\n');
|
||||
fout = f;
|
||||
}
|
||||
|
171
last1120c/c1t.s
Normal file
171
last1120c/c1t.s
Normal file
@ -0,0 +1,171 @@
|
||||
/ C operator tables
|
||||
|
||||
.globl _getwrd
|
||||
|
||||
.globl getw
|
||||
.globl fopen
|
||||
.globl _tmpfil
|
||||
|
||||
.data
|
||||
_getwrd: 1f
|
||||
.text
|
||||
1:
|
||||
tst buf
|
||||
bne 1f
|
||||
mov _tmpfil,r0
|
||||
jsr r5,fopen; buf
|
||||
bes botchp
|
||||
1:
|
||||
jsr r5,getw; buf
|
||||
bes botchp
|
||||
rts pc
|
||||
botchp:
|
||||
mov $1,r0
|
||||
sys write; botch; ebotch-botch
|
||||
sys exit
|
||||
botch:
|
||||
<Temp file botch.\n>; ebotch:
|
||||
.even
|
||||
.bss
|
||||
buf: .=.+518.
|
||||
.text
|
||||
.globl _opdope
|
||||
.globl _instab
|
||||
|
||||
_instab:.+2
|
||||
40.; 1f; 1f; .data; 1:<add\0>; .text
|
||||
70.; 1b; 1b
|
||||
41.; 2f; 2f; .data; 2:<sub\0>; .text
|
||||
71.; 2b; 2b
|
||||
30.; 3f; 1b; .data; 3:<inc\0>; .text
|
||||
31.; 4f; 2b; .data; 4:<dec\0>; .text
|
||||
32.; 3b; 1b
|
||||
33.; 4b; 2b
|
||||
|
||||
45.; 2b; 5f; .data; 5:<ac\0>; .text
|
||||
46.; 6f; 7f; .data; 6:<mov\0>; 7:<(r4)\0>; .text
|
||||
75.; 2b; 5b
|
||||
76.; 6b; 7b
|
||||
43.; 7b; 1f; .data; 1:<divf\0>; .text
|
||||
44.; 5b; 0
|
||||
73.; 7b; 1b
|
||||
74.; 5b; 0
|
||||
|
||||
60.; 0f; 1f; .data; 0:<beq\0>; 1:<bne\0>; .text
|
||||
61.; 1b; 0b
|
||||
62.; 2f; 5f; .data; 2:<ble\0>; 5:<bgt\0>; .text
|
||||
63.; 3f; 4f; .data; 3:<blt\0>; 4:<bge\0>; .text
|
||||
64.; 4b; 3b
|
||||
65.; 5b; 2b
|
||||
66.; 6f; 9f; .data; 6:<blos\0>; 9:<bhi\0>; .text
|
||||
67.; 7f; 8f; .data; 7:<blo\0>; 8:<bhis\0>; .text
|
||||
68.; 8b; 7b
|
||||
69.; 9b; 6b
|
||||
0
|
||||
.data
|
||||
.even
|
||||
.text
|
||||
|
||||
_opdope:.+2
|
||||
00000 / EOF
|
||||
00000 / ;
|
||||
00000 / {
|
||||
00000 / }
|
||||
36000 / [
|
||||
02000 / ]
|
||||
36000 / (
|
||||
02000 / )
|
||||
02000 / :
|
||||
07001 / ,
|
||||
00000 / 10
|
||||
00000 / 11
|
||||
00000 / 12
|
||||
00000 / 13
|
||||
00000 / 14
|
||||
00000 / 15
|
||||
00000 / 16
|
||||
00000 / 17
|
||||
00000 / 18
|
||||
00000 / 19
|
||||
00000 / name
|
||||
00000 / short constant
|
||||
00000 / string
|
||||
00000 / float
|
||||
00000 / double
|
||||
00000 / 25
|
||||
00000 / 26
|
||||
00000 / 27
|
||||
00000 / 28
|
||||
00000 / 29
|
||||
34002 / ++pre
|
||||
34002 / --pre
|
||||
34002 / ++post
|
||||
34002 / --post
|
||||
34020 / !un
|
||||
34002 / &un
|
||||
34020 / *un
|
||||
34000 / -un
|
||||
34020 / ~un
|
||||
00000 / 39
|
||||
30101 / +
|
||||
30001 / -
|
||||
32101 / *
|
||||
32001 / /
|
||||
32001 / %
|
||||
26061 / >>
|
||||
26061 / <<
|
||||
20161 / &
|
||||
16161 / |
|
||||
16161 / ^
|
||||
00000 / 50
|
||||
00000 / 51
|
||||
00000 / 52
|
||||
00000 / 53
|
||||
00000 / 54
|
||||
00000 / 55
|
||||
00000 / 56
|
||||
00000 / 57
|
||||
00000 / 58
|
||||
00000 / 59
|
||||
22105 / ==
|
||||
22105 / !=
|
||||
24105 / <=
|
||||
24105 / <
|
||||
24105 / >=
|
||||
24105 / >
|
||||
24105 / <p
|
||||
24105 / <=p
|
||||
24105 / >p
|
||||
24105 / >=p
|
||||
12013 / =+
|
||||
12013 / =-
|
||||
12013 / =*
|
||||
12013 / =/
|
||||
12013 / =%
|
||||
12053 / =>>
|
||||
12053 / =<<
|
||||
12053 / =&
|
||||
12053 / =|
|
||||
12053 / =^
|
||||
12013 / =
|
||||
00000 / 81
|
||||
00000 / 82
|
||||
00000 / 83
|
||||
00000 / int -> float
|
||||
00000 / int -> double
|
||||
00000 / float -> int
|
||||
00000 / float -> double
|
||||
00000 / double -> int
|
||||
00000 / double -> float
|
||||
14001 / ?
|
||||
00000 / 91
|
||||
00000 / 92
|
||||
00000 / 93
|
||||
00000 / int -> float
|
||||
00000 / int -> double
|
||||
00000 / float -> double
|
||||
00000 / int -> int[]
|
||||
00000 / int -> float[]
|
||||
00000 / int -> double[]
|
||||
36001 / call
|
||||
36001 / mcall
|
118
last1120c/cctab.s
Normal file
118
last1120c/cctab.s
Normal file
@ -0,0 +1,118 @@
|
||||
/ c code tables-- set condition codes
|
||||
|
||||
.globl _cctab
|
||||
|
||||
_cctab=.;.+2
|
||||
20.; rest
|
||||
21.; rest
|
||||
22.; rest
|
||||
30.; rest
|
||||
31.; rest
|
||||
34.; rest
|
||||
35.; rest
|
||||
36.; rest
|
||||
37.; rest
|
||||
40.; rest
|
||||
41.; rest
|
||||
42.; rest
|
||||
43.; rest
|
||||
44.; rest
|
||||
45.; rest
|
||||
46.; rest
|
||||
47.; rest
|
||||
48.; rest
|
||||
60.; cc60
|
||||
61.; cc60
|
||||
62.; cc60
|
||||
63.; cc60
|
||||
64.; cc60
|
||||
65.; cc60
|
||||
66.; cc60
|
||||
67.; cc60
|
||||
68.; cc60
|
||||
69.; cc60
|
||||
70.; rest
|
||||
71.; rest
|
||||
72.; rest
|
||||
73.; rest
|
||||
74.; rest
|
||||
75.; rest
|
||||
76.; rest
|
||||
77.; rest
|
||||
78.; rest
|
||||
79.; rest
|
||||
80.; rest
|
||||
|
||||
/ relationals
|
||||
cc60:
|
||||
%a,z
|
||||
tstB1 A1
|
||||
|
||||
%n*,z
|
||||
F*
|
||||
tstB1 #1(R)
|
||||
|
||||
%n,z
|
||||
F
|
||||
tst R
|
||||
|
||||
%a,a
|
||||
cmpBE A1,A2
|
||||
|
||||
%n*,a
|
||||
F*
|
||||
cmpBE #1(R),A2
|
||||
|
||||
%n,a
|
||||
F
|
||||
cmpB2 R,A2
|
||||
|
||||
%n*,e*
|
||||
F*
|
||||
S1*
|
||||
cmpBE #1(R),#2(R1)
|
||||
|
||||
%n*,e
|
||||
F*
|
||||
S1
|
||||
cmpB1 #1(R),R1
|
||||
|
||||
%n,e*
|
||||
F
|
||||
S1*
|
||||
cmpB2 R,#2(R1)
|
||||
|
||||
%n,e
|
||||
F
|
||||
S1
|
||||
cmp R,R1
|
||||
|
||||
%n*,n*
|
||||
FS*
|
||||
S*
|
||||
cmpBE (sp)+,#2(R)
|
||||
|
||||
%n*,n
|
||||
FS*
|
||||
S
|
||||
cmpB1 *(sp)+,R
|
||||
|
||||
%n,n*
|
||||
FS
|
||||
S*
|
||||
cmpB2 (sp)+,#2(R)
|
||||
|
||||
%n,n
|
||||
FS
|
||||
S
|
||||
cmp (sp)+,R
|
||||
|
||||
/ set codes right
|
||||
rest:
|
||||
%n,n
|
||||
H
|
||||
|
||||
.data
|
||||
.even
|
||||
.text
|
||||
|
357
last1120c/cvopt.c
Normal file
357
last1120c/cvopt.c
Normal file
@ -0,0 +1,357 @@
|
||||
main() {
|
||||
/*
|
||||
A1 -> A
|
||||
A2 B
|
||||
A O
|
||||
B1 C
|
||||
B2 D
|
||||
BE L
|
||||
BF P
|
||||
C1 E
|
||||
C2 F
|
||||
F G
|
||||
H H
|
||||
R I
|
||||
R1 J
|
||||
S K
|
||||
I M
|
||||
M N
|
||||
|
||||
* +1
|
||||
S +2
|
||||
C +4
|
||||
1 +8
|
||||
|
||||
z -> 4
|
||||
c 10
|
||||
a 14
|
||||
e 20
|
||||
n 63
|
||||
* +0100
|
||||
*/
|
||||
|
||||
extern putchar,getc,peekc,printf,flag,flush;
|
||||
|
||||
auto c,snlflg,nlflg,t,smode,m,ssmode;
|
||||
|
||||
smode = nlflg = snlflg = ssmode = 0;
|
||||
loop:
|
||||
c = getc();
|
||||
if (c!='\n' & c!='\t') nlflg = 0;
|
||||
if (ssmode!=0 & c!='%') {
|
||||
ssmode = 0;
|
||||
printf(".data\n1:<");
|
||||
}
|
||||
switch(c) {
|
||||
|
||||
case '\0':
|
||||
printf(".text; 0\n");
|
||||
flush();
|
||||
return;
|
||||
|
||||
case ':':
|
||||
if (!smode)
|
||||
printf("=.+2; 0"); else
|
||||
putchar(':');
|
||||
goto loop;
|
||||
|
||||
case 'A':
|
||||
if ((c=getc())=='1' | c=='2') {
|
||||
putchar(c+'A'-'1');
|
||||
goto loop;
|
||||
}
|
||||
putchar('O');
|
||||
peekc = c;
|
||||
goto loop;
|
||||
|
||||
case 'B':
|
||||
switch (getc()) {
|
||||
|
||||
case '1':
|
||||
putchar('C');
|
||||
goto loop;
|
||||
|
||||
case '2':
|
||||
putchar('D');
|
||||
goto loop;
|
||||
|
||||
case 'E':
|
||||
putchar('L');
|
||||
goto loop;
|
||||
|
||||
case 'F':
|
||||
putchar('P');
|
||||
goto loop;
|
||||
}
|
||||
putchar('?');
|
||||
goto loop;
|
||||
|
||||
case 'C':
|
||||
putchar(getc()+'E'-'1');
|
||||
goto loop;
|
||||
|
||||
case 'F':
|
||||
putchar('G');
|
||||
goto subtre;
|
||||
|
||||
case 'R':
|
||||
if ((c=getc()) == '1')
|
||||
putchar('J'); else {
|
||||
putchar('I');
|
||||
peekc = c;
|
||||
}
|
||||
goto loop;
|
||||
|
||||
case 'H':
|
||||
putchar('H');
|
||||
goto subtre;
|
||||
|
||||
case 'I':
|
||||
putchar('M');
|
||||
goto loop;
|
||||
|
||||
case 'M':
|
||||
putchar('N');
|
||||
snlflg++;
|
||||
goto loop;
|
||||
|
||||
case 'S':
|
||||
putchar('K');
|
||||
subtre:
|
||||
snlflg = 1;
|
||||
t = 'A';
|
||||
l1:
|
||||
switch (c=getc()) {
|
||||
|
||||
case '*':
|
||||
t++;
|
||||
goto l1;
|
||||
|
||||
case 'S':
|
||||
t =+ 2;
|
||||
goto l1;
|
||||
|
||||
case 'C':
|
||||
t =+ 4;
|
||||
goto l1;
|
||||
|
||||
case '1':
|
||||
t =+ 8;
|
||||
goto l1;
|
||||
}
|
||||
peekc = c;
|
||||
putchar(t);
|
||||
goto loop;
|
||||
|
||||
case '#':
|
||||
if(getc()=='1')
|
||||
putchar('#'); else
|
||||
putchar('"');
|
||||
goto loop;
|
||||
|
||||
case '%':
|
||||
if (smode)
|
||||
printf(".text;");
|
||||
loop1:
|
||||
switch (c=getc()) {
|
||||
|
||||
case 'a':
|
||||
m = 16;
|
||||
t = flag();
|
||||
goto pf;
|
||||
|
||||
case ',':
|
||||
putchar(';');
|
||||
goto loop1;
|
||||
|
||||
case 'i':
|
||||
m = 12;
|
||||
t = flag();
|
||||
goto pf;
|
||||
case 'z':
|
||||
m = 4;
|
||||
t = 0;
|
||||
goto pf;
|
||||
|
||||
case 'c':
|
||||
t = 0;
|
||||
m = 8;
|
||||
goto pf;
|
||||
|
||||
case 'e':
|
||||
t = flag();
|
||||
m = 20;
|
||||
goto pf;
|
||||
|
||||
case 'n':
|
||||
t = flag();
|
||||
m = 63;
|
||||
pf:
|
||||
if ((c=getc())=='*')
|
||||
m =+ 0100; else
|
||||
peekc = c;
|
||||
printf(".byte %o,%o", m, t);
|
||||
goto loop1;
|
||||
|
||||
case '\n':
|
||||
printf(";1f\n");
|
||||
ssmode = 1;
|
||||
nlflg = 1;
|
||||
smode = 1;
|
||||
goto loop;
|
||||
}
|
||||
putchar(c);
|
||||
goto loop1;
|
||||
|
||||
case '\t':
|
||||
if (nlflg) {
|
||||
nlflg = 0;
|
||||
goto loop;
|
||||
}
|
||||
putchar('\t');
|
||||
goto loop;
|
||||
|
||||
case '\n':
|
||||
if (!smode) {
|
||||
putchar('\n');
|
||||
goto loop;
|
||||
}
|
||||
if (nlflg) {
|
||||
nlflg = 0;
|
||||
printf("\\0>\n.text\n");
|
||||
smode = 0;
|
||||
goto loop;
|
||||
}
|
||||
if (!snlflg)
|
||||
printf("\\n");
|
||||
snlflg = 0;
|
||||
printf(">\n<");
|
||||
nlflg = 1;
|
||||
goto loop;
|
||||
}
|
||||
putchar(c);
|
||||
goto loop;
|
||||
}
|
||||
|
||||
getc() {
|
||||
extern getchar, peekc, nofloat;
|
||||
auto t, ifcnt;
|
||||
|
||||
ifcnt = 0;
|
||||
gc:
|
||||
if (peekc) {
|
||||
t = peekc;
|
||||
peekc = 0;
|
||||
} else
|
||||
t = getchar();
|
||||
if (t==0)
|
||||
return(0);
|
||||
if (t=='{') {
|
||||
ifcnt++;
|
||||
t = getchar();
|
||||
}
|
||||
if (t=='}') {
|
||||
t = getc();
|
||||
if (--ifcnt==0)
|
||||
if (t=='\n')
|
||||
t = getc();
|
||||
}
|
||||
if (ifcnt & nofloat)
|
||||
goto gc;
|
||||
return(t);
|
||||
}
|
||||
|
||||
flag() {
|
||||
extern getc, peekc;
|
||||
auto c, f;
|
||||
|
||||
f = 0;
|
||||
l1:
|
||||
switch(c=getc()) {
|
||||
|
||||
case 'w':
|
||||
f = 1;
|
||||
goto l1;
|
||||
|
||||
case 'i':
|
||||
f = 2;
|
||||
goto l1;
|
||||
|
||||
case 'b':
|
||||
f = 3;
|
||||
goto l1;
|
||||
|
||||
case 'f':
|
||||
f = 4;
|
||||
goto l1;
|
||||
|
||||
case 'd':
|
||||
f = 5;
|
||||
goto l1;
|
||||
|
||||
case 'p':
|
||||
f =+ 16;
|
||||
goto l1;
|
||||
}
|
||||
peekc = c;
|
||||
return(f);
|
||||
}
|
||||
|
||||
peekc 0;
|
||||
|
||||
putchar(c) {
|
||||
extern flush, oubuf, ouptr;
|
||||
char ouptr[], oubuf[];
|
||||
auto c1;
|
||||
|
||||
goto init;
|
||||
init:
|
||||
ouptr = oubuf;
|
||||
init = init1;
|
||||
init1:
|
||||
if(c1 = c>>8) {
|
||||
*ouptr++ = c1;
|
||||
if(ouptr >= oubuf+512)
|
||||
flush();
|
||||
}
|
||||
if(c =& 0377) {
|
||||
*ouptr++ = c;
|
||||
if(ouptr >= oubuf+512)
|
||||
flush();
|
||||
}
|
||||
}
|
||||
|
||||
flush() {
|
||||
extern ouptr, oubuf, fout, write;
|
||||
char ouptr[], oubuf[];
|
||||
|
||||
write(fout, oubuf, ouptr-oubuf);
|
||||
ouptr = oubuf;
|
||||
}
|
||||
|
||||
getcha() {
|
||||
extern read, incnt, fin, inbuf, inptr;
|
||||
char inbuf[], inptr[];
|
||||
|
||||
goto init;
|
||||
init:
|
||||
inptr = inbuf;
|
||||
init = init1;
|
||||
init1:
|
||||
if(inptr >= inbuf+incnt) {
|
||||
inptr = inbuf;
|
||||
incnt = read(fin, inbuf, 512);
|
||||
if(!incnt)
|
||||
return('\0');
|
||||
}
|
||||
return(*inptr++);
|
||||
}
|
||||
|
||||
inbuf[256];
|
||||
oubuf[256];
|
||||
inptr 0;
|
||||
incnt 0;
|
||||
ouptr 0;
|
||||
fin 0;
|
||||
fout 1;
|
||||
nofloat 0;
|
215
last1120c/efftab.s
Normal file
215
last1120c/efftab.s
Normal file
@ -0,0 +1,215 @@
|
||||
/ c code tables
|
||||
|
||||
.globl _efftab
|
||||
|
||||
_efftab=.;.+2
|
||||
30.; ci30
|
||||
31.; ci30
|
||||
32.; ci30 / same as 30
|
||||
33.; ci30 / same as 31
|
||||
80.; ci80
|
||||
70.; ci70
|
||||
71.; ci70 / - like +
|
||||
77.; ci77
|
||||
78.; ci78
|
||||
0
|
||||
|
||||
/ ++ prefix
|
||||
ci30:
|
||||
%ai,n
|
||||
%abp,n
|
||||
%ab,n
|
||||
IB1 A1
|
||||
|
||||
%aip,n
|
||||
I' $2,A1
|
||||
|
||||
%nbp*,n
|
||||
%ni*,n
|
||||
%nb*,n
|
||||
F*
|
||||
IB1 #1(R)
|
||||
|
||||
%nip*,n
|
||||
F*
|
||||
I' $2,#1(R)
|
||||
|
||||
/ =
|
||||
ci80:
|
||||
%a,z
|
||||
clrB1 A1
|
||||
|
||||
%n*,z
|
||||
F*
|
||||
clrB1 #1(R)
|
||||
|
||||
%a,aw
|
||||
movB1 A2,A1
|
||||
|
||||
%a,nw*
|
||||
S*
|
||||
movB1 #2(R),A1
|
||||
|
||||
%a,n
|
||||
S
|
||||
movB1 R,A1
|
||||
|
||||
%n*,aw
|
||||
F*
|
||||
movB1 A2,#1(R)
|
||||
|
||||
%n*,ew*
|
||||
F*
|
||||
S1*
|
||||
movB1 #2(R1),#1(R)
|
||||
|
||||
%n*,e
|
||||
F*
|
||||
S1
|
||||
movB1 R1,#1(R)
|
||||
|
||||
%e*,nw*
|
||||
S*
|
||||
F1*
|
||||
movB1 #2(R),#1(R1)
|
||||
|
||||
%e*,n
|
||||
S
|
||||
F1*
|
||||
movB1 R,#1(R1)
|
||||
|
||||
%n*,nw*
|
||||
FS*
|
||||
S*
|
||||
movB1 #2(R),*(sp)+
|
||||
|
||||
%n*,n
|
||||
FS*
|
||||
S
|
||||
movB1 R,*(sp)+
|
||||
|
||||
/ =| i
|
||||
ci78:
|
||||
%a,a
|
||||
bisBE A2,A1
|
||||
|
||||
%a,n
|
||||
S
|
||||
bisB1 R,A1
|
||||
|
||||
%n*,a
|
||||
F*
|
||||
bisBE A2,#1(R)
|
||||
|
||||
%e*,n*
|
||||
S*
|
||||
F1*
|
||||
bisBE #2(R),#1(R1)
|
||||
|
||||
%e*,n
|
||||
S
|
||||
F1*
|
||||
bisBE R,#1(R1)
|
||||
|
||||
%n*,e*
|
||||
F*
|
||||
S1*
|
||||
bisBE #2(R1),#1(R)
|
||||
|
||||
%n*,e
|
||||
F*
|
||||
S1
|
||||
bisBE R1,#1(R)
|
||||
|
||||
%n*,n*
|
||||
FS*
|
||||
S*
|
||||
bisBE #2(R),*(sp)+
|
||||
|
||||
%n*,n
|
||||
FS*
|
||||
S
|
||||
bisBE R,*(sp)+
|
||||
|
||||
/ =& i
|
||||
ci77:
|
||||
%a,c
|
||||
bicB1 $!C2,A1
|
||||
|
||||
%a,n
|
||||
S
|
||||
com R
|
||||
bicB1 R,A1
|
||||
|
||||
%e*,n
|
||||
S
|
||||
F1*
|
||||
com R
|
||||
bicB1 R,#1(R1)
|
||||
|
||||
%n*,c
|
||||
F*
|
||||
bicB1 $!C2,#1(R)
|
||||
|
||||
%n*,e
|
||||
F*
|
||||
S1
|
||||
com R1
|
||||
bicB1 R1,#1(R)
|
||||
|
||||
%n*,n
|
||||
FS*
|
||||
S
|
||||
com R
|
||||
bicB1 R,*(sp)+
|
||||
|
||||
/ =+
|
||||
ci70:
|
||||
%aw,aw
|
||||
I A2,A1
|
||||
|
||||
%aw,nw*
|
||||
S*
|
||||
I #2(R),A1
|
||||
|
||||
%aw,n
|
||||
S
|
||||
I R,A1
|
||||
|
||||
%ew*,nw*
|
||||
S*
|
||||
F1*
|
||||
I #2(R),#1(R1)
|
||||
|
||||
%a,nw*
|
||||
S*
|
||||
movB1 A1,R1
|
||||
I #2(R),R1
|
||||
movB1 R1,#2(R)
|
||||
|
||||
%a,n
|
||||
S
|
||||
movB1 A1,R1
|
||||
I R1,R
|
||||
movB1 R,A1
|
||||
|
||||
%ew*,n
|
||||
S
|
||||
F1*
|
||||
I R,#1(R1)
|
||||
|
||||
%nw*,n
|
||||
SS
|
||||
F*
|
||||
I (sp)+,#1(R)
|
||||
|
||||
%n*,n
|
||||
SS
|
||||
F*
|
||||
movB1 #1(R),R1
|
||||
I (sp)+,R1
|
||||
movB1 R1,#1(R)
|
||||
|
||||
.data
|
||||
.even
|
||||
|
696
last1120c/regtab.s
Normal file
696
last1120c/regtab.s
Normal file
@ -0,0 +1,696 @@
|
||||
/ c code tables-- compile to register
|
||||
|
||||
fp = 1 / enable floating-point
|
||||
|
||||
.globl _regtab
|
||||
|
||||
_regtab=.; .+2
|
||||
20.; cr20
|
||||
21.; cr20
|
||||
22.; cr20
|
||||
30.; cr30
|
||||
31.; cr30
|
||||
32.; cr32
|
||||
33.; cr32
|
||||
34.; cr34
|
||||
35.; cr35
|
||||
29.; cr29
|
||||
36.; cr36
|
||||
37.; cr37
|
||||
38.; cr38
|
||||
101.; cr100
|
||||
80.; cr80
|
||||
40.; cr40
|
||||
41.; cr40 / - like +
|
||||
42.; cr42
|
||||
43.; cr43
|
||||
44.; cr43
|
||||
45.; cr45
|
||||
46.; cr45
|
||||
47.; cr47
|
||||
48.; cr48
|
||||
60.; cr60
|
||||
61.; cr60
|
||||
62.; cr60
|
||||
63.; cr60
|
||||
64.; cr60
|
||||
65.; cr60
|
||||
66.; cr60
|
||||
67.; cr60
|
||||
68.; cr60
|
||||
69.; cr60
|
||||
70.; cr70
|
||||
71.; cr70
|
||||
72.; cr72
|
||||
73.; cr73
|
||||
74.; cr73
|
||||
75.; cr75
|
||||
76.; cr75
|
||||
77.; cr77
|
||||
78.; cr78
|
||||
102.; cr102
|
||||
97.; cr97
|
||||
0
|
||||
|
||||
/ goto
|
||||
cr102:
|
||||
%i,n
|
||||
jmp *A1
|
||||
|
||||
%n*,n
|
||||
F*
|
||||
jmp *#1(R)
|
||||
|
||||
%n,n
|
||||
F
|
||||
jmp (R)
|
||||
|
||||
/ call
|
||||
cr100:
|
||||
%n*,n
|
||||
F*
|
||||
jsr pc,*#1(R)
|
||||
|
||||
%a,n
|
||||
jsr pc,*A1
|
||||
|
||||
%n,n
|
||||
F
|
||||
jsr pc,(R)
|
||||
|
||||
/ name, constant
|
||||
cr20:
|
||||
%z,n
|
||||
clr R
|
||||
|
||||
%aw,n
|
||||
mov A,R
|
||||
|
||||
%ab,n
|
||||
movb A,R
|
||||
|
||||
.if fp
|
||||
%af,n
|
||||
M
|
||||
movf A,R
|
||||
|
||||
.endif
|
||||
|
||||
/++,-- prefix
|
||||
cr30:
|
||||
%ai,n
|
||||
%abp,n
|
||||
%ab,n
|
||||
IB1 A1
|
||||
movB1 A1,R
|
||||
|
||||
%a,n
|
||||
I' $2,A1
|
||||
mov A1,R
|
||||
|
||||
%nbp*,n
|
||||
%ni*,n
|
||||
%nb*,n
|
||||
F*
|
||||
IB1 #1(R)
|
||||
movB1 #1(R),R
|
||||
|
||||
%n*,n
|
||||
F*
|
||||
I' $2,#1(R)
|
||||
mov #1(R),R
|
||||
|
||||
/ ++,-- postfix
|
||||
cr32:
|
||||
%ai,n
|
||||
%abp,n
|
||||
%ab,n
|
||||
movB1 A1,R
|
||||
IB1 A1
|
||||
|
||||
%a,n
|
||||
mov A1,R
|
||||
I' $2,A1
|
||||
|
||||
%nbp*,n
|
||||
%nb*,n
|
||||
%ni*,n
|
||||
F*
|
||||
movB1 #1(R),-(sp)
|
||||
IB1 #1(R)
|
||||
movB1 (sp)+,R
|
||||
|
||||
%n*,n
|
||||
F*
|
||||
mov #1(R),-(sp)
|
||||
I' $2,#1(R)
|
||||
mov (sp)+,R
|
||||
|
||||
/ !
|
||||
cr34:
|
||||
%n,n
|
||||
FC
|
||||
beq 1f
|
||||
clr R
|
||||
br 2f
|
||||
1: mov $1,R
|
||||
2:
|
||||
|
||||
/ &unary
|
||||
cr35:
|
||||
%a,n
|
||||
mov $A1,R
|
||||
|
||||
/ & unary of auto
|
||||
cr29:
|
||||
%e,n
|
||||
mov r5,R
|
||||
add Z,R
|
||||
|
||||
/ *unary
|
||||
cr36:
|
||||
%abp*,n
|
||||
F
|
||||
movb (R),R
|
||||
|
||||
%a*,n
|
||||
F
|
||||
mov (R),R
|
||||
|
||||
%abp,n
|
||||
movb *A1,R
|
||||
|
||||
%a,n
|
||||
mov *A1,R
|
||||
|
||||
%nbp*,n
|
||||
F*
|
||||
movb *#1(R),R
|
||||
|
||||
%n*,n
|
||||
F*
|
||||
mov *#1(R),R
|
||||
|
||||
%nbp,n
|
||||
H*
|
||||
movb ~(R),R
|
||||
|
||||
%n,n
|
||||
H*
|
||||
mov ~(R),R
|
||||
|
||||
/ - unary
|
||||
cr37:
|
||||
%n,n
|
||||
F
|
||||
neg R
|
||||
|
||||
/ ~
|
||||
cr38:
|
||||
%n,n
|
||||
F
|
||||
com R
|
||||
|
||||
/ =
|
||||
cr80:
|
||||
%a,n
|
||||
S
|
||||
movB1 R,A1
|
||||
|
||||
%n*,a
|
||||
F*
|
||||
movB1 A2,#1(R)
|
||||
movB1 #1(R),R
|
||||
|
||||
%n*,e
|
||||
F*
|
||||
S1
|
||||
movB1 R1,#1(R)
|
||||
mov R1,R
|
||||
|
||||
%n*,n
|
||||
FS*
|
||||
S
|
||||
movB1 R,*(sp)+
|
||||
|
||||
/ |
|
||||
cr48:
|
||||
%n,a
|
||||
F
|
||||
bisB2 A2,R
|
||||
|
||||
%n,e*
|
||||
F
|
||||
S1*
|
||||
bisB2 #2(R1),R
|
||||
|
||||
%n,e
|
||||
F
|
||||
S1
|
||||
bis R1,R
|
||||
|
||||
%n,n
|
||||
FS
|
||||
S
|
||||
bis (sp)+,R
|
||||
|
||||
/ &
|
||||
cr47:
|
||||
%n,c
|
||||
F
|
||||
bic $!C2,R
|
||||
|
||||
%n,e
|
||||
F
|
||||
S1
|
||||
com R1
|
||||
bic R1,R
|
||||
|
||||
%n,n
|
||||
FS
|
||||
S
|
||||
com (sp)
|
||||
bic (sp)+,R
|
||||
|
||||
/ relationals
|
||||
cr60:
|
||||
%n,n
|
||||
HC
|
||||
I 2f
|
||||
clr R
|
||||
br 1f
|
||||
2: mov $1,R
|
||||
1:
|
||||
|
||||
/ >>, <<
|
||||
cr45:
|
||||
%a,aw
|
||||
movB1 A1,I'
|
||||
I A2,lsh
|
||||
movB1 I',R
|
||||
|
||||
%n*,aw
|
||||
F*
|
||||
movB1 #1(R),I'
|
||||
I A2,lsh
|
||||
movB1 I',R
|
||||
|
||||
%n,aw
|
||||
F
|
||||
mov R,I'
|
||||
I A2,lsh
|
||||
mov I',R
|
||||
|
||||
%a,nw*
|
||||
S*
|
||||
movB1 A1,(r4)
|
||||
I #2(R),lsh
|
||||
mov (r4),R
|
||||
|
||||
%a,n
|
||||
S
|
||||
movB1 A1,I'
|
||||
I R,lsh
|
||||
mov I',R
|
||||
|
||||
%n,n
|
||||
FS
|
||||
S
|
||||
mov (sp)+,I'
|
||||
I R,lsh
|
||||
mov I',R
|
||||
|
||||
/ +, -
|
||||
cr40:
|
||||
%n,aw
|
||||
F
|
||||
I A2,R
|
||||
|
||||
%n,ew*
|
||||
F
|
||||
S1*
|
||||
I #2(R1),R
|
||||
|
||||
%n,e
|
||||
F
|
||||
S1
|
||||
I R1,R
|
||||
|
||||
%n,nw*
|
||||
SS*
|
||||
F
|
||||
I *(sp)+,R
|
||||
|
||||
%n,n
|
||||
SS
|
||||
F
|
||||
I (sp)+,R
|
||||
|
||||
/ *
|
||||
cr42:
|
||||
%aw,a
|
||||
mov A1,(r4)+
|
||||
movB2 A2,(r4)
|
||||
mov -(r4),R
|
||||
|
||||
%n,a
|
||||
F
|
||||
mov R,(r4)+
|
||||
movB2 A2,(r4)
|
||||
mov -(r4),R
|
||||
|
||||
%n,e
|
||||
F
|
||||
S1
|
||||
mov R,(r4)+
|
||||
mov R1,(r4)
|
||||
mov -(r4),R
|
||||
|
||||
%n,n
|
||||
FS
|
||||
S
|
||||
mov (sp)+,(r4)+
|
||||
mov R,(r4)
|
||||
mov -(r4),R
|
||||
|
||||
/ /; mod
|
||||
cr43:
|
||||
%a,a
|
||||
movB1 A1,(r4)
|
||||
movB2 A2,div
|
||||
mov I,R
|
||||
|
||||
%a,n
|
||||
S
|
||||
movB1 A1,(r4)
|
||||
mov R,div
|
||||
mov I,R
|
||||
|
||||
%n,a
|
||||
F
|
||||
mov R,(r4)
|
||||
movB2 A2,div
|
||||
mov I,R
|
||||
|
||||
%n,e
|
||||
F
|
||||
S1
|
||||
mov R,(r4)
|
||||
mov R1,div
|
||||
mov I,R
|
||||
|
||||
%e,n
|
||||
S
|
||||
F1
|
||||
mov R1,(r4)
|
||||
mov R,div
|
||||
mov I,R
|
||||
|
||||
%n,n
|
||||
FS
|
||||
S
|
||||
mov (sp)+,(r4)
|
||||
mov R,div
|
||||
mov I,R
|
||||
|
||||
/ =*
|
||||
cr72:
|
||||
%a,a
|
||||
movB1 A1,(r4)
|
||||
movB2 A2,mul
|
||||
movB1 (r4),A1
|
||||
mov (r4),R
|
||||
|
||||
%a,n
|
||||
S
|
||||
mov R,(r4)+
|
||||
movB1 A1,(r4)
|
||||
mov -(r4),R
|
||||
movB1 R,A1
|
||||
|
||||
%n*,a
|
||||
F*
|
||||
movB1 #1(R),(r4)
|
||||
movB2 A2,mul
|
||||
movB1 (r4),#1(R)
|
||||
mov (r4),R
|
||||
|
||||
%n*,e
|
||||
F*
|
||||
S1
|
||||
movB1 #1(R),(r4)
|
||||
mov R1,mul
|
||||
movB1 (r4),#1(R)
|
||||
mov (r4),R
|
||||
|
||||
%e*,n
|
||||
S
|
||||
F1*
|
||||
movB1 #1(R1),(r4)
|
||||
mov R,mul
|
||||
movB1 (r4),#1(R1)
|
||||
mov (r4),R
|
||||
|
||||
%n*,n
|
||||
FS*
|
||||
S
|
||||
movB1 *(sp),(r4)
|
||||
mov R,mul
|
||||
movB1 (r4),*(sp)+
|
||||
mov (r4),R
|
||||
|
||||
/ =mod, =/
|
||||
cr73:
|
||||
%a,a
|
||||
movB1 A1,(r4)
|
||||
movB2 A2,div
|
||||
movB1 I,A1
|
||||
mov I,R
|
||||
|
||||
%a,n
|
||||
S
|
||||
movB1 A1,(r4)
|
||||
mov R,div
|
||||
mov I,R
|
||||
movB1 R,A1
|
||||
|
||||
%n*,a
|
||||
F*
|
||||
movB1 #1(R),(r4)
|
||||
movB2 A2,div
|
||||
movB1 I,#1(R)
|
||||
mov I,R
|
||||
|
||||
%n*,e
|
||||
F*
|
||||
S1
|
||||
movB1 #1(R),(r4)
|
||||
mov R1,div
|
||||
movB1 I,#1(R)
|
||||
mov I,R
|
||||
|
||||
%e*,n
|
||||
S
|
||||
F1*
|
||||
movB1 #1(R1),(r4)
|
||||
mov R,div
|
||||
movB1 I,#1(R1)
|
||||
mov I,R
|
||||
|
||||
%n*,n
|
||||
FS*
|
||||
S
|
||||
movB1 *(sp),(r4)
|
||||
mov R,div
|
||||
movB1 I,*(sp)+
|
||||
mov I,R
|
||||
|
||||
/ =|
|
||||
cr78:
|
||||
%a,a
|
||||
bisBE A2,A1
|
||||
movB1 A1,R
|
||||
|
||||
%a,n
|
||||
S
|
||||
bisB1 R,A1
|
||||
movB1 A1,R
|
||||
|
||||
%n*,a
|
||||
F*
|
||||
bisBE A2,#1(R)
|
||||
movB1 #1(R),R
|
||||
|
||||
%e*,n*
|
||||
S*
|
||||
F1*
|
||||
bisBE #1(R1),#2(R)
|
||||
movB1 #2(R),R
|
||||
|
||||
%e*,n
|
||||
S
|
||||
F1*
|
||||
bisBE R,#1(R1)
|
||||
movB1 #1(R1),R
|
||||
|
||||
%n*,e*
|
||||
F*
|
||||
S1*
|
||||
bisBE #2(R1),#1(R)
|
||||
movB1 #1(R),R
|
||||
|
||||
%n*,e
|
||||
F*
|
||||
S1
|
||||
bisBE R1,#1(R)
|
||||
movB2 #1(R),R
|
||||
|
||||
%n*,n*
|
||||
FS*
|
||||
S*
|
||||
bisBE #2(R),*(sp)
|
||||
movB2 *(sp)+,R
|
||||
|
||||
%n*,n
|
||||
FS*
|
||||
S
|
||||
bisBE R,*(sp)
|
||||
mov *(sp)+,R
|
||||
|
||||
/ =&
|
||||
cr77:
|
||||
%a,c
|
||||
bicB1 $!C2,A1
|
||||
movB2 A1,R
|
||||
|
||||
%a,n
|
||||
S
|
||||
com R
|
||||
bicB1 R,A1
|
||||
movB1 A1,R
|
||||
|
||||
%e*,n
|
||||
S
|
||||
F1*
|
||||
com R
|
||||
bicB1 R,#1(R1)
|
||||
movB1 #1(R1),R
|
||||
|
||||
%n*,e
|
||||
F*
|
||||
S1
|
||||
com R1
|
||||
bicB1 R1,#1(R)
|
||||
movB1 #1(R),R
|
||||
|
||||
%n*,n
|
||||
FS*
|
||||
S
|
||||
com R
|
||||
bicB1 R,*(sp)
|
||||
movB1 *(sp)+,R
|
||||
|
||||
/ =>>, =<<
|
||||
cr75:
|
||||
%a,aw
|
||||
movB1 A1,I'
|
||||
I A2,lsh
|
||||
movB1 I',A1
|
||||
movB1 I',R
|
||||
|
||||
%a,n
|
||||
S
|
||||
movB1 A1,I'
|
||||
I R,lsh
|
||||
movB1 I',A1
|
||||
movB1 I',R
|
||||
|
||||
%n*,e
|
||||
F*
|
||||
S1
|
||||
movB1 #1(R),I'
|
||||
I R1,lsh
|
||||
movB1 I',#1(R)
|
||||
movB1 I',R
|
||||
|
||||
%e*,n
|
||||
S
|
||||
F1*
|
||||
movB1 #1(R1),I'
|
||||
I R,lsh
|
||||
movB I',#1(R1)
|
||||
movB1 I',R
|
||||
|
||||
%n*,n
|
||||
FS*
|
||||
S
|
||||
movB1 *(sp),I'
|
||||
I R,lsh
|
||||
movB1 I',*(sp)+
|
||||
movB1 I',R
|
||||
|
||||
/ =+
|
||||
cr70:
|
||||
%aw,aw
|
||||
I A2,A1
|
||||
mov A1,R
|
||||
|
||||
%aw,nw*
|
||||
S*
|
||||
I #2(R),A1
|
||||
mov A1,R
|
||||
|
||||
%aw,n
|
||||
S
|
||||
I R,A1
|
||||
mov A1,R
|
||||
|
||||
%ew*,nw*
|
||||
S*
|
||||
F1*
|
||||
I #2(R),#1(R1)
|
||||
mov #1(R1),R
|
||||
|
||||
%a,nw*
|
||||
S*
|
||||
movB1 A1,R1
|
||||
I #2(R),R1
|
||||
movB1 R1,#2(R)
|
||||
mov R1,R
|
||||
|
||||
%a,n
|
||||
S
|
||||
movB1 A1,R1
|
||||
I R1,R
|
||||
movB1 R,A1
|
||||
|
||||
%ew*,n
|
||||
S
|
||||
F1*
|
||||
I R,#1(R1)
|
||||
mov #1(R1),R
|
||||
|
||||
%nw*,n
|
||||
SS
|
||||
F*
|
||||
I (sp)+,#1(R)
|
||||
mov #1(R),R
|
||||
|
||||
%n*,n
|
||||
SS
|
||||
F*
|
||||
movB1 #1(R),R1
|
||||
I (sp)+,R1
|
||||
movB1 R1,#1(R)
|
||||
mov R1,R
|
||||
|
||||
/ int -> int[]
|
||||
cr97:
|
||||
%n,n
|
||||
F
|
||||
asl R
|
||||
|
||||
.data
|
||||
.even
|
||||
.text
|
||||
|
167
last1120c/sptab.s
Normal file
167
last1120c/sptab.s
Normal file
@ -0,0 +1,167 @@
|
||||
/ c code tables-- expression to -(sp)
|
||||
|
||||
.globl _sptab
|
||||
|
||||
_sptab=.;.+2
|
||||
20.; cs20
|
||||
21.; cs21
|
||||
22.; cs21
|
||||
30.; cs30
|
||||
31.; cs30
|
||||
32.; cs32
|
||||
33.; cs32
|
||||
35.; cs35
|
||||
36.; cs36
|
||||
40.; cs40
|
||||
41.; cs40
|
||||
42.; cs42
|
||||
47.; cs47
|
||||
48.; cs48
|
||||
0
|
||||
|
||||
|
||||
/ name
|
||||
cs20:
|
||||
%aw,n
|
||||
mov A,-(sp)
|
||||
|
||||
/ constant
|
||||
cs21:
|
||||
%z,n
|
||||
clr -(sp)
|
||||
|
||||
%a,n
|
||||
mov A,-(sp)
|
||||
|
||||
/ ++,-- prefix
|
||||
cs30:
|
||||
%ai,n
|
||||
%abp,n
|
||||
I A1
|
||||
mov A1,-(sp)
|
||||
|
||||
%aw,n
|
||||
I' $2,A1
|
||||
mov A1,-(sp)
|
||||
|
||||
%nbp*,n
|
||||
%ni*,n
|
||||
F*
|
||||
I #1(R)
|
||||
mov #1(R),-(sp)
|
||||
|
||||
%nip*,n
|
||||
F*
|
||||
mov #1(R),-(sp)
|
||||
I' $2,#1(R)
|
||||
|
||||
/ ++,-- postfix
|
||||
cs32:
|
||||
%ai,n
|
||||
%abp,n
|
||||
mov A1,-(sp)
|
||||
I A1
|
||||
|
||||
%aip,n
|
||||
mov A1,-(sp)
|
||||
I' $2,A1
|
||||
|
||||
%nbp*,n
|
||||
%ni*,n
|
||||
F*
|
||||
mov #1(R),-(sp)
|
||||
I #1(R)
|
||||
|
||||
%nip*,n
|
||||
F*
|
||||
mov #1(R),-(sp)
|
||||
I' $2,#1(R)
|
||||
|
||||
/ & unary
|
||||
cs35:
|
||||
%i,n
|
||||
mov $A1,-(sp)
|
||||
|
||||
/ * unary
|
||||
cs36:
|
||||
%aw,n
|
||||
mov *A1,-(sp)
|
||||
|
||||
%nw*,n
|
||||
F*
|
||||
mov #1(R),-(sp)
|
||||
|
||||
/ +
|
||||
cs40:
|
||||
%n,aw
|
||||
FS
|
||||
I A2,(sp)
|
||||
|
||||
%n,nw*
|
||||
FS
|
||||
S*
|
||||
I #2(R),(sp)
|
||||
|
||||
%n,n
|
||||
FS
|
||||
S
|
||||
I R,(sp)
|
||||
|
||||
/ *
|
||||
cs42:
|
||||
%aw,a
|
||||
mov A1,(r4)+
|
||||
movB2 A2,(r4)
|
||||
mov -(r4),-(sp)
|
||||
|
||||
%n,a
|
||||
F
|
||||
mov R,(r4)+
|
||||
movB2 A2,(r4)
|
||||
mov -(r4),-(sp)
|
||||
|
||||
%n,nw*
|
||||
FS
|
||||
S*
|
||||
mov (sp)+,(r4)+
|
||||
mov #2(R),(r4)
|
||||
mov -(r4),-(sp)
|
||||
|
||||
%n,n
|
||||
FS
|
||||
S
|
||||
mov (sp)+,(r4)+
|
||||
mov R,(r4)
|
||||
mov -(r4),-(sp)
|
||||
|
||||
/ &
|
||||
cs47:
|
||||
%n,c
|
||||
FS
|
||||
bic $!C2,(sp)
|
||||
|
||||
%n,n
|
||||
FS
|
||||
S
|
||||
com R
|
||||
bic R,(sp)
|
||||
|
||||
/ |
|
||||
cs48:
|
||||
%n,a
|
||||
FS
|
||||
bisB2 A2,(sp)
|
||||
|
||||
%n,n*
|
||||
FS
|
||||
S*
|
||||
bisB2 #2(R),(sp)
|
||||
|
||||
%n,n
|
||||
FS
|
||||
S
|
||||
bis R,(sp)
|
||||
|
||||
.data
|
||||
.even
|
||||
.text
|
776
prestruct/c00.c
Normal file
776
prestruct/c00.c
Normal file
@ -0,0 +1,776 @@
|
||||
/* C compiler
|
||||
|
||||
Copyright 1972 Bell Telephone Laboratories, Inc.
|
||||
|
||||
*/
|
||||
|
||||
init(s, t)
|
||||
char s[]; {
|
||||
extern symbuf, namsiz;
|
||||
char symbuf[], sp[];
|
||||
int np[], i;
|
||||
|
||||
i = namsiz;
|
||||
sp = symbuf;
|
||||
while(i--)
|
||||
if ((*sp++ = *s++)=='\0') --s;
|
||||
np = lookup();
|
||||
*np++ = 1;
|
||||
*np = t;
|
||||
}
|
||||
|
||||
main(argc, argv)
|
||||
int argv[]; {
|
||||
extern extdef, eof;
|
||||
extern fout, fin, nerror, tmpfil, xdflg;
|
||||
|
||||
if(argc<4) {
|
||||
error("Arg count");
|
||||
exit(1);
|
||||
}
|
||||
if((fin=open(argv[1],0))<0) {
|
||||
error("Can't find %s", argv[1]);
|
||||
exit(1);
|
||||
}
|
||||
if((fout=creat(argv[2], 017))<0) {
|
||||
error("Can't create %s", argv[2]);
|
||||
exit(1);
|
||||
}
|
||||
tmpfil = argv[3];
|
||||
xdflg++;
|
||||
init("int", 0);
|
||||
init("char", 1);
|
||||
init("float", 2);
|
||||
init("double", 3);
|
||||
init("struct", 4);
|
||||
init("auto", 5);
|
||||
init("extern", 6);
|
||||
init("static", 7);
|
||||
init("goto", 10);
|
||||
init("return", 11);
|
||||
init("if", 12);
|
||||
init("while", 13);
|
||||
init("else", 14);
|
||||
init("switch", 15);
|
||||
init("case", 16);
|
||||
init("break", 17);
|
||||
init("continue", 18);
|
||||
init("do", 19);
|
||||
init("default", 20);
|
||||
xdflg = 0;
|
||||
while(!eof) {
|
||||
extdef();
|
||||
blkend();
|
||||
}
|
||||
flush();
|
||||
flshw();
|
||||
exit(nerror!=0);
|
||||
}
|
||||
|
||||
lookup() {
|
||||
extern hshtab, hshsiz, pssiz, symbuf, xdflg;
|
||||
int hshtab[], symbuf[];
|
||||
extern hshlen, hshused, nwps;
|
||||
auto i, j, np[], sp[], rp[];
|
||||
|
||||
i = 0;
|
||||
sp = symbuf;
|
||||
j = nwps;
|
||||
while(j--)
|
||||
i =+ *sp++ & 077577;
|
||||
if (i<0) i = -i;
|
||||
i =% hshsiz;
|
||||
i =* pssiz;
|
||||
while(*(np = &hshtab[i+4])) {
|
||||
sp = symbuf;
|
||||
j = nwps;
|
||||
while(j--)
|
||||
if ((*np++&077577) != *sp++) goto no;
|
||||
return(&hshtab[i]);
|
||||
no: if ((i =+ pssiz) >= hshlen) i = 0;
|
||||
}
|
||||
if(++hshused > hshsiz) {
|
||||
error("Symbol table overflow");
|
||||
exit(1);
|
||||
}
|
||||
rp = np = &hshtab[i];
|
||||
sp = symbuf;
|
||||
j = 4;
|
||||
while(j--)
|
||||
*np++ = 0;
|
||||
j = nwps;
|
||||
while(j--)
|
||||
*np++ = *sp++;
|
||||
*np = 0;
|
||||
if (xdflg)
|
||||
rp[4] =| 0200; /* mark non-deletable */
|
||||
return(rp);
|
||||
}
|
||||
|
||||
symbol() {
|
||||
extern peeksym, peekc, eof, line;
|
||||
extern csym, symbuf, namsiz, lookup, ctab, cval;
|
||||
int csym[];
|
||||
extern isn, mosflg, xdflg;
|
||||
auto b, c;
|
||||
char symbuf[], sp[], ctab[];
|
||||
|
||||
if (peeksym>=0) {
|
||||
c = peeksym;
|
||||
peeksym = -1;
|
||||
if (c==20)
|
||||
mosflg = 0;
|
||||
return(c);
|
||||
}
|
||||
if (peekc) {
|
||||
c = peekc;
|
||||
peekc = 0;
|
||||
} else
|
||||
if (eof)
|
||||
return(0); else
|
||||
c = getchar();
|
||||
loop:
|
||||
switch(ctab[c]) {
|
||||
|
||||
case 125: /* newline */
|
||||
line++;
|
||||
|
||||
case 126: /* white space */
|
||||
c = getchar();
|
||||
goto loop;
|
||||
|
||||
case 0: /* EOF */
|
||||
eof++;
|
||||
return(0);
|
||||
|
||||
case 40: /* + */
|
||||
return(subseq(c,40,30));
|
||||
|
||||
case 41: /* - */
|
||||
return(subseq(c,subseq('>',41,50),31));
|
||||
|
||||
case 80: /* = */
|
||||
if (subseq(' ',0,1)) return(80);
|
||||
c = symbol();
|
||||
if (c>=40 & c<=49)
|
||||
return(c+30);
|
||||
if (c==80)
|
||||
return(60);
|
||||
peeksym = c;
|
||||
return(80);
|
||||
|
||||
case 63: /* < */
|
||||
if (subseq(c,0,1)) return(46);
|
||||
return(subseq('=',63,62));
|
||||
|
||||
case 65: /* > */
|
||||
if (subseq(c,0,1)) return(45);
|
||||
return(subseq('=',65,64));
|
||||
|
||||
case 34: /* ! */
|
||||
return(subseq('=',34,61));
|
||||
|
||||
case 43: /* / */
|
||||
if (subseq('*',1,0))
|
||||
return(43);
|
||||
com:
|
||||
c = getchar();
|
||||
com1:
|
||||
if (c=='\0') {
|
||||
eof++;
|
||||
error("Nonterminated comment");
|
||||
return(0);
|
||||
}
|
||||
if (c=='\n')
|
||||
line++;
|
||||
if (c!='*')
|
||||
goto com;
|
||||
c = getchar();
|
||||
if (c!='/')
|
||||
goto com1;
|
||||
c = getchar();
|
||||
goto loop;
|
||||
|
||||
case 120: /* . */
|
||||
case 124: /* number */
|
||||
peekc = c;
|
||||
switch(c=getnum(c=='0'? 8:10)) {
|
||||
case 25: /* float 0 */
|
||||
c = 23;
|
||||
break;
|
||||
|
||||
case 23: /* float non 0 */
|
||||
cval = isn++;
|
||||
}
|
||||
return(c);
|
||||
|
||||
case 122: /* " */
|
||||
return(getstr());
|
||||
|
||||
case 121: /* ' */
|
||||
return(getcc());
|
||||
|
||||
case 123: /* letter */
|
||||
sp = symbuf;
|
||||
if (mosflg) {
|
||||
*sp++ = '.';
|
||||
mosflg = 0;
|
||||
}
|
||||
while(ctab[c]==123 | ctab[c]==124) {
|
||||
if (sp<symbuf+namsiz) *sp++ = c;
|
||||
c = getchar();
|
||||
}
|
||||
while(sp<symbuf+namsiz)
|
||||
*sp++ = '\0';
|
||||
peekc = c;
|
||||
csym = lookup();
|
||||
if (csym[0]==1) { /* keyword */
|
||||
cval = csym[1];
|
||||
return(19);
|
||||
}
|
||||
return(20);
|
||||
|
||||
case 127: /* unknown */
|
||||
error("Unknown character");
|
||||
c = getchar();
|
||||
goto loop;
|
||||
|
||||
}
|
||||
return(ctab[c]);
|
||||
}
|
||||
|
||||
subseq(c,a,b) {
|
||||
extern peekc;
|
||||
|
||||
if (!peekc)
|
||||
peekc = getchar();
|
||||
if (peekc != c)
|
||||
return(a);
|
||||
peekc = 0;
|
||||
return(b);
|
||||
}
|
||||
getstr() {
|
||||
extern isn, cval, strflg;
|
||||
auto c;
|
||||
char t[], d[];
|
||||
|
||||
t = ".text";
|
||||
d = ".data";
|
||||
printf("%s;L%d:.byte ", (strflg?t:d), cval=isn++);
|
||||
while((c=mapch('"')) >= 0)
|
||||
printf("%o,", c);
|
||||
printf("0;.even;%s\n", (strflg?d:t));
|
||||
return(22);
|
||||
}
|
||||
|
||||
getcc()
|
||||
{
|
||||
extern cval, ncpw;
|
||||
auto c, cc;
|
||||
char cp[];
|
||||
|
||||
cval = 0;
|
||||
cp = &cval;
|
||||
cc = 0;
|
||||
while((c=mapch('\'')) >= 0)
|
||||
if(cc++ < ncpw)
|
||||
*cp++ = c;
|
||||
if(cc>ncpw)
|
||||
error("Long character constant");
|
||||
return(21);
|
||||
}
|
||||
|
||||
mapch(c)
|
||||
{
|
||||
extern peekc, line;
|
||||
auto a;
|
||||
|
||||
if((a=getchar())==c)
|
||||
return(-1);
|
||||
switch(a) {
|
||||
|
||||
case '\n':
|
||||
case 0:
|
||||
error("Nonterminated string");
|
||||
peekc = a;
|
||||
return(-1);
|
||||
|
||||
case '\\':
|
||||
switch (a=getchar()) {
|
||||
|
||||
case 't':
|
||||
return('\t');
|
||||
|
||||
case 'n':
|
||||
return('\n');
|
||||
|
||||
case '0':
|
||||
return('\0');
|
||||
|
||||
case 'r':
|
||||
return('\r');
|
||||
|
||||
case '\n':
|
||||
line++;
|
||||
return('\n');
|
||||
}
|
||||
|
||||
}
|
||||
return(a);
|
||||
}
|
||||
|
||||
tree() {
|
||||
extern csym, ctyp, isn, fcval, peeksym, opdope, cp, cmst;
|
||||
int csym[], opdope[], cp[], cmst[];
|
||||
extern space, cval, ossiz, cmsiz, mosflg, osleft;
|
||||
double fcval;
|
||||
int space[];
|
||||
|
||||
int op[], opst[20], pp[], prst[20], andflg, o,
|
||||
p, ps, os;
|
||||
|
||||
osleft = ossiz;
|
||||
space = 0;
|
||||
*space++ = 0;
|
||||
op = opst;
|
||||
pp = prst;
|
||||
cp = cmst;
|
||||
*op = 200; /* stack EOF */
|
||||
*pp = 06;
|
||||
andflg = 0;
|
||||
|
||||
advanc:
|
||||
switch (o=symbol()) {
|
||||
|
||||
/* name */
|
||||
case 20:
|
||||
if (*csym==0)
|
||||
if((peeksym=symbol())==6) { /* ( */
|
||||
*csym = 6; /* extern */
|
||||
csym[1] = 020; /* int() */
|
||||
} else {
|
||||
csym[1] = 030; /* array */
|
||||
if (csym[2]==0)
|
||||
csym[2] = isn++;
|
||||
}
|
||||
*cp++ = block(2,20,csym[1],csym[3],*csym,0);
|
||||
if (*csym==6) { /* external */
|
||||
o = 3;
|
||||
while(++o<8) {
|
||||
pblock(csym[o]);
|
||||
if ((csym[o]&077400) == 0)
|
||||
break;
|
||||
}
|
||||
} else
|
||||
pblock(csym[2]);
|
||||
goto tand;
|
||||
|
||||
/* short constant */
|
||||
case 21:
|
||||
case21:
|
||||
*cp++ = block(1,21,ctyp,0,cval);
|
||||
goto tand;
|
||||
|
||||
/* floating constant */
|
||||
case 23:
|
||||
*cp++ = block(1,23,3,0,cval);
|
||||
if (cval) /* non-0 */
|
||||
printf(".data;L%d:%o;%o;%o;%o;.text\n",cval,fcval);
|
||||
goto tand;
|
||||
|
||||
/* string constant: fake a static char array */
|
||||
case 22:
|
||||
*cp++ = block(3, 20, 031, 1, 7, 0, cval);
|
||||
|
||||
tand:
|
||||
if(cp>=cmst+cmsiz) {
|
||||
error("Expression overflow");
|
||||
exit(1);
|
||||
}
|
||||
if (andflg)
|
||||
goto syntax;
|
||||
andflg = 1;
|
||||
goto advanc;
|
||||
|
||||
/* ++, -- */
|
||||
case 30:
|
||||
case 31:
|
||||
if (andflg)
|
||||
o =+ 2;
|
||||
goto oponst;
|
||||
|
||||
/* ! */
|
||||
case 34:
|
||||
/* ~ */
|
||||
case 38:
|
||||
if (andflg)
|
||||
goto syntax;
|
||||
goto oponst;
|
||||
|
||||
/* - */
|
||||
case 41:
|
||||
if (!andflg) {
|
||||
peeksym = symbol();
|
||||
if (peeksym==21) {
|
||||
peeksym = -1;
|
||||
cval = -cval;
|
||||
goto case21;
|
||||
}
|
||||
o = 37;
|
||||
}
|
||||
andflg = 0;
|
||||
goto oponst;
|
||||
|
||||
/* & */
|
||||
/* * */
|
||||
case 47:
|
||||
case 42:
|
||||
if (andflg)
|
||||
andflg = 0; else
|
||||
if(o==47)
|
||||
o = 35;
|
||||
else
|
||||
o = 36;
|
||||
goto oponst;
|
||||
|
||||
/* ( */
|
||||
case 6:
|
||||
if (andflg) {
|
||||
o = symbol();
|
||||
if (o==7)
|
||||
o = 101; else {
|
||||
peeksym = o;
|
||||
o = 100;
|
||||
andflg = 0;
|
||||
}
|
||||
}
|
||||
goto oponst;
|
||||
|
||||
/* ) */
|
||||
/* ] */
|
||||
case 5:
|
||||
case 7:
|
||||
if (!andflg)
|
||||
goto syntax;
|
||||
goto oponst;
|
||||
|
||||
case 39: /* . */
|
||||
mosflg++;
|
||||
break;
|
||||
|
||||
}
|
||||
/* binaries */
|
||||
if (!andflg)
|
||||
goto syntax;
|
||||
andflg = 0;
|
||||
|
||||
oponst:
|
||||
p = (opdope[o]>>9) & 077;
|
||||
opon1:
|
||||
ps = *pp;
|
||||
if (p>ps | p==ps & (opdope[o]&0200)!=0) { /* right-assoc */
|
||||
putin:
|
||||
switch (o) {
|
||||
|
||||
case 6: /* ( */
|
||||
case 4: /* [ */
|
||||
case 100: /* call */
|
||||
p = 04;
|
||||
}
|
||||
if(op>=opst+20) { /* opstack size */
|
||||
error("expression overflow");
|
||||
exit(1);
|
||||
}
|
||||
*++op = o;
|
||||
*++pp = p;
|
||||
goto advanc;
|
||||
}
|
||||
--pp;
|
||||
switch (os = *op--) {
|
||||
|
||||
/* EOF */
|
||||
case 200:
|
||||
peeksym = o;
|
||||
return(*--cp);
|
||||
|
||||
/* call */
|
||||
case 100:
|
||||
if (o!=7)
|
||||
goto syntax;
|
||||
build(os);
|
||||
goto advanc;
|
||||
|
||||
/* mcall */
|
||||
case 101:
|
||||
*cp++ = block(0,0,0,0); /* 0 arg call */
|
||||
os = 100;
|
||||
goto fbuild;
|
||||
|
||||
/* ( */
|
||||
case 6:
|
||||
if (o!=7)
|
||||
goto syntax;
|
||||
goto advanc;
|
||||
|
||||
/* [ */
|
||||
case 4:
|
||||
if (o!=5)
|
||||
goto syntax;
|
||||
build(4);
|
||||
goto advanc;
|
||||
}
|
||||
fbuild:
|
||||
build(os);
|
||||
goto opon1;
|
||||
|
||||
syntax:
|
||||
error("Expression syntax");
|
||||
errflush(o);
|
||||
return(0);
|
||||
}
|
||||
|
||||
scdeclare(kw)
|
||||
{
|
||||
extern csym, paraml, parame, peeksym;
|
||||
int csym[], paraml[], parame[];
|
||||
int o;
|
||||
|
||||
while((o=symbol())==20) { /* name */
|
||||
if(*csym>0 & *csym!=kw)
|
||||
redec();
|
||||
*csym = kw;
|
||||
if(kw==8) { /* parameter */
|
||||
*csym = -1;
|
||||
if (paraml==0)
|
||||
paraml = csym;
|
||||
else
|
||||
*parame = csym;
|
||||
parame = csym;
|
||||
}
|
||||
if ((o=symbol())!=9) /* , */
|
||||
break;
|
||||
}
|
||||
if(o==1 & kw!=8 | o==7 & kw==8)
|
||||
return;
|
||||
syntax:
|
||||
decsyn(o);
|
||||
}
|
||||
|
||||
tdeclare(kw, offset, mos)
|
||||
{
|
||||
int o, elsize, ds[];
|
||||
extern xdflg, peeksym, mosflg, defsym, csym;
|
||||
int csym[], ssym[];
|
||||
|
||||
if (kw == 4) { /* struct */
|
||||
ssym = 0;
|
||||
ds = defsym;
|
||||
mosflg = mos;
|
||||
if ((o=symbol())==20) { /* name */
|
||||
ssym = csym;
|
||||
o = symbol();
|
||||
}
|
||||
mosflg = mos;
|
||||
if (o != 6) { /* ( */
|
||||
if (ssym==0)
|
||||
goto syntax;
|
||||
if (*ssym!=8) /* class structname */
|
||||
error("Bad structure name");
|
||||
if (ssym[3]==0) { /* no size yet */
|
||||
kw = 5; /* deferred MOS */
|
||||
elsize = ssym;
|
||||
} else
|
||||
elsize = ssym[3];
|
||||
peeksym = o;
|
||||
} else {
|
||||
if (ssym) {
|
||||
if (*ssym)
|
||||
redec();
|
||||
*ssym = 8;
|
||||
ssym[3] = 0;
|
||||
}
|
||||
elsize = declist(4);
|
||||
if ((elsize&01) != 0)
|
||||
elsize++;
|
||||
defsym = ds;
|
||||
if ((o = symbol()) != 7) /* ) */
|
||||
goto syntax;
|
||||
if (ssym)
|
||||
ssym[3] = elsize;
|
||||
}
|
||||
}
|
||||
mosflg = mos;
|
||||
if ((peeksym=symbol()) == 1) { /* ; */
|
||||
peeksym = -1;
|
||||
mosflg = 0;
|
||||
return(offset);
|
||||
}
|
||||
do {
|
||||
offset =+ t1dec(kw, offset, mos, elsize);
|
||||
if (xdflg & !mos)
|
||||
return;
|
||||
} while ((o=symbol()) == 9); /* , */
|
||||
if (o==1)
|
||||
return(offset);
|
||||
syntax:
|
||||
decsyn(o);
|
||||
}
|
||||
|
||||
t1dec(kw, offset, mos, elsize)
|
||||
{
|
||||
int type, nel, defsym[], t1;
|
||||
extern defsym, mosflg;
|
||||
|
||||
nel = 0;
|
||||
mosflg = mos;
|
||||
if ((t1=getype(&nel)) < 0)
|
||||
goto syntax;
|
||||
type = 0;
|
||||
do
|
||||
type = type<<2 | (t1 & 03);
|
||||
while(t1 =>> 2);
|
||||
t1 = type<<3 | kw;
|
||||
if (defsym[1] & defsym[1]!=t1)
|
||||
redec();
|
||||
defsym[1] = t1;
|
||||
defsym[3] = elsize;
|
||||
elsize = length(defsym);
|
||||
if (mos) {
|
||||
if (*defsym)
|
||||
redec();
|
||||
else
|
||||
*defsym = 4;
|
||||
if ((offset&1)!=0 & elsize!=1)
|
||||
offset++;
|
||||
defsym[2] = offset;
|
||||
} else
|
||||
if (*defsym == 0)
|
||||
*defsym = -2; /* default auto */
|
||||
if (nel==0)
|
||||
nel = 1;
|
||||
defsym[8] = nel;
|
||||
syntax:
|
||||
return(nel*elsize);
|
||||
}
|
||||
|
||||
getype(pnel)
|
||||
int pnel[];
|
||||
{
|
||||
int o, type;
|
||||
extern cval, peeksym, xdflg, defsym, csym, pssiz;
|
||||
int defsym[], csym[];
|
||||
|
||||
switch(o=symbol()) {
|
||||
|
||||
case 42: /* * */
|
||||
return(getype(pnel)<<2 | 01);
|
||||
|
||||
case 6: /* ( */
|
||||
type = getype(pnel);
|
||||
if ((o=symbol()) != 7) /* ) */
|
||||
goto syntax;
|
||||
goto getf;
|
||||
|
||||
case 20: /* name */
|
||||
defsym = csym;
|
||||
type = 0;
|
||||
getf:
|
||||
switch(o=symbol()) {
|
||||
|
||||
case 6: /* ( */
|
||||
if (xdflg) {
|
||||
xdflg = 0;
|
||||
o = defsym;
|
||||
scdeclare(8);
|
||||
defsym = o;
|
||||
xdflg++;
|
||||
} else
|
||||
if ((o=symbol()) != 7) /* ) */
|
||||
goto syntax;
|
||||
type = type<<2 | 02;
|
||||
goto getf;
|
||||
|
||||
case 4: /* [ */
|
||||
if ((o=symbol()) != 5) { /* ] */
|
||||
if (o!=21) /* const */
|
||||
goto syntax;
|
||||
*pnel = cval;
|
||||
if ((o=symbol())!=5)
|
||||
goto syntax;
|
||||
}
|
||||
type = type<<2 | 03;
|
||||
goto getf;
|
||||
}
|
||||
peeksym = o;
|
||||
return(type);
|
||||
}
|
||||
syntax:
|
||||
decsyn(o);
|
||||
return(-1);
|
||||
}
|
||||
|
||||
decsyn(o)
|
||||
{
|
||||
error("Declaration syntax");
|
||||
errflush(o);
|
||||
}
|
||||
|
||||
redec()
|
||||
{
|
||||
extern csym;
|
||||
int csym[];
|
||||
|
||||
error("%p redeclared", &csym[4]);
|
||||
}
|
||||
|
||||
/* storage */
|
||||
|
||||
regtab 0;
|
||||
efftab 1;
|
||||
cctab 2;
|
||||
sptab 3;
|
||||
symbuf[4];
|
||||
pssiz 9;
|
||||
namsiz 8;
|
||||
nwps 4;
|
||||
hshused;
|
||||
hshsiz 100;
|
||||
hshlen 900; /* 9*hshsiz */
|
||||
hshtab[900];
|
||||
space;
|
||||
cp;
|
||||
cmsiz 40;
|
||||
cmst[40];
|
||||
ctyp;
|
||||
isn 1;
|
||||
swsiz 120;
|
||||
swtab[120];
|
||||
swp;
|
||||
contlab;
|
||||
brklab;
|
||||
deflab;
|
||||
nreg 4;
|
||||
nauto;
|
||||
stack;
|
||||
peeksym 0177777;
|
||||
peekc;
|
||||
eof;
|
||||
line 1;
|
||||
defsym;
|
||||
xdflg;
|
||||
csym;
|
||||
cval;
|
||||
fcval 0; /* a double number */
|
||||
fc1 0;
|
||||
fc2 0;
|
||||
fc3 0;
|
||||
ncpw 2;
|
||||
nerror;
|
||||
paraml;
|
||||
parame;
|
||||
tmpfil;
|
||||
strflg;
|
||||
ossiz 250;
|
||||
osleft;
|
||||
mosflg;
|
||||
debug 0;
|
369
prestruct/c01.c
Normal file
369
prestruct/c01.c
Normal file
@ -0,0 +1,369 @@
|
||||
build(op) {
|
||||
extern cp[], cvtab, opdope[], maprel[];
|
||||
auto p1[], t1, d1, p2[], t2, d2, p3[], t3, d3, t;
|
||||
auto d, dope, leftc, cvn, pcvn;
|
||||
char cvtab[];
|
||||
|
||||
if (op==4) { /* [] */
|
||||
build(40); /* + */
|
||||
op = 36; /* * */
|
||||
}
|
||||
dope = opdope[op];
|
||||
if ((dope&01)!=0) { /* binary */
|
||||
p2 = disarray(*--cp);
|
||||
t2 = p2[1];
|
||||
chkfun(p2);
|
||||
d2 = p2[2];
|
||||
if (*p2==20)
|
||||
d2 = 0;
|
||||
}
|
||||
p1 = disarray(*--cp);
|
||||
if (op!=100 & op!=35) /* call, * */
|
||||
chkfun(p1);
|
||||
t1 = p1[1];
|
||||
d1 = p1[2];
|
||||
if (*p1==20)
|
||||
d1 = 0;
|
||||
pcvn = 0;
|
||||
switch (op) {
|
||||
|
||||
/* : */
|
||||
case 8:
|
||||
if (t1!=t2)
|
||||
error("Type clash in conditional");
|
||||
t = t1;
|
||||
goto nocv;
|
||||
|
||||
/* , */
|
||||
case 9:
|
||||
*cp++ = block(2, 9, 0, 0, p1, p2);
|
||||
return;
|
||||
|
||||
/* ? */
|
||||
case 90:
|
||||
if (*p2!=8)
|
||||
error("Illegal conditional");
|
||||
t = t2;
|
||||
goto nocv;
|
||||
|
||||
/* call */
|
||||
case 100:
|
||||
if ((t1&030) != 020)
|
||||
error("Call of non-function");
|
||||
*cp++ = block(2,100,decref(t1),24,p1,p2);
|
||||
return;
|
||||
|
||||
/* * */
|
||||
case 36:
|
||||
if (*p1==35 | *p1==29) { /* & unary */
|
||||
*cp++ = p1[3];
|
||||
return;
|
||||
}
|
||||
if (*p1!=20 & d1==0)
|
||||
d1 = 1;
|
||||
if ((t1&030) == 020) /* function */
|
||||
error("Illegal indirection");
|
||||
*cp++ = block(1,36,decref(t1),d1,p1);
|
||||
return;
|
||||
|
||||
/* & unary */
|
||||
case 35:
|
||||
if (*p1==36) { /* * */
|
||||
*cp++ = p1[3];
|
||||
return;
|
||||
}
|
||||
if (*p1==20) {
|
||||
*cp++ = block(1,p1[3]==5?29:35,incref(t1),1,p1);
|
||||
return;
|
||||
}
|
||||
error("Illegal lvalue");
|
||||
break;
|
||||
|
||||
case 43: /* / */
|
||||
case 44: /* % */
|
||||
case 73: /* =/ */
|
||||
case 74: /* =% */
|
||||
d1++;
|
||||
d2++;
|
||||
|
||||
case 42: /* * */
|
||||
case 72: /* =* */
|
||||
d1++;
|
||||
d2++;
|
||||
break;
|
||||
|
||||
case 30: /* ++ -- pre and post */
|
||||
case 31:
|
||||
case 32:
|
||||
case 33:
|
||||
chklval(p1);
|
||||
*cp++ = block(2,op,t1,max(d1,1),p1,plength(p1));
|
||||
return;
|
||||
|
||||
case 39: /* . (structure ref) */
|
||||
case 50: /* -> (indirect structure ref) */
|
||||
if (p2[0]!=20 | p2[3]!=4) /* not mos */
|
||||
error("Illegal structure ref");
|
||||
*cp++ = p1;
|
||||
t = t2;
|
||||
if ((t&030) == 030) /* array */
|
||||
t = decref(t);
|
||||
setype(p1, t);
|
||||
if (op==39) /* is "." */
|
||||
build(35); /* unary & */
|
||||
*cp++ = block(1,21,7,0,p2[5]);
|
||||
build(40); /* + */
|
||||
if ((t2&030) != 030) /* not array */
|
||||
build(36); /* unary * */
|
||||
return;
|
||||
}
|
||||
if ((dope&02)!=0) /* lvalue needed on left? */
|
||||
chklval(p1);
|
||||
if ((dope&020)!=0) /* word operand on left? */
|
||||
chkw(p1);
|
||||
if ((dope&040)!=0) /* word operand on right? */
|
||||
chkw(p2);
|
||||
if ((dope&01)==0) { /* unary op? */
|
||||
*cp++ = block(1,op,t1,max(d1,1),p1);
|
||||
return;
|
||||
}
|
||||
if (t2==7) {
|
||||
t = t1;
|
||||
p2[1] = 0; /* no int cv for struct */
|
||||
t2 = 0;
|
||||
goto nocv;
|
||||
}
|
||||
cvn = cvtab[11*lintyp(t1)+lintyp(t2)];
|
||||
leftc = cvn&0100;
|
||||
t = leftc? t2:t1;
|
||||
if (op==80 & t1!=4 & t2!=4) { /* = */
|
||||
t = t1;
|
||||
if (leftc | cvn!=1)
|
||||
goto nocv;
|
||||
}
|
||||
if (cvn =& 077) {
|
||||
if (cvn==077) {
|
||||
illcv:
|
||||
error("Illegal conversion");
|
||||
goto nocv;
|
||||
}
|
||||
if (cvn>4 & cvn<10) { /* ptr conv */
|
||||
t = 0; /* integer result */
|
||||
cvn = 0;
|
||||
if ((dope&04)!=0) /* relational? */
|
||||
goto nocv;
|
||||
if (op!=41) /* - */
|
||||
goto illcv;
|
||||
pcvn = cvn;
|
||||
goto nocv;
|
||||
}
|
||||
if (leftc) {
|
||||
if ((dope&010) != 0) { /* =op */
|
||||
if (cvn == 1) {
|
||||
leftc = 0;
|
||||
cvn = 8;
|
||||
t = t1;
|
||||
goto rcvt;
|
||||
} else
|
||||
goto illcv;
|
||||
}
|
||||
d1 = (p1=convert(p1, t, d1, cvn, plength(p2)))[2];
|
||||
} else {
|
||||
rcvt:
|
||||
d2 = (p2=convert(p2, t, d2, cvn, plength(p1)))[2];
|
||||
}
|
||||
nocv:; }
|
||||
if (d1==d2)
|
||||
d = d1+1; else
|
||||
d = max(d1,d2);
|
||||
if ((dope&04)!=0) { /* relational? */
|
||||
if (op>61 & t>=010)
|
||||
op =+ 4; /* ptr relation */
|
||||
t = 0; /* relational is integer */
|
||||
}
|
||||
*cp++ = optim(block(2,op,t,d,p1,p2));
|
||||
if (pcvn) {
|
||||
p1 = *--cp;
|
||||
*cp++ = block(1,50+pcvn,0,d,p1);
|
||||
}
|
||||
return;
|
||||
*cp++ = block(1,op,t1,d1==0?1:d1,p1);
|
||||
}
|
||||
|
||||
setype(p, t)
|
||||
int p[];
|
||||
{
|
||||
int p1[];
|
||||
|
||||
if ((p[1]&07) != 4) /* not structure */
|
||||
return;
|
||||
p[1] = t;
|
||||
switch(*p) {
|
||||
|
||||
case 29: /* & */
|
||||
case 35:
|
||||
setype(p[3], decref(t));
|
||||
return;
|
||||
|
||||
case 36: /* * */
|
||||
setype(p[3], incref(t));
|
||||
return;
|
||||
|
||||
case 40: /* + */
|
||||
setype(p[4], t);
|
||||
}
|
||||
}
|
||||
|
||||
chkfun(p)
|
||||
int p[];
|
||||
{
|
||||
if ((p[1]&030)==020) /* func */
|
||||
error("Illegal use of function");
|
||||
}
|
||||
|
||||
optim(p)
|
||||
int p[];
|
||||
{
|
||||
int p1[], p2[], t;
|
||||
|
||||
if (*p != 40) /* + */
|
||||
return(p);
|
||||
p1 = p[3];
|
||||
p2 = p[4];
|
||||
if (*p1==21) { /* const */
|
||||
t = p1;
|
||||
p1 = p2;
|
||||
p2 = t;
|
||||
}
|
||||
if (*p2 != 21) /* const */
|
||||
return(p);
|
||||
if ((t=p2[3]) == 0) /* const 0 */
|
||||
return(p1);
|
||||
if (*p1!=35 & *p1!=29) /* not & */
|
||||
return(p);
|
||||
p2 = p1[3];
|
||||
if (*p2!=20) { /* name? */
|
||||
error("C error (optim)");
|
||||
return(p);
|
||||
}
|
||||
p2[4] =+ t;
|
||||
return(p1);
|
||||
}
|
||||
|
||||
disarray(p)
|
||||
int p[];
|
||||
{
|
||||
extern cp;
|
||||
int t, cp[];
|
||||
|
||||
if (((t = p[1]) & 030)!=030 | p[0]==20&p[3]==4) /* array & not MOS */
|
||||
return(p);
|
||||
p[1] = decref(t);
|
||||
*cp++ = p;
|
||||
build(35); /* add & */
|
||||
return(*--cp);
|
||||
}
|
||||
|
||||
convert(p, t, d, cvn, len)
|
||||
int p[];
|
||||
{
|
||||
int c, p1[];
|
||||
|
||||
if (*p==21) { /* constant */
|
||||
c = p[3];
|
||||
switch(cvn) {
|
||||
|
||||
case 4: /* int -> double[] */
|
||||
c =<< 1;
|
||||
|
||||
case 3: /* int -> float[] */
|
||||
c =<< 1;
|
||||
|
||||
case 2: /* int -> int[] */
|
||||
c =<< 1;
|
||||
p[3] = c;
|
||||
return(p);
|
||||
|
||||
case 10: /* i -> s[] */
|
||||
p[3] = c*len;
|
||||
return(p);
|
||||
}
|
||||
}
|
||||
if (cvn==10) /* i -> s[]; retrun i*len */
|
||||
return(block(2,42,t,d+2,p,block(1,21,0,0,len)));
|
||||
return(block(1, 50+cvn, t, max(1,d), p));
|
||||
}
|
||||
|
||||
chkw(p)
|
||||
int p[]; {
|
||||
extern error;
|
||||
auto t;
|
||||
|
||||
if ((t=p[1])>1 & t<=07)
|
||||
error("Integer operand required");
|
||||
return;
|
||||
}
|
||||
|
||||
lintyp(t)
|
||||
{
|
||||
if (t<=07)
|
||||
return(t);
|
||||
if ((t&037)==t)
|
||||
return((t&07)+5);
|
||||
return(10);
|
||||
}
|
||||
|
||||
error(s, p1, p2, p3, p4, p5, p6) {
|
||||
extern line, fout, nerror;
|
||||
int f;
|
||||
|
||||
nerror++;
|
||||
flush();
|
||||
f = fout;
|
||||
fout = 1;
|
||||
printf("%d: ", line);
|
||||
printf(s, p1, p2, p3, p4, p5, p6);
|
||||
putchar('\n');
|
||||
fout = f;
|
||||
}
|
||||
|
||||
block(n, op, t, d, p1,p2,p3)
|
||||
int p1[],p2[],p3[]; {
|
||||
int p[], ap[], space[];
|
||||
extern space;
|
||||
|
||||
ap = &op;
|
||||
n =+ 3;
|
||||
p = space;
|
||||
while(n--)
|
||||
pblock(*ap++);
|
||||
return(p);
|
||||
}
|
||||
|
||||
pblock(p)
|
||||
{
|
||||
extern space, osleft;
|
||||
int space[];
|
||||
|
||||
*space++ = p;
|
||||
if (--osleft<=0) {
|
||||
error("Expression overflow");
|
||||
exit(1);
|
||||
}
|
||||
}
|
||||
|
||||
chklval(p)
|
||||
int p[]; {
|
||||
extern error;
|
||||
|
||||
if (*p!=20 & *p !=36)
|
||||
error("Lvalue required");
|
||||
}
|
||||
|
||||
max(a, b)
|
||||
{
|
||||
if (a>b)
|
||||
return(a);
|
||||
return(b);
|
||||
}
|
||||
|
505
prestruct/c02.c
Normal file
505
prestruct/c02.c
Normal file
@ -0,0 +1,505 @@
|
||||
extdef() {
|
||||
extern eof, cval, defsym;
|
||||
extern csym, strflg, xdflg, peeksym, fcval;
|
||||
int o, c, cs[], type, csym[], width, nel, ninit, defsym[];
|
||||
char s[];
|
||||
float sf;
|
||||
double fcval;
|
||||
|
||||
if(((o=symbol())==0) | o==1) /* EOF */
|
||||
return;
|
||||
type = 0;
|
||||
if (o==19) { /* keyword */
|
||||
if ((type=cval)>4)
|
||||
goto syntax; /* not type */
|
||||
} else {
|
||||
if (o==20)
|
||||
csym[4] =| 0200; /* remember name */
|
||||
peeksym = o;
|
||||
}
|
||||
defsym = 0;
|
||||
xdflg++;
|
||||
tdeclare(type, 0, 0);
|
||||
if (defsym==0)
|
||||
return;
|
||||
*defsym = 6;
|
||||
cs = &defsym[4];
|
||||
printf(".globl %p\n", cs);
|
||||
strflg = 1;
|
||||
xdflg = 0;
|
||||
type = defsym[1];
|
||||
if ((type&030)==020) { /* a function */
|
||||
printf(".text\n%p:\nmov r5,-(sp); mov sp,r5\n", cs);
|
||||
declist(0);
|
||||
strflg = 0;
|
||||
c = 0;
|
||||
if ((peeksym=symbol())!=2) { /* { */
|
||||
blkhed();
|
||||
c++;
|
||||
}
|
||||
statement(1);
|
||||
retseq();
|
||||
if (c)
|
||||
blkend();
|
||||
return;
|
||||
}
|
||||
width = length(defsym);
|
||||
if ((type&030)==030) /* array */
|
||||
width = plength(defsym);
|
||||
nel = defsym[8];
|
||||
ninit = 0;
|
||||
if ((peeksym=symbol()) == 1) { /* ; */
|
||||
printf(".comm %p,%o\n", &defsym[4], nel*width);
|
||||
peeksym = -1;
|
||||
return;
|
||||
}
|
||||
printf(".data\n%p:", &defsym[4]);
|
||||
loop: {
|
||||
ninit++;
|
||||
switch(o=symbol()) {
|
||||
|
||||
case 22: /* string */
|
||||
if (width!=2)
|
||||
bxdec();
|
||||
printf("L%d\n", cval);
|
||||
break;
|
||||
|
||||
case 41: /* - const */
|
||||
if ((o=symbol())==23) { /* float */
|
||||
fcval = -fcval;
|
||||
goto case23;
|
||||
}
|
||||
if (o!=21)
|
||||
goto syntax;
|
||||
cval = -cval;
|
||||
|
||||
case 21: /* const */
|
||||
if (width==1)
|
||||
printf(".byte ");
|
||||
if (width>2) {
|
||||
fcval = cval;
|
||||
goto case23;
|
||||
}
|
||||
printf("%o\n", cval);
|
||||
break;
|
||||
|
||||
case 20: /* name */
|
||||
if (width!=2)
|
||||
bxdec();
|
||||
printf("%p\n", &csym[4]);
|
||||
break;
|
||||
|
||||
case 23:
|
||||
case23:
|
||||
if (width==4) {
|
||||
sf = fcval;
|
||||
printf("%o;%o\n", sf);
|
||||
break;
|
||||
}
|
||||
if (width==8) {
|
||||
printf("%o;%o;%o;%o\n", fcval);
|
||||
break;
|
||||
}
|
||||
bxdec();
|
||||
break;
|
||||
|
||||
default:
|
||||
goto syntax;
|
||||
|
||||
}
|
||||
} if ((o=symbol())==9) goto loop; /* , */
|
||||
if (o==1) { /* ; */
|
||||
done:
|
||||
if (ninit<nel)
|
||||
printf(".=.+%d.\n", (nel-ninit)*width);
|
||||
return;
|
||||
}
|
||||
syntax:
|
||||
error("External definition syntax");
|
||||
errflush(o);
|
||||
statement(0);
|
||||
}
|
||||
|
||||
bxdec()
|
||||
{
|
||||
error("Inconsistent external initialization");
|
||||
}
|
||||
|
||||
statement(d) {
|
||||
extern symbol, error, blkhed, eof, peeksym;
|
||||
extern blkend, csym[], rcexpr, block[], tree[], regtab[];
|
||||
extern retseq, jumpc, jump, label, contlab, brklab, cval;
|
||||
extern swp[], isn, pswitch, peekc;
|
||||
extern efftab[], deflab, errflush, swtab[], swsiz, branch;
|
||||
|
||||
int o, o1, o2, o3, np[];
|
||||
|
||||
stmt:
|
||||
switch(o=symbol()) {
|
||||
|
||||
/* EOF */
|
||||
case 0:
|
||||
error("Unexpected EOF");
|
||||
/* ; */
|
||||
case 1:
|
||||
/* } */
|
||||
case 3:
|
||||
return;
|
||||
|
||||
/* { */
|
||||
case 2: {
|
||||
if(d)
|
||||
blkhed();
|
||||
while (!eof) {
|
||||
if ((o=symbol())==3) /* } */
|
||||
goto bend;
|
||||
peeksym = o;
|
||||
statement(0);
|
||||
}
|
||||
error("Missing '}'");
|
||||
bend:
|
||||
return;
|
||||
}
|
||||
|
||||
/* keyword */
|
||||
case 19:
|
||||
switch(cval) {
|
||||
|
||||
/* goto */
|
||||
case 10:
|
||||
np = tree();
|
||||
if ((np[1]&030)!=030) /* not array */
|
||||
np = block(1, 36, 1, np[2]+1, np);
|
||||
rcexpr(block(1,102,0,0,np), regtab);
|
||||
goto semi;
|
||||
|
||||
/* return */
|
||||
case 11:
|
||||
if((peeksym=symbol())==6) /* ( */
|
||||
rcexpr(block(1,110,0,0,pexpr()), regtab);
|
||||
retseq();
|
||||
goto semi;
|
||||
|
||||
/* if */
|
||||
case 12:
|
||||
jumpc(pexpr(), o1=isn++, 0);
|
||||
statement(0);
|
||||
if ((o=symbol())==19 & cval==14) { /* else */
|
||||
o2 = isn++;
|
||||
(easystmt()?branch:jump)(o2);
|
||||
label(o1);
|
||||
statement(0);
|
||||
label(o2);
|
||||
return;
|
||||
}
|
||||
peeksym = o;
|
||||
label(o1);
|
||||
return;
|
||||
|
||||
/* while */
|
||||
case 13:
|
||||
o1 = contlab;
|
||||
o2 = brklab;
|
||||
label(contlab = isn++);
|
||||
jumpc(pexpr(), brklab=isn++, 0);
|
||||
o3 = easystmt();
|
||||
statement(0);
|
||||
(o3?branch:jump)(contlab);
|
||||
label(brklab);
|
||||
contlab = o1;
|
||||
brklab = o2;
|
||||
return;
|
||||
|
||||
/* break */
|
||||
case 17:
|
||||
if(brklab==0)
|
||||
error("Nothing to break from");
|
||||
jump(brklab);
|
||||
goto semi;
|
||||
|
||||
/* continue */
|
||||
case 18:
|
||||
if(contlab==0)
|
||||
error("Nothing to continue");
|
||||
jump(contlab);
|
||||
goto semi;
|
||||
|
||||
/* do */
|
||||
case 19:
|
||||
o1 = contlab;
|
||||
o2 = brklab;
|
||||
contlab = isn++;
|
||||
brklab = isn++;
|
||||
label(o3 = isn++);
|
||||
statement(0);
|
||||
label(contlab);
|
||||
contlab = o1;
|
||||
if ((o=symbol())==19 & cval==13) { /* while */
|
||||
jumpc(tree(), o3, 1);
|
||||
label(brklab);
|
||||
brklab = o2;
|
||||
goto semi;
|
||||
}
|
||||
goto syntax;
|
||||
|
||||
/* case */
|
||||
case 16:
|
||||
if ((o=symbol())!=21) { /* constant */
|
||||
if (o!=41) /* - */
|
||||
goto syntax;
|
||||
if ((o=symbol())!=21)
|
||||
goto syntax;
|
||||
cval = - cval;
|
||||
}
|
||||
if ((o=symbol())!=8) /* : */
|
||||
goto syntax;
|
||||
if (swp==0) {
|
||||
error("Case not in switch");
|
||||
goto stmt;
|
||||
}
|
||||
if(swp>=swtab+swsiz) {
|
||||
error("Switch table overflow");
|
||||
} else {
|
||||
*swp++ = isn;
|
||||
*swp++ = cval;
|
||||
label(isn++);
|
||||
}
|
||||
goto stmt;
|
||||
|
||||
/* switch */
|
||||
case 15:
|
||||
o1 = brklab;
|
||||
brklab = isn++;
|
||||
np = pexpr();
|
||||
if (np[1]>1 & np[1]<07)
|
||||
error("Integer required");
|
||||
rcexpr(block(1,110,0,0,np), regtab);
|
||||
pswitch();
|
||||
brklab = o1;
|
||||
return;
|
||||
|
||||
/* default */
|
||||
case 20:
|
||||
if (swp==0)
|
||||
error("Default not in switch");
|
||||
if ((o=symbol())!=8) /* : */
|
||||
goto syntax;
|
||||
deflab = isn++;
|
||||
label(deflab);
|
||||
goto stmt;
|
||||
}
|
||||
|
||||
error("Unknown keyword");
|
||||
goto syntax;
|
||||
|
||||
/* name */
|
||||
case 20:
|
||||
if (peekc==':') {
|
||||
peekc = 0;
|
||||
if (csym[0]>0) {
|
||||
error("Redefinition");
|
||||
goto stmt;
|
||||
}
|
||||
csym[0] = 7;
|
||||
csym[1] = 030; /* int[] */
|
||||
if (csym[2]==0)
|
||||
csym[2] = isn++;
|
||||
label(csym[2]);
|
||||
goto stmt;
|
||||
}
|
||||
}
|
||||
|
||||
peeksym = o;
|
||||
rcexpr(tree(), efftab);
|
||||
goto semi;
|
||||
|
||||
semi:
|
||||
if ((o=symbol())!=1) /* ; */
|
||||
goto syntax;
|
||||
return;
|
||||
|
||||
syntax:
|
||||
error("Statement syntax");
|
||||
errflush(o);
|
||||
goto stmt;
|
||||
}
|
||||
|
||||
pexpr()
|
||||
{
|
||||
auto o, t;
|
||||
|
||||
if ((o=symbol())!=6) /* ( */
|
||||
goto syntax;
|
||||
t = tree();
|
||||
if ((o=symbol())!=7) /* ) */
|
||||
goto syntax;
|
||||
return(t);
|
||||
syntax:
|
||||
error("Statement syntax");
|
||||
errflush(o);
|
||||
return(0);
|
||||
}
|
||||
|
||||
pswitch() {
|
||||
extern swp[], isn, swtab[], printf, deflab, statement, brklab;
|
||||
extern label;
|
||||
int sswp[], dl, cv, swlab;
|
||||
|
||||
sswp = swp;
|
||||
if (swp==0)
|
||||
swp = swtab;
|
||||
swlab = isn++;
|
||||
printf("jsr pc,bswitch; l%d\n", swlab);
|
||||
dl = deflab;
|
||||
deflab = 0;
|
||||
statement(0);
|
||||
if (!deflab) {
|
||||
deflab = isn++;
|
||||
label(deflab);
|
||||
}
|
||||
printf("L%d:.data;L%d:", brklab, swlab);
|
||||
while(swp>sswp & swp>swtab) {
|
||||
cv = *--swp;
|
||||
printf("%o; l%d\n", cv, *--swp);
|
||||
}
|
||||
printf("L%d; 0\n.text\n", deflab);
|
||||
deflab = dl;
|
||||
swp = sswp;
|
||||
}
|
||||
|
||||
blkhed()
|
||||
{
|
||||
extern symbol, cval, peeksym, paraml[], parame[];
|
||||
extern error, rlength, setstk, defvec, isn, defstat;
|
||||
extern stack, hshtab[], hshsiz, pssiz;
|
||||
int al, pl, cs[], hl, t[];
|
||||
|
||||
declist(0);
|
||||
stack = al = 0;
|
||||
pl = 4;
|
||||
while(paraml) {
|
||||
*parame = 0;
|
||||
paraml = *(cs = paraml);
|
||||
if (cs[1]==2) /* float args -> double */
|
||||
cs[1] = 3;
|
||||
cs[2] = pl;
|
||||
*cs = 10;
|
||||
if ((cs[1]&030) == 030) /* array */
|
||||
cs[1] =- 020; /* set ref */
|
||||
pl =+ rlength(cs);
|
||||
}
|
||||
cs = hshtab;
|
||||
hl = hshsiz;
|
||||
while(hl--) {
|
||||
if (cs[4]) {
|
||||
if (cs[0]>1 & (cs[1]&07)==05) { /* referred structure */
|
||||
t = cs[3];
|
||||
cs[3] = t[3];
|
||||
cs[1] = cs[1]&077770 | 04;
|
||||
}
|
||||
switch(cs[0]) {
|
||||
|
||||
/* sort unmentioned */
|
||||
case -2:
|
||||
cs[0] = 5; /* auto */
|
||||
|
||||
/* auto */
|
||||
case 5:
|
||||
al =- trlength(cs);
|
||||
cs[2] = al;
|
||||
break;
|
||||
|
||||
/* parameter */
|
||||
case 10:
|
||||
cs[0] = 5;
|
||||
break;
|
||||
|
||||
/* static */
|
||||
case 7:
|
||||
cs[2] = isn;
|
||||
printf(".bss; L%d: .=.+%o; .text\n",
|
||||
isn++, trlength(cs));
|
||||
break;
|
||||
|
||||
}
|
||||
}
|
||||
cs = cs+pssiz;
|
||||
}
|
||||
setstk(al);
|
||||
}
|
||||
|
||||
blkend() {
|
||||
extern hshtab[], hshsiz, pssiz, hshused, debug;
|
||||
auto i, hl;
|
||||
|
||||
i = 0;
|
||||
hl = hshsiz;
|
||||
while(hl--) {
|
||||
if(hshtab[i+4]) {
|
||||
if (debug)
|
||||
if (hshtab[i]!=1)
|
||||
error("%p %o %o %o %o %o",
|
||||
&hshtab[i+4],
|
||||
hshtab[i],
|
||||
hshtab[i+1],
|
||||
hshtab[i+2],
|
||||
hshtab[i+3],
|
||||
hshtab[i+8]);
|
||||
if (hshtab[i]==0)
|
||||
error("%p undefined", &hshtab[i+4]);
|
||||
if((hshtab[i+4]&0200)==0) { /* not top-level */
|
||||
hshtab[i+4] = 0;
|
||||
hshused--;
|
||||
}
|
||||
}
|
||||
i =+ pssiz;
|
||||
}
|
||||
}
|
||||
|
||||
errflush(o) {
|
||||
extern symbol, peeksym, eof;
|
||||
|
||||
while(o>3) /* ; { } */
|
||||
o = symbol();
|
||||
peeksym = o;
|
||||
}
|
||||
|
||||
declist(mosflg)
|
||||
{
|
||||
extern peeksym, csym[], cval;
|
||||
auto o, offset;
|
||||
|
||||
offset = 0;
|
||||
while((o=symbol())==19 & cval<10)
|
||||
if (cval<=4)
|
||||
offset = tdeclare(cval, offset, mosflg);
|
||||
else
|
||||
scdeclare(cval);
|
||||
peeksym = o;
|
||||
return(offset);
|
||||
}
|
||||
|
||||
easystmt()
|
||||
{
|
||||
extern peeksym, peekc, cval;
|
||||
|
||||
if((peeksym=symbol())==20) /* name */
|
||||
return(peekc!=':'); /* not label */
|
||||
if (peeksym==19) { /* keyword */
|
||||
switch(cval)
|
||||
|
||||
case 10: /* goto */
|
||||
case 11: /* return */
|
||||
case 17: /* break */
|
||||
case 18: /* continue */
|
||||
return(1);
|
||||
return(0);
|
||||
}
|
||||
return(peeksym!=2); /* { */
|
||||
}
|
||||
|
||||
branch(lab)
|
||||
{
|
||||
printf("br L%d\n", lab);
|
||||
}
|
||||
|
251
prestruct/c03.c
Normal file
251
prestruct/c03.c
Normal file
@ -0,0 +1,251 @@
|
||||
retseq()
|
||||
{
|
||||
printf("jmp retrn\n");
|
||||
}
|
||||
|
||||
decref(t)
|
||||
{
|
||||
|
||||
if ((t & 077770) == 0) {
|
||||
error("Illegal indirection");
|
||||
return(t);
|
||||
}
|
||||
return((t>>2) & 077770 | t&07);
|
||||
}
|
||||
|
||||
incref(t)
|
||||
{
|
||||
return((t<<2)&077740 | (t&07) | 010);
|
||||
}
|
||||
|
||||
jumpc(tree, lbl, cond)
|
||||
int tree[];
|
||||
{
|
||||
extern cctab, block, rcexpr;
|
||||
|
||||
rcexpr(block(1,easystmt()+103,tree,lbl,cond),cctab);
|
||||
}
|
||||
|
||||
rcexpr(tree, table)
|
||||
int tree[], table;
|
||||
{
|
||||
extern space, putwrd, putchar, line;
|
||||
int c, sp[];
|
||||
|
||||
if (tree == 0)
|
||||
return;
|
||||
putchar('#');
|
||||
c = space;
|
||||
c =/ 2; /* # addresses per word */
|
||||
sp = 0;
|
||||
putwrd(c);
|
||||
putwrd(tree);
|
||||
putwrd(table);
|
||||
putwrd(line);
|
||||
while(c--)
|
||||
putwrd(*sp++);
|
||||
}
|
||||
|
||||
jump(lab) {
|
||||
extern printf;
|
||||
|
||||
printf("jmp\tl%d\n", lab);
|
||||
}
|
||||
|
||||
label(l) {
|
||||
extern printf;
|
||||
|
||||
printf("L%d:", l);
|
||||
}
|
||||
|
||||
setstk(a) {
|
||||
extern printf, stack;
|
||||
auto ts;
|
||||
|
||||
ts = a-stack;
|
||||
stack = a;
|
||||
switch(ts) {
|
||||
|
||||
case 0:
|
||||
return;
|
||||
|
||||
case 0177776: /* -2 */
|
||||
printf("tst -(sp)\n");
|
||||
return;
|
||||
|
||||
case 0177774: /* -4 */
|
||||
printf("cmp -(sp),-(sp)\n");
|
||||
return;
|
||||
}
|
||||
printf("add $%o,sp\n", ts);
|
||||
}
|
||||
|
||||
plength(p)
|
||||
int p[];
|
||||
{
|
||||
int t, l;
|
||||
|
||||
if (((t=p[1])&077770) == 0) /* not a reference */
|
||||
return(1);
|
||||
p[1] = decref(t);
|
||||
l = length(p);
|
||||
p[1] = t;
|
||||
return(l);
|
||||
}
|
||||
|
||||
length(cs)
|
||||
int cs[];
|
||||
{
|
||||
extern hshtab[];
|
||||
int t;
|
||||
|
||||
t = cs[1];
|
||||
if ((t&030) == 030) /* array */
|
||||
t = decref(t);
|
||||
if (t>=010)
|
||||
return(2);
|
||||
switch(t&07) {
|
||||
|
||||
case 0: /* int */
|
||||
return(2);
|
||||
|
||||
case 1: /* char */
|
||||
return(1);
|
||||
|
||||
case 2: /* float */
|
||||
return(4);
|
||||
|
||||
case 3: /* double */
|
||||
return(8);
|
||||
|
||||
case 4: /* structure */
|
||||
if (cs>=hshtab) /* in namelist */
|
||||
return(cs[3]);
|
||||
return(getlen(cs));
|
||||
|
||||
case 5:
|
||||
error("Bad structure");
|
||||
return(0);
|
||||
}
|
||||
error("Compiler error (length)");
|
||||
}
|
||||
|
||||
getlen(p)
|
||||
int p[];
|
||||
{
|
||||
int p1[];
|
||||
|
||||
switch(*p) {
|
||||
|
||||
case 20: /* name */
|
||||
return(p[2]);
|
||||
|
||||
case 35:
|
||||
case 29: /* & */
|
||||
case 36: /* * */
|
||||
case 100: /* call */
|
||||
case 41: /* - */
|
||||
return(getlen(p[3]));
|
||||
|
||||
case 40: /* + */
|
||||
p1 = p[4];
|
||||
if ((p1[1]&07) == 04)
|
||||
return(getlen(p1));
|
||||
return(getlen(p[3]));
|
||||
}
|
||||
error("Unimplemented pointer conversion");
|
||||
return(0);
|
||||
}
|
||||
|
||||
rlength(cs)
|
||||
int cs[];
|
||||
{
|
||||
auto l;
|
||||
|
||||
if (((l=length(cs))&01) != 0)
|
||||
l++;
|
||||
return(l);
|
||||
}
|
||||
|
||||
tlength(cs)
|
||||
int cs[];
|
||||
{
|
||||
int nel;
|
||||
|
||||
if ((nel = cs[8]) == 0)
|
||||
nel = 1;
|
||||
return(length(cs)*nel);
|
||||
}
|
||||
|
||||
trlength(cs)
|
||||
int cs[];
|
||||
{
|
||||
int l;
|
||||
|
||||
if (((l=tlength(cs))&01) != 0)
|
||||
l++;
|
||||
return(l);
|
||||
}
|
||||
|
||||
printn(n,b) {
|
||||
extern putchar;
|
||||
auto a;
|
||||
|
||||
if(a=n/b) /* assignment, not test for equality */
|
||||
printn(a, b); /* recursive */
|
||||
putchar(n%b + '0');
|
||||
}
|
||||
|
||||
printf(fmt,x1,x2,x3,x4,x5,x6,x7,x8,x9)
|
||||
char fmt[]; {
|
||||
extern printn, putchar, namsiz, ncpw;
|
||||
char s[];
|
||||
auto adx[], x, c, i[];
|
||||
|
||||
adx = &x1; /* argument pointer */
|
||||
loop:
|
||||
while((c = *fmt++) != '%') {
|
||||
if(c == '\0')
|
||||
return;
|
||||
putchar(c);
|
||||
}
|
||||
x = *adx++;
|
||||
switch (c = *fmt++) {
|
||||
|
||||
case 'd': /* decimal */
|
||||
case 'o': /* octal */
|
||||
if(x < 0) {
|
||||
x = -x;
|
||||
if(x<0) { /* - infinity */
|
||||
if(c=='o')
|
||||
printf("100000");
|
||||
else
|
||||
printf("-32767");
|
||||
goto loop;
|
||||
}
|
||||
putchar('-');
|
||||
}
|
||||
printn(x, c=='o'?8:10);
|
||||
goto loop;
|
||||
|
||||
case 's': /* string */
|
||||
s = x;
|
||||
while(c = *s++)
|
||||
putchar(c);
|
||||
goto loop;
|
||||
|
||||
case 'p':
|
||||
s = x;
|
||||
putchar('_');
|
||||
c = namsiz;
|
||||
while(c--)
|
||||
if (*s)
|
||||
putchar((*s++)&0177);
|
||||
goto loop;
|
||||
}
|
||||
putchar('%');
|
||||
fmt--;
|
||||
adx--;
|
||||
goto loop;
|
||||
}
|
||||
|
588
prestruct/c10.c
Normal file
588
prestruct/c10.c
Normal file
@ -0,0 +1,588 @@
|
||||
/*
|
||||
|
||||
C compiler, part 2
|
||||
|
||||
Copyright 1972 Bell Telephone Laboratories, Inc.
|
||||
|
||||
*/
|
||||
|
||||
waste() /* waste space */
|
||||
{
|
||||
waste(waste(waste),waste(waste),waste(waste));
|
||||
waste(waste(waste),waste(waste),waste(waste));
|
||||
waste(waste(waste),waste(waste),waste(waste));
|
||||
waste(waste(waste),waste(waste),waste(waste));
|
||||
waste(waste(waste),waste(waste),waste(waste));
|
||||
waste(waste(waste),waste(waste),waste(waste));
|
||||
waste(waste(waste),waste(waste),waste(waste));
|
||||
waste(waste(waste),waste(waste),waste(waste));
|
||||
}
|
||||
main(argc, argv)
|
||||
char argv[][];
|
||||
{
|
||||
extern fout, fin, nerror, line;
|
||||
extern getwrd, rcexpr, tmpfil;
|
||||
extern cctab[], regtab[], efftab[], sptab[];
|
||||
int sp[], c, table[], tabtab[3][], tree;
|
||||
|
||||
if (argc<4) {
|
||||
error("Arg count");
|
||||
exit(1);
|
||||
}
|
||||
if((fin=open(argv[1],0))<0) {
|
||||
error("Cant't find %s", argv[1]);
|
||||
exit(1);
|
||||
}
|
||||
if((fout=creat(argv[3],017))<0) {
|
||||
error("Can't create %s", argv[3]);
|
||||
exit(1);
|
||||
}
|
||||
tmpfil = argv[2];
|
||||
|
||||
tabtab[0] = regtab;
|
||||
tabtab[1] = efftab;
|
||||
tabtab[2] = cctab;
|
||||
tabtab[3] = sptab;
|
||||
while(c=getchar()) {
|
||||
if(c=='#') {
|
||||
sp = 0;
|
||||
c = getwrd();
|
||||
tree = getwrd();
|
||||
table = tabtab[getwrd()];
|
||||
line = getwrd();
|
||||
while(c--)
|
||||
*sp++ = getwrd();
|
||||
rcexpr(tree, table, 0);
|
||||
} else
|
||||
putchar(c);
|
||||
}
|
||||
flush();
|
||||
exit(nerror!=0);
|
||||
}
|
||||
|
||||
match(tree, table, nreg)
|
||||
int tree[], table[]; {
|
||||
extern opdope[], cctab, maprel;
|
||||
int op, d1, d2, t1, t2, p1[], p2[], dope, cctab[];
|
||||
int maprel[];
|
||||
char mp[];
|
||||
|
||||
if (tree==0)
|
||||
return(0);
|
||||
op = *tree;
|
||||
if (op>=29) /* if not leaf */
|
||||
p1 = tree[3];
|
||||
else
|
||||
p1 = tree;
|
||||
t1 = p1[1];
|
||||
d1 = dcalc(p1, nreg);
|
||||
if (((dope=opdope[op])&01)!=0) { /* binary? */
|
||||
p2 = tree[4];
|
||||
t2 = p2[1];
|
||||
d2 = dcalc(p2, nreg);
|
||||
if (d2>d1 & (dope&0100)!=0) /* commute? */
|
||||
if (table!=cctab | (op!=47&op!=48)) { /* commute? */
|
||||
if ((dope&04)!=0) /* relation? */
|
||||
*tree = op = maprel[op-60];
|
||||
dope = t1;
|
||||
t1 = t2;
|
||||
t2 = dope;
|
||||
dope = p1;
|
||||
tree[3] = p1 = p2;
|
||||
tree[4] = p2 = dope;
|
||||
dope = d1;
|
||||
d1 = d2;
|
||||
d2 = dope;
|
||||
dope = t1;
|
||||
t1 = t2;
|
||||
t2 = dope;
|
||||
}
|
||||
}
|
||||
while(*table) {
|
||||
if (*table++ == op) goto foundop;
|
||||
table++;
|
||||
}
|
||||
return(0);
|
||||
foundop:
|
||||
table = *table;
|
||||
nxtry:
|
||||
mp = table;
|
||||
if (*mp == 0)
|
||||
return(0);
|
||||
if (d1 > (*mp&077) | (*mp>=0100)&(*p1!=36))
|
||||
goto notyet;
|
||||
if (notcompat(t1, mp[1]))
|
||||
goto notyet;
|
||||
if ((opdope[op]&01)!=0 & p2!=0) {
|
||||
if (d2 > (mp[2]&077) | (mp[2]>=0100)&(*p2!=36))
|
||||
goto notyet;
|
||||
if (notcompat(t2,mp[3]))
|
||||
goto notyet;
|
||||
}
|
||||
now:
|
||||
return(table[2]);
|
||||
notyet:
|
||||
table = table+3;
|
||||
goto nxtry;
|
||||
}
|
||||
|
||||
rcexpr(tree, table, reg)
|
||||
int tree[]; {
|
||||
extern cexpr, regtab, cctab, sptab, printf, error;
|
||||
extern jumpc, cbranch;
|
||||
int r, modf;
|
||||
|
||||
if(tree==0)
|
||||
return(0);
|
||||
if(*tree == 103 | *tree==104) {
|
||||
(*tree==103?jumpc:cbranch)(tree[1],tree[2],tree[3],0);
|
||||
return(0);
|
||||
}
|
||||
modf = isfloat(tree)? 'f':0;
|
||||
if (*tree == 110) { /* force r0 */
|
||||
if((r=rcexpr(tree[3], table, reg)) != 0)
|
||||
printf("mov%c r%d,r0\n", modf, r);
|
||||
return(0);
|
||||
}
|
||||
if ((r=cexpr(tree, table, reg))>=0)
|
||||
return(r);
|
||||
if (table!=regtab)
|
||||
if((r=cexpr(tree, regtab, reg))>=0) {
|
||||
if (table==sptab)
|
||||
printf("mov%c r%d,-(sp)\n", modf, r);
|
||||
if (table==cctab) {
|
||||
if (modf=='f')
|
||||
printf("cfcc\n");
|
||||
printf("tst%c r%d\n", modf, r);
|
||||
}
|
||||
return(0);
|
||||
}
|
||||
error("No match for op %d", *tree);
|
||||
}
|
||||
|
||||
cexpr(tree, table, reg)
|
||||
int tree[][], table[]; {
|
||||
extern match, nreg, printf, pname, putchar, regtab;
|
||||
extern sptab, cctab, rcexpr, prins, rlength, popstk;
|
||||
extern collcon, isn, label, branch, cbranch;
|
||||
extern maprel[];
|
||||
int p1[], p2[], c, r, p[], otable[], ctable[], regtab[], cctab[];
|
||||
int sptab[];
|
||||
char string[], match[];
|
||||
int reg1, rreg;
|
||||
|
||||
if ((c = *tree)==100) { /* call */
|
||||
p1 = tree[3];
|
||||
p2 = tree[4];
|
||||
r = 0;
|
||||
if(*p2) {
|
||||
while (*p2==9) { /* comma */
|
||||
rcexpr(p2[4], sptab, 0);
|
||||
r =+ arlength((p=p2[4])[1]);
|
||||
p2 = p2[3];
|
||||
}
|
||||
rcexpr(p2, sptab, 0);
|
||||
r =+ arlength(p2[1]);
|
||||
}
|
||||
*tree = 101;
|
||||
tree[2] = r; /* save arg length */
|
||||
}
|
||||
if(c==90) { /* ? */
|
||||
cbranch(tree[3], c=isn++, 0, reg);
|
||||
rcexpr(tree[4][3], table, reg);
|
||||
branch(r=isn++, 0);
|
||||
label(c);
|
||||
reg = rcexpr(tree[4][4], table, reg);
|
||||
label(r);
|
||||
goto retrn;
|
||||
}
|
||||
reg = oddreg(tree, reg);
|
||||
reg1 = reg+1;
|
||||
if ((string=match(tree, table, nreg-reg))==0)
|
||||
return(-1);
|
||||
p1 = tree[3];
|
||||
p2 = tree[4];
|
||||
loop:
|
||||
switch(c = *string++) {
|
||||
|
||||
case '\0':
|
||||
p = tree;
|
||||
if (*p==101) {
|
||||
if (p[2]>0)
|
||||
popstk(p[2]);
|
||||
reg = 0;
|
||||
}
|
||||
retrn:
|
||||
c = isfloat(tree);
|
||||
if (table==cctab & c)
|
||||
printf("cfcc\n");
|
||||
if (!c)
|
||||
if ((c = *tree)==43 | c==73)
|
||||
reg--;
|
||||
return(reg);
|
||||
|
||||
/* A1 */
|
||||
case 'A':
|
||||
p = tree[3];
|
||||
goto adr;
|
||||
|
||||
/* A2 */
|
||||
case 'B':
|
||||
p = tree[4];
|
||||
goto adr;
|
||||
|
||||
/* A */
|
||||
case 'O':
|
||||
p = tree;
|
||||
adr:
|
||||
pname(p);
|
||||
goto loop;
|
||||
|
||||
/* I */
|
||||
case 'M':
|
||||
if ((c = *string)=='\'')
|
||||
string++; else
|
||||
c = 0;
|
||||
prins(*tree, c);
|
||||
goto loop;
|
||||
|
||||
/* B1 */
|
||||
case 'C':
|
||||
if ((c = *tree)<28)
|
||||
p = tree;
|
||||
else
|
||||
p = tree[3];
|
||||
goto pbyte;
|
||||
|
||||
/* BF */
|
||||
case 'P':
|
||||
p = tree;
|
||||
goto pb1;
|
||||
|
||||
/* B2 */
|
||||
case 'D':
|
||||
p = tree[4];
|
||||
pbyte:
|
||||
if (p[1]==1) /* char type? */
|
||||
putchar('b');
|
||||
pb1:
|
||||
if (isfloat(p))
|
||||
putchar('f');
|
||||
goto loop;
|
||||
|
||||
/* BE */
|
||||
case 'L':
|
||||
if (tree[3][1]==1 | tree[4][1]==1)
|
||||
putchar('b');
|
||||
p = tree;
|
||||
goto pb1;
|
||||
|
||||
/* C1 */
|
||||
case 'E':
|
||||
p = p1[3];
|
||||
goto const;
|
||||
|
||||
/* C2 */
|
||||
case 'F':
|
||||
p = p2[3];
|
||||
const:
|
||||
printf("%o", p);
|
||||
goto loop;
|
||||
|
||||
/* F */
|
||||
case 'G':
|
||||
p = p1;
|
||||
goto subtre;
|
||||
|
||||
/* S */
|
||||
case 'K':
|
||||
p = p2;
|
||||
goto subtre;
|
||||
|
||||
/* H */
|
||||
case 'H':
|
||||
p = tree;
|
||||
|
||||
subtre:
|
||||
ctable = regtab;
|
||||
r = reg;
|
||||
c = *string++ - 'A';
|
||||
if ((c&02)!=0)
|
||||
ctable = sptab;
|
||||
if ((c&04)!=0)
|
||||
ctable = cctab;
|
||||
if((c&010)!=0)
|
||||
r = reg1;
|
||||
if((c&01)!=0)
|
||||
if(*p==36) {
|
||||
p = p[3];
|
||||
if(collcon(p) & ctable!=sptab)
|
||||
p = p[3];
|
||||
}
|
||||
rreg = rcexpr(p, ctable, r);
|
||||
if (rreg==r | ctable!=regtab)
|
||||
goto loop;
|
||||
if (string[-2]=='G') /* left operand */
|
||||
if (oddreg(tree, 0)==1) {
|
||||
printf("mov r%d,r%d\n", rreg, r);
|
||||
goto loop;
|
||||
}
|
||||
if (r==reg) {
|
||||
reg = rreg;
|
||||
reg1 = rreg+1;
|
||||
} else
|
||||
reg1 = rreg;
|
||||
goto loop;
|
||||
|
||||
/* R */
|
||||
case 'I':
|
||||
r = reg;
|
||||
if (*string=='-') {
|
||||
string++;
|
||||
r--;
|
||||
}
|
||||
goto preg;
|
||||
|
||||
/* R1 */
|
||||
case 'J':
|
||||
r = reg1;
|
||||
preg:
|
||||
if (r>=5)
|
||||
error("Register overflow: simplify expression");
|
||||
printf("r%d", r);
|
||||
goto loop;
|
||||
|
||||
case '#':
|
||||
p = p1[3];
|
||||
goto nmbr;
|
||||
|
||||
case '"':
|
||||
p = p2[3];
|
||||
goto nmbr;
|
||||
|
||||
case '~':
|
||||
p = tree[3];
|
||||
|
||||
nmbr:
|
||||
if(collcon(p)) {
|
||||
if (*p==41) /* - */
|
||||
putchar('-');
|
||||
switch (*(p = p[4])) {
|
||||
|
||||
case 21: /* number */
|
||||
if (p[3])
|
||||
printf("%d.", p[3]);
|
||||
break;
|
||||
|
||||
case 35: /* & name */
|
||||
pname(p[3]);
|
||||
break;
|
||||
|
||||
}
|
||||
}
|
||||
goto loop;
|
||||
|
||||
/* V */
|
||||
case 'V':
|
||||
tree[0] = maprel[(c=tree[0])-60];
|
||||
goto loop;
|
||||
|
||||
/* Z */
|
||||
case 'Z':
|
||||
printf("$%o", p1[5]+p1[4]);
|
||||
goto loop;
|
||||
|
||||
case '^': /* for ++ -- */
|
||||
printf("%o", tree[4]);
|
||||
goto loop;
|
||||
}
|
||||
putchar(c);
|
||||
goto loop;
|
||||
}
|
||||
|
||||
pname(p)
|
||||
int p[][]; {
|
||||
char np[];
|
||||
int i;
|
||||
|
||||
loop:
|
||||
switch(*p) {
|
||||
|
||||
case 21: /* const */
|
||||
printf("$%o", p[3]);
|
||||
return;
|
||||
|
||||
case 23: /* float const */
|
||||
printf("L%d", p[3]);
|
||||
return;
|
||||
|
||||
casename:
|
||||
case 20: /* name */
|
||||
if (i=p[4])
|
||||
printf("%d.+", i);
|
||||
switch(p[3]) {
|
||||
|
||||
case 5: /* auto, param */
|
||||
printf("%d.(r5)", p[5]);
|
||||
return;
|
||||
|
||||
/* extern */
|
||||
case 6:
|
||||
printf("%p", &p[5]);
|
||||
return;
|
||||
|
||||
case 4:
|
||||
error("Illegal structure reference");
|
||||
printf("$0");
|
||||
return;
|
||||
|
||||
}
|
||||
printf("L%d", p[5]);
|
||||
return;
|
||||
|
||||
case 35: /* & */
|
||||
putchar('$');
|
||||
p = p[3];
|
||||
goto loop;
|
||||
|
||||
case 36: /* * */
|
||||
putchar('*');
|
||||
p = p[3];
|
||||
goto loop;
|
||||
|
||||
}
|
||||
error("pname called illegally");
|
||||
}
|
||||
|
||||
dcalc(p, nreg)
|
||||
int p[]; {
|
||||
int op, t, p1[], p2[];
|
||||
|
||||
if (p==0)
|
||||
return(0);
|
||||
op = *p;
|
||||
switch (op) {
|
||||
|
||||
case 20: /* name */
|
||||
case 35: /* & (non-automatic) */
|
||||
return(12);
|
||||
|
||||
case 21: /* short constant */
|
||||
return(p[3]==0? 4:8);
|
||||
|
||||
case 23: /* float const */
|
||||
return(p[3]==0? 4:12);
|
||||
|
||||
case 36: /* * */
|
||||
p1 = p[3];
|
||||
if (*p1==20) /* name or offset name */
|
||||
return(12);
|
||||
}
|
||||
|
||||
def:
|
||||
return(p[2]<=nreg? 20: 24);
|
||||
}
|
||||
|
||||
notcompat(at, st) {
|
||||
|
||||
if (st==0) /* word, byte */
|
||||
return(at>1 & at<=07);
|
||||
if (st==1) /* word */
|
||||
return(at>0 & at<=07);
|
||||
st =- 2;
|
||||
if ((at&077740) != 0)
|
||||
at = 020; /* *int for **stuff */
|
||||
if ((at&077770) != 0)
|
||||
at = at&07 | 020;
|
||||
if (st==2 & at==3)
|
||||
at = 2;
|
||||
return(st != at);
|
||||
}
|
||||
|
||||
prins(op, c) {
|
||||
extern instab[], printf;
|
||||
int insp[];
|
||||
|
||||
insp = instab;
|
||||
while(*insp) {
|
||||
if (*insp++ == op) {
|
||||
if ((c = insp[c!=0])==0)
|
||||
goto err;
|
||||
printf("%s", c);
|
||||
return;
|
||||
} else
|
||||
insp = insp + 2;
|
||||
}
|
||||
err:
|
||||
error("No match' for op %d", op);
|
||||
}
|
||||
|
||||
collcon(p)
|
||||
int p[]; {
|
||||
int p1[], t[];
|
||||
|
||||
if(*p==40 | *p==41) {
|
||||
if(*(p1=p[4])==21) { /* number */
|
||||
return(1);
|
||||
}
|
||||
if (*p1==35)
|
||||
return(1);
|
||||
if (*(p1=p[3])==35) {
|
||||
p1 = p[3];
|
||||
p[3] = p[4];
|
||||
p[4] = p1;
|
||||
return(1);
|
||||
}
|
||||
}
|
||||
return(0);
|
||||
}
|
||||
|
||||
isfloat(t)
|
||||
int t[];
|
||||
{
|
||||
extern opdope[];
|
||||
int rt;
|
||||
|
||||
if ((opdope[t[0]]&04)!=0) /* relational */
|
||||
t = t[3];
|
||||
if ((rt=t[1])>=2 & rt<=3)
|
||||
return(rt);
|
||||
return(0);
|
||||
}
|
||||
|
||||
nreg 3;
|
||||
isn 10000;
|
||||
namsiz 8;
|
||||
line;
|
||||
tmpfil;
|
||||
nerror;
|
||||
|
||||
oddreg(t, reg)
|
||||
int t[];
|
||||
{
|
||||
if (!isfloat(t))
|
||||
switch(*t) {
|
||||
case 43: /* / */
|
||||
case 44: /* % */
|
||||
case 73: /* =/ */
|
||||
case 74: /* =% */
|
||||
reg++;
|
||||
|
||||
case 42: /* * */
|
||||
case 72: /* =* */
|
||||
return(reg|1);
|
||||
}
|
||||
return(reg);
|
||||
}
|
||||
|
||||
arlength(t)
|
||||
{
|
||||
int arl;
|
||||
|
||||
if ((arl=rlength(t)) == 4)
|
||||
return(8);
|
||||
return(arl);
|
||||
}
|
||||
|
||||
maprel[] 60, 61, 64, 65, 62, 63, 68, 69, 66, 67;
|
||||
|
261
prestruct/c11.c
Normal file
261
prestruct/c11.c
Normal file
@ -0,0 +1,261 @@
|
||||
jumpc(tree, lbl, cond)
|
||||
int tree[]; {
|
||||
extern jump, cctab[], rcexpr, isn, label, branch, cbranch;
|
||||
int l1, l2;
|
||||
|
||||
if (tree==0)
|
||||
return;
|
||||
switch(*tree) {
|
||||
|
||||
/* & */
|
||||
case 47:
|
||||
if (cond) {
|
||||
cbranch(tree[3], l1=isn++, 0, 0);
|
||||
cbranch(tree[4], l1, 0, 0);
|
||||
jump(lbl);
|
||||
label(l1);
|
||||
} else {
|
||||
cbranch(tree[3], l1=isn++, 0, 0);
|
||||
cbranch(tree[4], l2=isn++, 1, 0);
|
||||
label(l1);
|
||||
jump(lbl);
|
||||
label(l2);
|
||||
}
|
||||
return;
|
||||
|
||||
/* | */
|
||||
case 48:
|
||||
if (cond) {
|
||||
cbranch(tree[3], l1=isn++, 1, 0);
|
||||
cbranch(tree[4], l2=isn++, 0, 0);
|
||||
label(l1);
|
||||
jump(lbl);
|
||||
label(l2);
|
||||
} else {
|
||||
cbranch(tree[3], l1=isn++, 1, 0);
|
||||
cbranch(tree[4], l1, 1, 0);
|
||||
jump(lbl);
|
||||
label(l1);
|
||||
}
|
||||
return;
|
||||
|
||||
/* ! */
|
||||
case 34:
|
||||
jumpc(tree[3], lbl, !cond);
|
||||
return;
|
||||
}
|
||||
rcexpr(tree, cctab, 0);
|
||||
branch(l1=isn++, *tree, cond);
|
||||
jump(lbl);
|
||||
label(l1);
|
||||
return;
|
||||
}
|
||||
|
||||
cbranch(tree, lbl, cond, reg)
|
||||
int tree[]; {
|
||||
extern branch, cctab[], rcexpr, isn, label;
|
||||
int l1;
|
||||
|
||||
if (tree==0)
|
||||
return;
|
||||
switch(*tree) {
|
||||
|
||||
/* & */
|
||||
case 47:
|
||||
if (cond) {
|
||||
cbranch(tree[3], l1=isn++, 0, reg);
|
||||
cbranch(tree[4], lbl, 1, reg);
|
||||
label(l1);
|
||||
} else {
|
||||
cbranch(tree[3], lbl, 0, reg);
|
||||
cbranch(tree[4], lbl, 0, reg);
|
||||
}
|
||||
return;
|
||||
|
||||
/* | */
|
||||
case 48:
|
||||
if (cond) {
|
||||
cbranch(tree[3], lbl, 1, reg);
|
||||
cbranch(tree[4], lbl, 1, reg);
|
||||
} else {
|
||||
cbranch(tree[3], l1=isn++, 1, reg);
|
||||
cbranch(tree[4], lbl, 0, reg);
|
||||
label(l1);
|
||||
}
|
||||
return;
|
||||
|
||||
/* ! */
|
||||
case 34:
|
||||
cbranch(tree[3], lbl, !cond, reg);
|
||||
return;
|
||||
}
|
||||
rcexpr(tree, cctab, reg);
|
||||
branch(lbl, *tree, !cond);
|
||||
return;
|
||||
}
|
||||
|
||||
|
||||
branch(lbl, op, c) {
|
||||
extern printf, prins, opdope[];
|
||||
|
||||
if(op) {
|
||||
if((opdope[op]&04)==0)
|
||||
op = 61;
|
||||
prins(op,c);
|
||||
} else
|
||||
printf("br");
|
||||
printf("\tl%d\n", lbl);
|
||||
}
|
||||
|
||||
jump(lab) {
|
||||
extern printf;
|
||||
|
||||
printf("jmp\tl%d\n", lab);
|
||||
}
|
||||
|
||||
label(l) {
|
||||
extern printf;
|
||||
|
||||
printf("l%d:", l);
|
||||
}
|
||||
|
||||
|
||||
popstk(a) {
|
||||
extern printf;
|
||||
|
||||
switch(a) {
|
||||
|
||||
case 0:
|
||||
return;
|
||||
|
||||
case 2:
|
||||
printf("tst (sp)+\n");
|
||||
return;
|
||||
|
||||
case 4:
|
||||
printf("cmp (sp)+,(sp)+\n");
|
||||
return;
|
||||
}
|
||||
printf("add $%o,sp\n", a);
|
||||
}
|
||||
|
||||
length(t) {
|
||||
|
||||
if (t>=010)
|
||||
return(2);
|
||||
switch(t) {
|
||||
|
||||
case 0:
|
||||
return(2);
|
||||
|
||||
case 1:
|
||||
return(1);
|
||||
|
||||
case 2:
|
||||
return(4);
|
||||
|
||||
case 3:
|
||||
return(8);
|
||||
|
||||
case 4:
|
||||
return(4);
|
||||
|
||||
}
|
||||
return(1024);
|
||||
}
|
||||
|
||||
rlength(c) {
|
||||
extern length;
|
||||
auto l;
|
||||
|
||||
return((l=length(c))==1? 2: l);
|
||||
}
|
||||
|
||||
printd(n) {
|
||||
int a;
|
||||
|
||||
if(a=n/10)
|
||||
printd(a);
|
||||
putchar(n%10 + '0');
|
||||
}
|
||||
|
||||
printo(n)
|
||||
{
|
||||
int a;
|
||||
if (a = (n>>3) & 017777)
|
||||
printo(a);
|
||||
putchar((n&07) + '0');
|
||||
}
|
||||
|
||||
printf(fmt,x1,x2,x3,x4,x5,x6,x7,x8,x9)
|
||||
char fmt[]; {
|
||||
extern namsiz, ncpw;
|
||||
char s[];
|
||||
auto adx[], x, c, i[];
|
||||
|
||||
adx = &x1; /* argument pointer */
|
||||
loop:
|
||||
while((c = *fmt++) != '%') {
|
||||
if(c == '\0')
|
||||
return;
|
||||
putchar(c);
|
||||
}
|
||||
x = *adx++;
|
||||
switch (c = *fmt++) {
|
||||
|
||||
case 'o':
|
||||
printo(x);
|
||||
goto loop;
|
||||
|
||||
case 'd': /* decimal */
|
||||
if(x < 0) {
|
||||
x = -x;
|
||||
if(x<0) { /* - infinity */
|
||||
printf("-32768");
|
||||
goto loop;
|
||||
}
|
||||
putchar('-');
|
||||
}
|
||||
printd(x);
|
||||
goto loop;
|
||||
|
||||
case 'c':
|
||||
if (x)
|
||||
putchar(x);
|
||||
goto loop;
|
||||
|
||||
case 's': /* string */
|
||||
s = x;
|
||||
while(c = *s++)
|
||||
putchar(c);
|
||||
goto loop;
|
||||
|
||||
case 'p':
|
||||
s = x;
|
||||
putchar('_');
|
||||
c = namsiz;
|
||||
while(c--)
|
||||
if(*s)
|
||||
putchar((*s++)&0177);
|
||||
goto loop;
|
||||
}
|
||||
putchar('%');
|
||||
fmt--;
|
||||
adx--;
|
||||
goto loop;
|
||||
}
|
||||
|
||||
error(s, p1, p2) {
|
||||
extern printf, line, fout, flush, putchar, nerror;
|
||||
int f;
|
||||
|
||||
nerror++;
|
||||
flush();
|
||||
f = fout;
|
||||
fout = 1;
|
||||
printf("%d: ", line);
|
||||
printf(s, p1, p2);
|
||||
putchar('\n');
|
||||
fout = f;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user