Annotation of researchv10no/cmd/kasb/kas0.y, revision 1.1

1.1     ! root        1: /*     @(#)kas0.y      1.1     */
        !             2: %union {
        !             3:        int     ival;
        !             4:        struct exp *expr;
        !             5:        struct symtab *sym;
        !             6:        char *str;
        !             7:        }
        !             8: 
        !             9: %token NOCHAR NL
        !            10: %token CM SEMI COLON LP RP
        !            11: %token PLUS MINUS MUL DIV NOT POP BAR INC
        !            12: %token AND XOR LS RS
        !            13: %token <ival> INT
        !            14: %token <sym> DNAME UNAME TNAME PAGE
        !            15: %token <str> STR
        !            16: %token <sym> REG BRG MEM MAR REGL REGH PC PCR
        !            17: %token <sym> MVINS SFINS DFINS BRINS JMPINS
        !            18: %token <sym> SEG ORG DATA DEBUG
        !            19: 
        !            20: %nonassoc COLON
        !            21: %left BAR XOR
        !            22: %left AND
        !            23: %left LS RS
        !            24: %left PLUS MINUS
        !            25: %left MUL DIV
        !            26: %left NOT POP
        !            27: 
        !            28: 
        !            29: %type <sym> fref
        !            30: %type <ival> mach func page dst pdst sdst udst boreg oreg reg2
        !            31: %type <expr> expr val db debug
        !            32: %{
        !            33: #include <stdio.h>
        !            34: #include "kas.h"
        !            35: struct exp     explist[10];
        !            36: struct exp     *xp = { explist};
        !            37: %}
        !            38: 
        !            39: %%
        !            40: %{
        !            41:        int     dinc;
        !            42:        int     nlf;
        !            43: %}
        !            44: prog:          /* empty */
        !            45:        | prog line = {
        !            46:                xp = explist;
        !            47:                if (nlf)
        !            48:                        lineno++;
        !            49:        }
        !            50:        ;
        !            51: 
        !            52: line:  labels close
        !            53:        | labels mach = {
        !            54:                putins($2);
        !            55:        }
        !            56:        | labels pseudo close
        !            57:        | debug close = {
        !            58:                debug($1->xvalue, $1->xtype);
        !            59:        }
        !            60:        | error close = {
        !            61:                yyerrok;
        !            62:        }
        !            63:        ;
        !            64: 
        !            65: labels:                /* empty */
        !            66:        | labels UNAME COLON = {
        !            67:                $2->type = dot->type;
        !            68:                backup($2,dot->value);
        !            69:        }
        !            70:        | labels INT COLON = {
        !            71:                if ($2<0 || $2>9) {
        !            72:                        yyerror("illegal numeric label");
        !            73:                } else {
        !            74:                        loclab[$2].name[0] = 1;
        !            75:                        backup(&loclab[$2], dot->value);
        !            76:                        loclab[$2].type = dot->value;
        !            77:                        loclab[$2].value = 0;
        !            78:                }
        !            79:        }
        !            80:        ;
        !            81: 
        !            82: close: NL = {
        !            83:                nlf = 1;
        !            84:        }
        !            85:        | SEMI = {
        !            86:                nlf = 0;
        !            87:        }
        !            88:        ;
        !            89: 
        !            90: mach:  MVINS fref CM udst close = {
        !            91:                $$ = $1->value|$4;
        !            92:                reloc[dot->value] = $2->value;
        !            93:                $2->value = dot->value|RLCMV;
        !            94:        }
        !            95:        | MVINS POP fref CM udst close = {
        !            96:                $$ = $1->value|$5;
        !            97:                reloc[dot->value] = $3->value;
        !            98:                $3->value = dot->value|RLCPOP;
        !            99:        }
        !           100:        | MVINS expr CM dst close = {
        !           101:                $$ = $1->value|cksrc($2->xvalue&0377, $4);
        !           102:        }
        !           103:        | MVINS REG CM dst close = {
        !           104:                $$ = $1->value|SRCBRG|SELA|ckreg($2->value, $4);
        !           105:        }
        !           106:        | MVINS oreg CM dst close = {
        !           107:                $$ = $1->value|$2|$4;
        !           108:        }
        !           109:        | SFINS REG CM dst close = {
        !           110:                $$ = $1->value|SRCBRG|ckreg($2->value, $4);
        !           111:        }
        !           112:        | SFINS REG close = {
        !           113:                $$ = $1->value|SRCBRG|$2->value|DSTREG;
        !           114:        }
        !           115:        | DFINS reg2 CM REG CM dst close = {
        !           116:                $$ = $1->value|$2|ckreg($4->value, $6);
        !           117:        }
        !           118:        | DFINS reg2 CM REG close = {
        !           119:                $$ = $1->value|$2|$4->value|DSTREG;
        !           120:        }
        !           121:        | BRINS expr close = {
        !           122:                $$ = $1->value|($2->xvalue&0377)|(($2->xvalue&01400)<<3);
        !           123:                if ((dot->value&~01777) != ($2->xvalue&~01777))
        !           124:                        yyerror("branch out of range");
        !           125:        }
        !           126:        | BRINS fref close = {
        !           127:                $$ = $1->value;
        !           128:                reloc[dot->value] = $2->value;
        !           129:                $2->value = dot->value|RLCBR;
        !           130:        }
        !           131:        | BRINS LP func RP page close = {
        !           132:                $$ = $1->value|$3|$5;
        !           133:        }
        !           134:        | JMPINS expr close = {
        !           135:                $$ = $1->value|($2->xvalue&0377);
        !           136:        }
        !           137:        | JMPINS fref close = {
        !           138:                $$ = $1->value;
        !           139:                reloc[dot->value] = $2->value;
        !           140:                $2->value = dot->value|RLCMV;
        !           141:        }
        !           142:        | JMPINS LP func RP close = {
        !           143:                $$ = $1->value|$3;
        !           144:        }
        !           145:        ;
        !           146: 
        !           147: func:  REG = {
        !           148:                $$ = $1->value|SRCBRG|SELA;
        !           149:        }
        !           150:        | reg2 = {
        !           151:                $$ = $1|SELB;
        !           152:        }
        !           153:        | SFINS CM REG = {
        !           154:                $$ = $1->value|$3->value|SRCBRG;
        !           155:        }
        !           156:        | DFINS CM reg2 CM REG = {
        !           157:                $$ = $1->value|$3|$5->value;
        !           158:        }
        !           159:        ;
        !           160: 
        !           161: page:  /* empty */ = {
        !           162:                $$ = 0;
        !           163:        }
        !           164:        | CM PAGE = {
        !           165:                $$ = $2->value;
        !           166:        }
        !           167:        | CM POP val = {
        !           168:                $$ = ($3->xvalue&01400)<<3;
        !           169:        }
        !           170:        | CM POP fref = {
        !           171:                $$ = 0;
        !           172:                reloc[dot->value] = $3->value;
        !           173:                $3->value = dot->value|RLCPG;
        !           174:        }
        !           175:        ;
        !           176: 
        !           177: fref:
        !           178:        UNAME
        !           179:        | TNAME
        !           180:        ;
        !           181: 
        !           182: dst:    MINUS = {
        !           183:                $$ = 0;
        !           184:        }
        !           185:        | pdst
        !           186:        | pdst BAR pdst = {
        !           187:                $$ = ckdst($1, $3);
        !           188:        }
        !           189:        | pdst BAR pdst BAR pdst = {
        !           190:                $$ = ckdst(ckdst($1, $3), $5);
        !           191:        }
        !           192:        ;
        !           193: 
        !           194: pdst:  REG = {
        !           195:                $$ = $1->value|DSTREG;
        !           196:        }
        !           197:        | BRG = {
        !           198:                $$ = DSTBRG;
        !           199:        }
        !           200:        | MEM = {
        !           201:                $$ = DSTMEM;
        !           202:        }
        !           203:        | REGL = {
        !           204:                $$ = $1->value|DSTREGL;
        !           205:        }
        !           206:        | REGH = {
        !           207:                $$ = $1->value|DSTREGH;
        !           208:        }
        !           209:        | BRG RS = {
        !           210:                $$ = DSTBGRS;
        !           211:        }
        !           212:        | MAR = {
        !           213:                $$ = DSTMAR;
        !           214:        }
        !           215:        | MAR INC = {
        !           216:                $$ = DSTMARI;
        !           217:        }
        !           218:        | POP MAR = {
        !           219:                $$ = DSTMARP;
        !           220:        }
        !           221:        | PCR = {
        !           222:                $$ = DSTPCH|DSTREGH;
        !           223:        }
        !           224:        ;
        !           225: 
        !           226: udst:  sdst
        !           227:        | sdst BAR sdst = {
        !           228:                $$ = ckdst($1, $3);
        !           229:        }
        !           230:        ;
        !           231: 
        !           232: sdst:  BRG = {
        !           233:                $$ = DSTBRG;
        !           234:        }
        !           235:        | MEM = {
        !           236:                $$ = DSTMEM;
        !           237:        }
        !           238:        | MAR = {
        !           239:                $$ = DSTMAR;
        !           240:        }
        !           241:        | MAR INC = {
        !           242:                $$ = DSTMARI;
        !           243:        }
        !           244:        | POP MAR = {
        !           245:                $$ = DSTMARP;
        !           246:        }
        !           247:        ;
        !           248: 
        !           249: oreg:  reg2 = {
        !           250:                $$ = $1|SELB;
        !           251:        }
        !           252:        | REGL = {
        !           253:                $$ = ($1->value<<4)|SRCREGL;
        !           254:        }
        !           255:        | REGH = {
        !           256:                $$ = ($1->value<<4)|SRCREGH;
        !           257:        }
        !           258:        | boreg = {
        !           259:                $$ = ($1<<4)|SRCREGH;
        !           260:        }
        !           261:        ;
        !           262: 
        !           263: reg2:  BRG = {
        !           264:                $$ = SRCBRG;
        !           265:        }
        !           266:        | MEM = {
        !           267:                $$ = SRCMEM;
        !           268:        }
        !           269:        ;
        !           270: 
        !           271: boreg: MAR = {
        !           272:                $$ = SRCMARL;
        !           273:        }
        !           274:        | POP MAR = {
        !           275:                $$ = SRCMARH;
        !           276:        }
        !           277:        | PC = {
        !           278:                $$ = SRCPCL;
        !           279:        }
        !           280:        | POP PC = {
        !           281:                $$ = SRCPCH;
        !           282:        }
        !           283:        ;
        !           284: 
        !           285: expr:  val
        !           286:        | LP expr RP = {
        !           287:                $$ = $2;
        !           288:        }
        !           289:        | expr BAR expr = {
        !           290:                $1->xvalue |= $3->xvalue;
        !           291:        }
        !           292:        | expr XOR expr = {
        !           293:                $1->xvalue ^= $3->xvalue;
        !           294:        }
        !           295:        | expr AND expr = {
        !           296:                $1->xvalue &= $3->xvalue;
        !           297:        }
        !           298:        | expr LS expr = {
        !           299:                $1->xvalue <<= $3->xvalue;
        !           300:        }
        !           301:        | expr RS expr = {
        !           302:                $1->xvalue >>= $3->xvalue;
        !           303:        }
        !           304:        | expr PLUS expr = {
        !           305:                $1->xvalue += $3->xvalue;
        !           306:        }
        !           307:        | expr MINUS expr = {
        !           308:                $1->xvalue -= $3->xvalue;
        !           309:        }
        !           310:        | expr MUL expr = {
        !           311:                $1->xvalue *= $3->xvalue;
        !           312:        }
        !           313:        | expr DIV expr = {
        !           314:                $1->xvalue /= $3->xvalue;
        !           315:        }
        !           316:        | NOT expr = {
        !           317:                $2->xvalue = ~$2->xvalue;
        !           318:                $$ = $2;
        !           319:        }
        !           320:        | POP expr = {
        !           321:                $2->xvalue = ($2->xvalue>>8)&0377;
        !           322:                $$ = $2;
        !           323:        }
        !           324:        | MINUS expr %prec POP = {
        !           325:                $2->xvalue = -$2->xvalue;
        !           326:                $$ = $2;
        !           327:        }
        !           328:        ;
        !           329: 
        !           330: val:   DNAME = {
        !           331:                $$ = xp++;
        !           332:                $$->xtype = XABS;
        !           333:                $$->xvalue = $1->value;
        !           334:        }
        !           335:        | INT = {
        !           336:                $$ = xp++;
        !           337:                $$->xtype = XABS;
        !           338:                $$->xvalue = $1;
        !           339:        }
        !           340:        ;
        !           341: 
        !           342: pseudo: SEG = {
        !           343:                if (dot->type==XTEXT)
        !           344:                        textsv = dot->value;
        !           345:                else    datasv = dot->value;
        !           346:                dot->type = $1->value;
        !           347:                if (dot->type==XTEXT)
        !           348:                        dot->value = textsv;
        !           349:                else    dot->value = datasv;
        !           350:        }
        !           351:        | ORG expr = {
        !           352:                if ($2->xvalue<0 || $2->xvalue>=NKMCI)
        !           353:                        yyerror("illegal org value");
        !           354:                else    dot->value = $2->xvalue;
        !           355:        }
        !           356:        | data explist
        !           357:        ;
        !           358: 
        !           359: data:  DATA = {
        !           360:                if (dot->type != XDATA) {
        !           361:                        yyerror("no data in text");
        !           362:                }
        !           363:                dinc = $1->value;
        !           364:        }
        !           365:        ;
        !           366: 
        !           367: explist: outexpr
        !           368:        | explist CM outexpr
        !           369:        ;
        !           370: 
        !           371: outexpr: expr = {
        !           372:                putdat($1->xvalue&0377);
        !           373:                if (dinc==2)
        !           374:                        putdat(($1->xvalue>>8)&0377);
        !           375:                xp = explist;
        !           376:        }
        !           377:        ;
        !           378: 
        !           379: debug: db
        !           380:        | db INT = {
        !           381:                $1->xtype = $2;
        !           382:        }
        !           383:        | db STR = {
        !           384:                $1->xtype = (int)$2;
        !           385:        }
        !           386:        ;
        !           387: 
        !           388: db:    DEBUG = {
        !           389:                $$ = xp++;
        !           390:                $$->xvalue = $1->value;
        !           391:                $$->xtype = 0;
        !           392:        }
        !           393:        ;
        !           394: %%
        !           395: 
        !           396: yyerror(s, a)
        !           397: char *s;
        !           398: {
        !           399:        anyerrs++;
        !           400:        if (infile)
        !           401:                fprintf(stderr, "%s:", infile);
        !           402:        fprintf(stderr, "%d:", lineno);
        !           403:        fprintf(stderr, s, a);
        !           404:        fprintf(stderr, "\n");
        !           405: }
        !           406: 
        !           407: #include "kas0.yl"

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.