OpenCores
URL https://opencores.org/ocsvn/ao68000/ao68000/trunk

Subversion Repositories ao68000

[/] [ao68000/] [trunk/] [tests/] [compare_with_winuae/] [winuae/] [build68k.c] - Blame information for rev 12

Details | Compare with Previous | View Log

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

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.