Annotation of hatari/src/cpu/build68k.c, revision 1.1

1.1     ! root        1: /*
        !             2:  * UAE - The Un*x Amiga Emulator
        !             3:  *
        !             4:  * Read 68000 CPU specs from file "table68k" and build table68k.c
        !             5:  *
        !             6:  * Copyright 1995,1996 Bernd Schmidt
        !             7:  */
        !             8: 
        !             9: #include <stdlib.h>
        !            10: //#include <tchar.h>
        !            11: #include <string.h>
        !            12: #include <assert.h>
        !            13: #include <ctype.h>
        !            14: 
        !            15: #define TCHAR char
        !            16: 
        !            17: #include "sysconfig.h"
        !            18: #include "sysdeps.h"
        !            19: 
        !            20: 
        !            21: #include "readcpu.h"
        !            22: 
        !            23: static FILE *tablef;
        !            24: static int nextch = 0;
        !            25: 
        !            26: static void getnextch(void)
        !            27: {
        !            28:     do {
        !            29:        nextch = fgetc(tablef);
        !            30:        if (nextch == '%') {
        !            31:            do {
        !            32:                nextch = fgetc(tablef);
        !            33:            } while (nextch != EOF && nextch != '\n');
        !            34:        }
        !            35:     } while (nextch != EOF && isspace(nextch));
        !            36: }
        !            37: 
        !            38: static int nextchtohex(void)
        !            39: {
        !            40:     switch (isupper (nextch) ? tolower (nextch) : nextch) {
        !            41:      case '0': return 0;
        !            42:      case '1': return 1;
        !            43:      case '2': return 2;
        !            44:      case '3': return 3;
        !            45:      case '4': return 4;
        !            46:      case '5': return 5;
        !            47:      case '6': return 6;
        !            48:      case '7': return 7;
        !            49:      case '8': return 8;
        !            50:      case '9': return 9;
        !            51:      case 'a': return 10;
        !            52:      case 'b': return 11;
        !            53:      case 'c': return 12;
        !            54:      case 'd': return 13;
        !            55:      case 'e': return 14;
        !            56:      case 'f': return 15;
        !            57:      default: abort();
        !            58:     }
        !            59: }
        !            60: 
        !            61: int main(int argc, char **argv)
        !            62: {
        !            63:     int no_insns = 0;
        !            64: 
        !            65:     printf ("#include \"sysconfig.h\"\n");
        !            66:     printf ("#include \"sysdeps.h\"\n");
        !            67:     printf ("#include \"readcpu.h\"\n");
        !            68:     printf ("struct instr_def defs68k[] = {\n");
        !            69: #if 0
        !            70:     tablef = fopen("table68k","r");
        !            71:     if (tablef == NULL) {
        !            72:        fprintf(stderr, "table68k not found\n");
        !            73:        exit(1);
        !            74:     }
        !            75: #else
        !            76:     tablef = stdin;
        !            77: #endif
        !            78:     getnextch();
        !            79:     while (nextch != EOF) {
        !            80:        int cpulevel, plevel, sduse;
        !            81:        int i;
        !            82: 
        !            83:        char patbits[16];
        !            84:        char opcstr[256];
        !            85:        int bitpos[16];
        !            86:        int flagset[5], flaguse[5];
        !            87: 
        !            88:        unsigned int bitmask,bitpattern;
        !            89:        int n_variable;
        !            90: 
        !            91:        n_variable = 0;
        !            92:        bitmask = bitpattern = 0;
        !            93:        memset (bitpos, 0, sizeof(bitpos));
        !            94:        for(i=0; i<16; i++) {
        !            95:            int currbit;
        !            96:            bitmask <<= 1;
        !            97:            bitpattern <<= 1;
        !            98: 
        !            99:            switch (nextch) {
        !           100:             case '0': currbit = bit0; bitmask |= 1; break;
        !           101:             case '1': currbit = bit1; bitmask |= 1; bitpattern |= 1; break;
        !           102:             case 'c': currbit = bitc; break;
        !           103:             case 'C': currbit = bitC; break;
        !           104:             case 'f': currbit = bitf; break;
        !           105:             case 'i': currbit = biti; break;
        !           106:             case 'I': currbit = bitI; break;
        !           107:             case 'j': currbit = bitj; break;
        !           108:             case 'J': currbit = bitJ; break;
        !           109:             case 'k': currbit = bitk; break;
        !           110:             case 'K': currbit = bitK; break;
        !           111:             case 's': currbit = bits; break;
        !           112:             case 'S': currbit = bitS; break;
        !           113:             case 'd': currbit = bitd; break;
        !           114:             case 'D': currbit = bitD; break;
        !           115:             case 'r': currbit = bitr; break;
        !           116:             case 'R': currbit = bitR; break;
        !           117:             case 'z': currbit = bitz; break;
        !           118:             case 'p': currbit = bitp; break;
        !           119:             default: abort();
        !           120:            }
        !           121:            if (!(bitmask & 1)) {
        !           122:                bitpos[n_variable] = currbit;
        !           123:                n_variable++;
        !           124:            }
        !           125: 
        !           126:            if (nextch == '0' || nextch == '1')
        !           127:                bitmask |= 1;
        !           128:            if (nextch == '1')
        !           129:                bitpattern |= 1;
        !           130:            patbits[i] = nextch;
        !           131:            getnextch();
        !           132:        }
        !           133: 
        !           134:        while (isspace(nextch) || nextch == ':') /* Get CPU and privilege level */
        !           135:            getnextch();
        !           136: 
        !           137:        switch (nextch) {
        !           138:         case '0': cpulevel = 0; break;
        !           139:         case '1': cpulevel = 1; break;
        !           140:         case '2': cpulevel = 2; break;
        !           141:         case '3': cpulevel = 3; break;
        !           142:         case '4': cpulevel = 4; break;
        !           143:         case '5': cpulevel = 5; break;
        !           144:         case '6': cpulevel = 6; break;
        !           145:         case '7': cpulevel = 7; break;
        !           146:         default: abort();
        !           147:        }
        !           148:        getnextch();
        !           149: 
        !           150:        switch (nextch) {
        !           151:         case '0': plevel = 0; break;
        !           152:         case '1': plevel = 1; break;
        !           153:         case '2': plevel = 2; break;
        !           154:         case '3': plevel = 3; break;
        !           155:         default: abort();
        !           156:        }
        !           157:        getnextch();
        !           158: 
        !           159:        while (isspace(nextch))                   /* Get flag set information */
        !           160:            getnextch();
        !           161: 
        !           162:        if (nextch != ':')
        !           163:            abort();
        !           164: 
        !           165:        for(i = 0; i < 5; i++) {
        !           166:            getnextch();
        !           167:            switch(nextch){
        !           168:             case '-': flagset[i] = fa_unset; break;
        !           169:             case '/': flagset[i] = fa_isjmp; break;
        !           170:             case '+': flagset[i] = fa_isbranch; break;
        !           171:             case '0': flagset[i] = fa_zero; break;
        !           172:             case '1': flagset[i] = fa_one; break;
        !           173:             case 'x': flagset[i] = fa_dontcare; break;
        !           174:             case '?': flagset[i] = fa_unknown; break;
        !           175:             default: flagset[i] = fa_set; break;
        !           176:            }
        !           177:        }
        !           178: 
        !           179:        getnextch();
        !           180:        while (isspace(nextch))
        !           181:            getnextch();
        !           182: 
        !           183:        if (nextch != ':')                        /* Get flag used information */
        !           184:            abort();
        !           185: 
        !           186:        for(i = 0; i < 5; i++) {
        !           187:            getnextch();
        !           188:            switch(nextch){
        !           189:             case '-': flaguse[i] = fu_unused; break;
        !           190:             case '/': flaguse[i] = fu_isjmp; break;
        !           191:             case '+': flaguse[i] = fu_maybecc; break;
        !           192:             case '?': flaguse[i] = fu_unknown; break;
        !           193:             default: flaguse[i] = fu_used; break;
        !           194:            }
        !           195:        }
        !           196: 
        !           197:        getnextch();
        !           198:        while (isspace(nextch))
        !           199:            getnextch();
        !           200: 
        !           201:        if (nextch != ':')                        /* Get source/dest usage information */
        !           202:            abort();
        !           203: 
        !           204:        getnextch();
        !           205:        sduse = nextchtohex() << 4;
        !           206:        getnextch();
        !           207:        sduse |= nextchtohex();
        !           208: 
        !           209:        getnextch();
        !           210:        while (isspace(nextch))
        !           211:            getnextch();
        !           212: 
        !           213:        if (nextch != ':')
        !           214:            abort();
        !           215: 
        !           216:        if (fgets(opcstr, 250, tablef) == NULL) {
        !           217:            perror("fgets");
        !           218:            return -1;
        !           219:        }
        !           220:        getnextch();
        !           221:        {
        !           222:            int j;
        !           223:            /* Remove superfluous spaces from the string */
        !           224:            char *opstrp = opcstr, *osendp;
        !           225:            char tmp[100], *p;
        !           226:            int slen = 0;
        !           227: 
        !           228:            while (isspace(*opstrp))
        !           229:                opstrp++;
        !           230: 
        !           231:            osendp = opstrp;
        !           232:            while (*osendp) {
        !           233:                if (!isspace (*osendp))
        !           234:                    slen = osendp - opstrp + 1;
        !           235:                osendp++;
        !           236:            }
        !           237:            opstrp[slen] = 0;
        !           238: 
        !           239:            if (no_insns > 0)
        !           240:                printf(",\n");
        !           241:            no_insns++;
        !           242:            strcpy (tmp, opstrp);
        !           243:            strcat (tmp, " ");
        !           244:            p = tmp;
        !           245:            while (!isspace(*p++));
        !           246:            *p = 0;
        !           247:            printf("/* %s */\n", tmp);
        !           248:            printf("{0x%04X,%2d,{", bitpattern, n_variable);
        !           249:            for (j = 0; j < 16; j++) {
        !           250:                printf("%2d", bitpos[j]);
        !           251:                if (j < 15)
        !           252:                    printf(",");
        !           253:            }
        !           254:            printf ("},0x%04X,%d,%d,{", bitmask, cpulevel, plevel);
        !           255:            for(i = 0; i < 5; i++) {
        !           256:                printf("{%d,%d}%s", flaguse[i], flagset[i], i == 4 ? "" : ",");
        !           257:            }
        !           258:            printf("},%2d,\"%s\"}", sduse, opstrp);
        !           259:        }
        !           260:     }
        !           261:     printf("};\nint n_defs68k = %d;\n", no_insns);
        !           262:     return 0;
        !           263: }

unix.superglobalmegacorp.com

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