Annotation of researchv9/cmd/adb/vax/opset.c, revision 1.1

1.1     ! root        1: /*
        !             2:  * instruction decoding
        !             3:  * VAX instructions; works only on a VAX for now
        !             4:  */
        !             5: 
        !             6: #include "defs.h"
        !             7: #include "space.h"
        !             8: 
        !             9: #define        LOBYTE  0377
        !            10: 
        !            11: /* instruction printing */
        !            12: 
        !            13: /*
        !            14:  * Argument access types
        !            15:  */
        !            16: #define ACCA   (8<<3)  /* address only */
        !            17: #define ACCR   (1<<3)  /* read */
        !            18: #define ACCW   (2<<3)  /* write */
        !            19: #define ACCM   (3<<3)  /* modify */
        !            20: #define ACCB   (4<<3)  /* branch displacement */
        !            21: #define ACCI   (5<<3)  /* XFC code */
        !            22: 
        !            23: /*
        !            24:  * Argument data types
        !            25:  */
        !            26: #define TYPB   0       /* byte */
        !            27: #define TYPW   1       /* word */
        !            28: #define TYPL   2       /* long */
        !            29: #define TYPQ   3       /* quad */
        !            30: #define TYPF   4       /* floating */
        !            31: #define TYPD   5       /* double floating */
        !            32: 
        !            33: typedef        struct optab    *OPTAB;
        !            34: struct optab {
        !            35:        char *iname;
        !            36:        char val;
        !            37:        char nargs;
        !            38:        char argtype[6];
        !            39: } optab[];
        !            40: char *regname[];
        !            41: char *fltimm[];
        !            42: static ADDR    incp;
        !            43: 
        !            44: int ioptab[256]; /* index by opcode to optab */
        !            45: 
        !            46: mkioptab() {/* set up ioptab */
        !            47:        register OPTAB p=optab;
        !            48: 
        !            49:        while (p->iname){
        !            50:                ioptab[p->val&LOBYTE]=p-optab;
        !            51:                p++;
        !            52:        }
        !            53: }
        !            54: 
        !            55: printins(idsp)
        !            56: {
        !            57:        register short argno;   /* argument index */
        !            58:        register short mode;    /* mode */
        !            59:        register char **r;      /* register name */
        !            60:        register unsigned char ins;
        !            61:        long    d;              /* assembled byte, word, long or float */
        !            62:        long    snarf();
        !            63:        register char * ap;
        !            64:        register OPTAB  ip;
        !            65: 
        !            66:        ins = cget(dot, idsp);
        !            67:        chkerr();
        !            68:        ip=optab+ioptab[ins];
        !            69:        printf("%s%8t",ip->iname);
        !            70:        incp = 1;
        !            71:        ap = ip->argtype;
        !            72:        for (argno=0; argno<ip->nargs; argno++,ap++) {
        !            73:                var[argno] = 0x80000000;
        !            74:                if (argno!=0) printc(',');
        !            75: top:
        !            76:                if (*ap&ACCB)
        !            77:                        mode = 0xAF + ((*ap&7)<<5);  /* branch displacement */
        !            78:                else{
        !            79:                        mode = cget(inkdot((WORD)incp), idsp);
        !            80:                        chkerr();
        !            81:                        ++incp;
        !            82:                }
        !            83:                if (mode & 0300) {/* not short literal */
        !            84:                        r = &regname[mode&0xF];
        !            85:                        mode >>= 4;
        !            86:                        switch ((int)mode) {
        !            87:                        case 4: /* [r] */
        !            88:                                printf("[%s]",*r);
        !            89:                                goto top;
        !            90:                        case 5: /* r */
        !            91:                                printf("%s",*r);
        !            92:                                break;
        !            93:                        case 6: /* (r) */
        !            94:                                printf("(%s)",*r);
        !            95:                                break;
        !            96:                        case 7: /* -(r) */
        !            97:                                printf("-(%s)",*r);
        !            98:                                break;
        !            99:                        case 9: /* *(r)+ */
        !           100:                                printc('*');
        !           101:                        case 8: /* (r)+ */
        !           102:                                if (r==(regname+0xF)) {
        !           103:                                        printc('$');
        !           104:                                        if (mode==9){   /* PC absolute, always 4 bytes*/
        !           105:                                                d = snarf(4, idsp);
        !           106:                                                goto disp;
        !           107:                                        }
        !           108:                                        switch(*ap&7){
        !           109:                                        case TYPB:
        !           110:                                                d = snarf(1, idsp);
        !           111:                                                goto disp;
        !           112:                                        case TYPW:
        !           113:                                                d = snarf(2, idsp);
        !           114:                                                goto disp;
        !           115:                                        case TYPL:
        !           116:                                                d = snarf(4, idsp);
        !           117:                                                goto disp;
        !           118:                                        case TYPQ:
        !           119:                                                d = snarf(4, idsp);
        !           120:                                                printquad(d, snarf(4, idsp));
        !           121:                                                break;
        !           122:                                        case TYPF:
        !           123:                                                printfloating(snarf(4, idsp), 0L);
        !           124:                                                break;
        !           125:                                        case TYPD:
        !           126:                                                d = snarf(4, idsp);
        !           127:                                                printfloating(d, snarf(4, idsp));
        !           128:                                                break;
        !           129:                                        } /*end of type switch */
        !           130:                                        /*
        !           131:                                         *      here only for TYPQ, TYPf, TYPD
        !           132:                                         *      others went to disp
        !           133:                                         */
        !           134:                                } else {        /*it's not PC immediate or abs*/
        !           135:                                        printf("(%s)+",*r);
        !           136:                                }
        !           137:                                break;
        !           138:                        case 0xB:       /* byte displacement defferred*/
        !           139:                                printc('*');
        !           140:                        case 0xA:       /* byte displacement */
        !           141:                                d = snarf(1, idsp);
        !           142:                                goto disp;
        !           143:                        case 0xD:       /* word displacement deferred */
        !           144:                                printc('*');
        !           145:                        case 0xC:       /* word displacement */
        !           146:                                d = snarf(2, idsp);
        !           147:                                goto disp;
        !           148:                        case 0xF:       /* long displacement deferred */
        !           149:                                printc('*');
        !           150:                        case 0xE:       /* long displacement */
        !           151:                                d = snarf(4, idsp);
        !           152:                                goto disp;
        !           153: disp:
        !           154:                                var[argno]=d;
        !           155:                                if (r==(regname+0xF) && mode>=0xA){
        !           156:                                        /* PC offset addressing */
        !           157:                                        var[argno] += dot+incp;
        !           158:                                }
        !           159:                                psymoff(var[argno],ANYSP,"");
        !           160:                                if (r != regname+0xF)
        !           161:                                        printf("(%s)",*r);
        !           162:                                break;
        !           163:                        } /* end of the mode switch */
        !           164:                } else {   /* short literal */
        !           165:                        var[argno]=mode;
        !           166:                        if((*ap&7)==TYPF || (*ap&7)==TYPD)
        !           167:                                printf("$%s",fltimm[mode]);
        !           168:                        else
        !           169:                                printf("$%r",mode);
        !           170:                }
        !           171:        }
        !           172:        if (ins==0xCF || ins==0xAF || ins==0x8F) {/* CASEx instr */
        !           173:                for (argno=0; argno<=var[2]; ++argno) {
        !           174:                        printc(EOR);
        !           175:                        printf("    %R:  ",argno+var[1]);
        !           176:                        d=sget(inkdot((WORD)incp+argno+argno),idsp);
        !           177:                        if (d&0x8000) d -= 0x10000;
        !           178:                        psymoff((WORD)(inkdot((WORD)incp)+d),ANYSP,"");
        !           179:                }
        !           180:                incp += var[2]+var[2]+2;
        !           181:        }
        !           182:        dotinc=incp;
        !           183: }
        !           184: 
        !           185: /*
        !           186:  *     magic values to mung an offset to a register into
        !           187:  *     something that psymoff can understand.. all magic
        !           188:  */
        !           189: /* 0   1       2       3       4 */
        !           190: static long magic_masks[5] =   {
        !           191:        0,      0x80,   0x8000, 0,      0};
        !           192: static long magic_compl[5] =   {
        !           193:        0,      0x100,  0x10000,0,      0};
        !           194: 
        !           195: static
        !           196: long
        !           197: snarf(nbytes, idsp)
        !           198: int    nbytes;
        !           199: {
        !           200:        register        int     byteindex;
        !           201:        union Long{
        !           202:                char    long_bytes[4];
        !           203:                long    long_value;
        !           204:        } d;
        !           205: 
        !           206:        d.long_value = 0;
        !           207:        for (byteindex = 0; byteindex < nbytes; byteindex++){
        !           208:                d.long_bytes[byteindex] = cget(inkdot((WORD)incp), idsp);
        !           209:                chkerr();
        !           210:                ++incp;
        !           211:        }
        !           212:        if (d.long_value & magic_masks[nbytes])
        !           213:                d.long_value -= magic_compl[nbytes];
        !           214:        return(d.long_value);
        !           215: }
        !           216: 
        !           217: static
        !           218: printfloating(word_first, word_last)
        !           219: long   word_first;
        !           220: long   word_last;
        !           221: {
        !           222:        union   Double{
        !           223:                struct {
        !           224:                        long    word_first;
        !           225:                        long    word_last;
        !           226:                } composite;
        !           227:                double  dvalue;
        !           228:        } reconstructed;
        !           229: 
        !           230:        reconstructed.composite.word_first = word_first;
        !           231:        reconstructed.composite.word_last = word_last;
        !           232:        fpout('F', (char *)&reconstructed.dvalue);
        !           233: }
        !           234: 
        !           235: static
        !           236: printquad(word_first, word_last)
        !           237: long   word_first;
        !           238: long   word_last;
        !           239: {
        !           240:        union Quad {
        !           241:                char    quad_bytes[8];
        !           242:                long    quad_long[2];
        !           243:        } reconstructed;
        !           244:        int     leading_zero = 1;
        !           245:        int     byteindex;
        !           246:        int     nibbleindex;
        !           247:        register        int     ch;
        !           248: 
        !           249:        reconstructed.quad_long[0] = word_first;
        !           250:        reconstructed.quad_long[1] = word_last;
        !           251:        for (byteindex = 7; byteindex >= 0; --byteindex){
        !           252:                for (nibbleindex = 4; nibbleindex >= 0; nibbleindex -= 4){
        !           253:                        ch = (reconstructed.quad_bytes[byteindex]
        !           254:                            >> nibbleindex) & 0x0F;
        !           255:                        if ( ! (leading_zero &= (ch == 0) ) ){
        !           256:                                if (ch <= 0x09)
        !           257:                                        printc(ch + '0');
        !           258:                                else
        !           259:                                        printc(ch - 0x0A + 'a');
        !           260:                        }
        !           261:                }
        !           262:        }
        !           263: }

unix.superglobalmegacorp.com

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