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

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [gnu-old/] [gdb-6.8/] [sim/] [m32r/] [cpu2.h] - Blame information for rev 840

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 24 jeremybenn
/* CPU family header for m32r2f.
2
 
3
THIS FILE IS MACHINE GENERATED WITH CGEN.
4
 
5
Copyright 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003 Free Software Foundation, Inc.
6
 
7
This file is part of the GNU simulators.
8
 
9
This program is free software; you can redistribute it and/or modify
10
it under the terms of the GNU General Public License as published by
11
the Free Software Foundation; either version 3 of the License, or
12
(at your option) any later version.
13
 
14
This program is distributed in the hope that it will be useful,
15
but WITHOUT ANY WARRANTY; without even the implied warranty of
16
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17
GNU General Public License for more details.
18
 
19
You should have received a copy of the GNU General Public License
20
along with this program.  If not, see <http://www.gnu.org/licenses/>.
21
 
22
*/
23
 
24
#ifndef CPU_M32R2F_H
25
#define CPU_M32R2F_H
26
 
27
/* Maximum number of instructions that are fetched at a time.
28
   This is for LIW type instructions sets (e.g. m32r).  */
29
#define MAX_LIW_INSNS 2
30
 
31
/* Maximum number of instructions that can be executed in parallel.  */
32
#define MAX_PARALLEL_INSNS 2
33
 
34
/* CPU state information.  */
35
typedef struct {
36
  /* Hardware elements.  */
37
  struct {
38
  /* program counter */
39
  USI h_pc;
40
#define GET_H_PC() CPU (h_pc)
41
#define SET_H_PC(x) (CPU (h_pc) = (x))
42
  /* general registers */
43
  SI h_gr[16];
44
#define GET_H_GR(a1) CPU (h_gr)[a1]
45
#define SET_H_GR(a1, x) (CPU (h_gr)[a1] = (x))
46
  /* control registers */
47
  USI h_cr[16];
48
#define GET_H_CR(index) m32r2f_h_cr_get_handler (current_cpu, index)
49
#define SET_H_CR(index, x) \
50
do { \
51
m32r2f_h_cr_set_handler (current_cpu, (index), (x));\
52
;} while (0)
53
  /* accumulator */
54
  DI h_accum;
55
#define GET_H_ACCUM() m32r2f_h_accum_get_handler (current_cpu)
56
#define SET_H_ACCUM(x) \
57
do { \
58
m32r2f_h_accum_set_handler (current_cpu, (x));\
59
;} while (0)
60
  /* accumulators */
61
  DI h_accums[2];
62
#define GET_H_ACCUMS(index) m32r2f_h_accums_get_handler (current_cpu, index)
63
#define SET_H_ACCUMS(index, x) \
64
do { \
65
m32r2f_h_accums_set_handler (current_cpu, (index), (x));\
66
;} while (0)
67
  /* condition bit */
68
  BI h_cond;
69
#define GET_H_COND() CPU (h_cond)
70
#define SET_H_COND(x) (CPU (h_cond) = (x))
71
  /* psw part of psw */
72
  UQI h_psw;
73
#define GET_H_PSW() m32r2f_h_psw_get_handler (current_cpu)
74
#define SET_H_PSW(x) \
75
do { \
76
m32r2f_h_psw_set_handler (current_cpu, (x));\
77
;} while (0)
78
  /* backup psw */
79
  UQI h_bpsw;
80
#define GET_H_BPSW() CPU (h_bpsw)
81
#define SET_H_BPSW(x) (CPU (h_bpsw) = (x))
82
  /* backup bpsw */
83
  UQI h_bbpsw;
84
#define GET_H_BBPSW() CPU (h_bbpsw)
85
#define SET_H_BBPSW(x) (CPU (h_bbpsw) = (x))
86
  /* lock */
87
  BI h_lock;
88
#define GET_H_LOCK() CPU (h_lock)
89
#define SET_H_LOCK(x) (CPU (h_lock) = (x))
90
  } hardware;
91
#define CPU_CGEN_HW(cpu) (& (cpu)->cpu_data.hardware)
92
} M32R2F_CPU_DATA;
93
 
94
/* Cover fns for register access.  */
95
USI m32r2f_h_pc_get (SIM_CPU *);
96
void m32r2f_h_pc_set (SIM_CPU *, USI);
97
SI m32r2f_h_gr_get (SIM_CPU *, UINT);
98
void m32r2f_h_gr_set (SIM_CPU *, UINT, SI);
99
USI m32r2f_h_cr_get (SIM_CPU *, UINT);
100
void m32r2f_h_cr_set (SIM_CPU *, UINT, USI);
101
DI m32r2f_h_accum_get (SIM_CPU *);
102
void m32r2f_h_accum_set (SIM_CPU *, DI);
103
DI m32r2f_h_accums_get (SIM_CPU *, UINT);
104
void m32r2f_h_accums_set (SIM_CPU *, UINT, DI);
105
BI m32r2f_h_cond_get (SIM_CPU *);
106
void m32r2f_h_cond_set (SIM_CPU *, BI);
107
UQI m32r2f_h_psw_get (SIM_CPU *);
108
void m32r2f_h_psw_set (SIM_CPU *, UQI);
109
UQI m32r2f_h_bpsw_get (SIM_CPU *);
110
void m32r2f_h_bpsw_set (SIM_CPU *, UQI);
111
UQI m32r2f_h_bbpsw_get (SIM_CPU *);
112
void m32r2f_h_bbpsw_set (SIM_CPU *, UQI);
113
BI m32r2f_h_lock_get (SIM_CPU *);
114
void m32r2f_h_lock_set (SIM_CPU *, BI);
115
 
116
/* These must be hand-written.  */
117
extern CPUREG_FETCH_FN m32r2f_fetch_register;
118
extern CPUREG_STORE_FN m32r2f_store_register;
119
 
120
typedef struct {
121
  int empty;
122
} MODEL_M32R2_DATA;
123
 
124
/* Instruction argument buffer.  */
125
 
126
union sem_fields {
127
  struct { /* no operands */
128
    int empty;
129
  } fmt_empty;
130
  struct { /*  */
131
    UINT f_uimm8;
132
  } sfmt_clrpsw;
133
  struct { /*  */
134
    UINT f_uimm4;
135
  } sfmt_trap;
136
  struct { /*  */
137
    IADDR i_disp24;
138
    unsigned char out_h_gr_SI_14;
139
  } sfmt_bl24;
140
  struct { /*  */
141
    IADDR i_disp8;
142
    unsigned char out_h_gr_SI_14;
143
  } sfmt_bl8;
144
  struct { /*  */
145
    SI f_imm1;
146
    UINT f_accd;
147
    UINT f_accs;
148
  } sfmt_rac_dsi;
149
  struct { /*  */
150
    SI* i_dr;
151
    UINT f_hi16;
152
    UINT f_r1;
153
    unsigned char out_dr;
154
  } sfmt_seth;
155
  struct { /*  */
156
    SI* i_src1;
157
    UINT f_accs;
158
    UINT f_r1;
159
    unsigned char in_src1;
160
  } sfmt_mvtachi_a;
161
  struct { /*  */
162
    SI* i_dr;
163
    UINT f_accs;
164
    UINT f_r1;
165
    unsigned char out_dr;
166
  } sfmt_mvfachi_a;
167
  struct { /*  */
168
    ADDR i_uimm24;
169
    SI* i_dr;
170
    UINT f_r1;
171
    unsigned char out_dr;
172
  } sfmt_ld24;
173
  struct { /*  */
174
    SI* i_sr;
175
    UINT f_r2;
176
    unsigned char in_sr;
177
    unsigned char out_h_gr_SI_14;
178
  } sfmt_jl;
179
  struct { /*  */
180
    SI* i_sr;
181
    INT f_simm16;
182
    UINT f_r2;
183
    UINT f_uimm3;
184
    unsigned char in_sr;
185
  } sfmt_bset;
186
  struct { /*  */
187
    SI* i_dr;
188
    UINT f_r1;
189
    UINT f_uimm5;
190
    unsigned char in_dr;
191
    unsigned char out_dr;
192
  } sfmt_slli;
193
  struct { /*  */
194
    SI* i_dr;
195
    INT f_simm8;
196
    UINT f_r1;
197
    unsigned char in_dr;
198
    unsigned char out_dr;
199
  } sfmt_addi;
200
  struct { /*  */
201
    SI* i_src1;
202
    SI* i_src2;
203
    UINT f_r1;
204
    UINT f_r2;
205
    unsigned char in_src1;
206
    unsigned char in_src2;
207
    unsigned char out_src2;
208
  } sfmt_st_plus;
209
  struct { /*  */
210
    SI* i_src1;
211
    SI* i_src2;
212
    INT f_simm16;
213
    UINT f_r1;
214
    UINT f_r2;
215
    unsigned char in_src1;
216
    unsigned char in_src2;
217
  } sfmt_st_d;
218
  struct { /*  */
219
    SI* i_src1;
220
    SI* i_src2;
221
    UINT f_acc;
222
    UINT f_r1;
223
    UINT f_r2;
224
    unsigned char in_src1;
225
    unsigned char in_src2;
226
  } sfmt_machi_a;
227
  struct { /*  */
228
    SI* i_dr;
229
    SI* i_sr;
230
    UINT f_r1;
231
    UINT f_r2;
232
    unsigned char in_sr;
233
    unsigned char out_dr;
234
    unsigned char out_sr;
235
  } sfmt_ld_plus;
236
  struct { /*  */
237
    IADDR i_disp16;
238
    SI* i_src1;
239
    SI* i_src2;
240
    UINT f_r1;
241
    UINT f_r2;
242
    unsigned char in_src1;
243
    unsigned char in_src2;
244
  } sfmt_beq;
245
  struct { /*  */
246
    SI* i_dr;
247
    SI* i_sr;
248
    UINT f_r1;
249
    UINT f_r2;
250
    UINT f_uimm16;
251
    unsigned char in_sr;
252
    unsigned char out_dr;
253
  } sfmt_and3;
254
  struct { /*  */
255
    SI* i_dr;
256
    SI* i_sr;
257
    INT f_simm16;
258
    UINT f_r1;
259
    UINT f_r2;
260
    unsigned char in_sr;
261
    unsigned char out_dr;
262
  } sfmt_add3;
263
  struct { /*  */
264
    SI* i_dr;
265
    SI* i_sr;
266
    UINT f_r1;
267
    UINT f_r2;
268
    unsigned char in_dr;
269
    unsigned char in_sr;
270
    unsigned char out_dr;
271
  } sfmt_add;
272
#if WITH_SCACHE_PBB
273
  /* Writeback handler.  */
274
  struct {
275
    /* Pointer to argbuf entry for insn whose results need writing back.  */
276
    const struct argbuf *abuf;
277
  } write;
278
  /* x-before handler */
279
  struct {
280
    /*const SCACHE *insns[MAX_PARALLEL_INSNS];*/
281
    int first_p;
282
  } before;
283
  /* x-after handler */
284
  struct {
285
    int empty;
286
  } after;
287
  /* This entry is used to terminate each pbb.  */
288
  struct {
289
    /* Number of insns in pbb.  */
290
    int insn_count;
291
    /* Next pbb to execute.  */
292
    SCACHE *next;
293
    SCACHE *branch_target;
294
  } chain;
295
#endif
296
};
297
 
298
/* The ARGBUF struct.  */
299
struct argbuf {
300
  /* These are the baseclass definitions.  */
301
  IADDR addr;
302
  const IDESC *idesc;
303
  char trace_p;
304
  char profile_p;
305
  /* ??? Temporary hack for skip insns.  */
306
  char skip_count;
307
  char unused;
308
  /* cpu specific data follows */
309
  union sem semantic;
310
  int written;
311
  union sem_fields fields;
312
};
313
 
314
/* A cached insn.
315
 
316
   ??? SCACHE used to contain more than just argbuf.  We could delete the
317
   type entirely and always just use ARGBUF, but for future concerns and as
318
   a level of abstraction it is left in.  */
319
 
320
struct scache {
321
  struct argbuf argbuf;
322
};
323
 
324
/* Macros to simplify extraction, reading and semantic code.
325
   These define and assign the local vars that contain the insn's fields.  */
326
 
327
#define EXTRACT_IFMT_EMPTY_VARS \
328
  unsigned int length;
329
#define EXTRACT_IFMT_EMPTY_CODE \
330
  length = 0; \
331
 
332
#define EXTRACT_IFMT_ADD_VARS \
333
  UINT f_op1; \
334
  UINT f_r1; \
335
  UINT f_op2; \
336
  UINT f_r2; \
337
  unsigned int length;
338
#define EXTRACT_IFMT_ADD_CODE \
339
  length = 2; \
340
  f_op1 = EXTRACT_MSB0_UINT (insn, 16, 0, 4); \
341
  f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4); \
342
  f_op2 = EXTRACT_MSB0_UINT (insn, 16, 8, 4); \
343
  f_r2 = EXTRACT_MSB0_UINT (insn, 16, 12, 4); \
344
 
345
#define EXTRACT_IFMT_ADD3_VARS \
346
  UINT f_op1; \
347
  UINT f_r1; \
348
  UINT f_op2; \
349
  UINT f_r2; \
350
  INT f_simm16; \
351
  unsigned int length;
352
#define EXTRACT_IFMT_ADD3_CODE \
353
  length = 4; \
354
  f_op1 = EXTRACT_MSB0_UINT (insn, 32, 0, 4); \
355
  f_r1 = EXTRACT_MSB0_UINT (insn, 32, 4, 4); \
356
  f_op2 = EXTRACT_MSB0_UINT (insn, 32, 8, 4); \
357
  f_r2 = EXTRACT_MSB0_UINT (insn, 32, 12, 4); \
358
  f_simm16 = EXTRACT_MSB0_INT (insn, 32, 16, 16); \
359
 
360
#define EXTRACT_IFMT_AND3_VARS \
361
  UINT f_op1; \
362
  UINT f_r1; \
363
  UINT f_op2; \
364
  UINT f_r2; \
365
  UINT f_uimm16; \
366
  unsigned int length;
367
#define EXTRACT_IFMT_AND3_CODE \
368
  length = 4; \
369
  f_op1 = EXTRACT_MSB0_UINT (insn, 32, 0, 4); \
370
  f_r1 = EXTRACT_MSB0_UINT (insn, 32, 4, 4); \
371
  f_op2 = EXTRACT_MSB0_UINT (insn, 32, 8, 4); \
372
  f_r2 = EXTRACT_MSB0_UINT (insn, 32, 12, 4); \
373
  f_uimm16 = EXTRACT_MSB0_UINT (insn, 32, 16, 16); \
374
 
375
#define EXTRACT_IFMT_OR3_VARS \
376
  UINT f_op1; \
377
  UINT f_r1; \
378
  UINT f_op2; \
379
  UINT f_r2; \
380
  UINT f_uimm16; \
381
  unsigned int length;
382
#define EXTRACT_IFMT_OR3_CODE \
383
  length = 4; \
384
  f_op1 = EXTRACT_MSB0_UINT (insn, 32, 0, 4); \
385
  f_r1 = EXTRACT_MSB0_UINT (insn, 32, 4, 4); \
386
  f_op2 = EXTRACT_MSB0_UINT (insn, 32, 8, 4); \
387
  f_r2 = EXTRACT_MSB0_UINT (insn, 32, 12, 4); \
388
  f_uimm16 = EXTRACT_MSB0_UINT (insn, 32, 16, 16); \
389
 
390
#define EXTRACT_IFMT_ADDI_VARS \
391
  UINT f_op1; \
392
  UINT f_r1; \
393
  INT f_simm8; \
394
  unsigned int length;
395
#define EXTRACT_IFMT_ADDI_CODE \
396
  length = 2; \
397
  f_op1 = EXTRACT_MSB0_UINT (insn, 16, 0, 4); \
398
  f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4); \
399
  f_simm8 = EXTRACT_MSB0_INT (insn, 16, 8, 8); \
400
 
401
#define EXTRACT_IFMT_ADDV3_VARS \
402
  UINT f_op1; \
403
  UINT f_r1; \
404
  UINT f_op2; \
405
  UINT f_r2; \
406
  INT f_simm16; \
407
  unsigned int length;
408
#define EXTRACT_IFMT_ADDV3_CODE \
409
  length = 4; \
410
  f_op1 = EXTRACT_MSB0_UINT (insn, 32, 0, 4); \
411
  f_r1 = EXTRACT_MSB0_UINT (insn, 32, 4, 4); \
412
  f_op2 = EXTRACT_MSB0_UINT (insn, 32, 8, 4); \
413
  f_r2 = EXTRACT_MSB0_UINT (insn, 32, 12, 4); \
414
  f_simm16 = EXTRACT_MSB0_INT (insn, 32, 16, 16); \
415
 
416
#define EXTRACT_IFMT_BC8_VARS \
417
  UINT f_op1; \
418
  UINT f_r1; \
419
  SI f_disp8; \
420
  unsigned int length;
421
#define EXTRACT_IFMT_BC8_CODE \
422
  length = 2; \
423
  f_op1 = EXTRACT_MSB0_UINT (insn, 16, 0, 4); \
424
  f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4); \
425
  f_disp8 = ((((EXTRACT_MSB0_INT (insn, 16, 8, 8)) << (2))) + (((pc) & (-4)))); \
426
 
427
#define EXTRACT_IFMT_BC24_VARS \
428
  UINT f_op1; \
429
  UINT f_r1; \
430
  SI f_disp24; \
431
  unsigned int length;
432
#define EXTRACT_IFMT_BC24_CODE \
433
  length = 4; \
434
  f_op1 = EXTRACT_MSB0_UINT (insn, 32, 0, 4); \
435
  f_r1 = EXTRACT_MSB0_UINT (insn, 32, 4, 4); \
436
  f_disp24 = ((((EXTRACT_MSB0_INT (insn, 32, 8, 24)) << (2))) + (pc)); \
437
 
438
#define EXTRACT_IFMT_BEQ_VARS \
439
  UINT f_op1; \
440
  UINT f_r1; \
441
  UINT f_op2; \
442
  UINT f_r2; \
443
  SI f_disp16; \
444
  unsigned int length;
445
#define EXTRACT_IFMT_BEQ_CODE \
446
  length = 4; \
447
  f_op1 = EXTRACT_MSB0_UINT (insn, 32, 0, 4); \
448
  f_r1 = EXTRACT_MSB0_UINT (insn, 32, 4, 4); \
449
  f_op2 = EXTRACT_MSB0_UINT (insn, 32, 8, 4); \
450
  f_r2 = EXTRACT_MSB0_UINT (insn, 32, 12, 4); \
451
  f_disp16 = ((((EXTRACT_MSB0_INT (insn, 32, 16, 16)) << (2))) + (pc)); \
452
 
453
#define EXTRACT_IFMT_BEQZ_VARS \
454
  UINT f_op1; \
455
  UINT f_r1; \
456
  UINT f_op2; \
457
  UINT f_r2; \
458
  SI f_disp16; \
459
  unsigned int length;
460
#define EXTRACT_IFMT_BEQZ_CODE \
461
  length = 4; \
462
  f_op1 = EXTRACT_MSB0_UINT (insn, 32, 0, 4); \
463
  f_r1 = EXTRACT_MSB0_UINT (insn, 32, 4, 4); \
464
  f_op2 = EXTRACT_MSB0_UINT (insn, 32, 8, 4); \
465
  f_r2 = EXTRACT_MSB0_UINT (insn, 32, 12, 4); \
466
  f_disp16 = ((((EXTRACT_MSB0_INT (insn, 32, 16, 16)) << (2))) + (pc)); \
467
 
468
#define EXTRACT_IFMT_CMP_VARS \
469
  UINT f_op1; \
470
  UINT f_r1; \
471
  UINT f_op2; \
472
  UINT f_r2; \
473
  unsigned int length;
474
#define EXTRACT_IFMT_CMP_CODE \
475
  length = 2; \
476
  f_op1 = EXTRACT_MSB0_UINT (insn, 16, 0, 4); \
477
  f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4); \
478
  f_op2 = EXTRACT_MSB0_UINT (insn, 16, 8, 4); \
479
  f_r2 = EXTRACT_MSB0_UINT (insn, 16, 12, 4); \
480
 
481
#define EXTRACT_IFMT_CMPI_VARS \
482
  UINT f_op1; \
483
  UINT f_r1; \
484
  UINT f_op2; \
485
  UINT f_r2; \
486
  INT f_simm16; \
487
  unsigned int length;
488
#define EXTRACT_IFMT_CMPI_CODE \
489
  length = 4; \
490
  f_op1 = EXTRACT_MSB0_UINT (insn, 32, 0, 4); \
491
  f_r1 = EXTRACT_MSB0_UINT (insn, 32, 4, 4); \
492
  f_op2 = EXTRACT_MSB0_UINT (insn, 32, 8, 4); \
493
  f_r2 = EXTRACT_MSB0_UINT (insn, 32, 12, 4); \
494
  f_simm16 = EXTRACT_MSB0_INT (insn, 32, 16, 16); \
495
 
496
#define EXTRACT_IFMT_CMPZ_VARS \
497
  UINT f_op1; \
498
  UINT f_r1; \
499
  UINT f_op2; \
500
  UINT f_r2; \
501
  unsigned int length;
502
#define EXTRACT_IFMT_CMPZ_CODE \
503
  length = 2; \
504
  f_op1 = EXTRACT_MSB0_UINT (insn, 16, 0, 4); \
505
  f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4); \
506
  f_op2 = EXTRACT_MSB0_UINT (insn, 16, 8, 4); \
507
  f_r2 = EXTRACT_MSB0_UINT (insn, 16, 12, 4); \
508
 
509
#define EXTRACT_IFMT_DIV_VARS \
510
  UINT f_op1; \
511
  UINT f_r1; \
512
  UINT f_op2; \
513
  UINT f_r2; \
514
  INT f_simm16; \
515
  unsigned int length;
516
#define EXTRACT_IFMT_DIV_CODE \
517
  length = 4; \
518
  f_op1 = EXTRACT_MSB0_UINT (insn, 32, 0, 4); \
519
  f_r1 = EXTRACT_MSB0_UINT (insn, 32, 4, 4); \
520
  f_op2 = EXTRACT_MSB0_UINT (insn, 32, 8, 4); \
521
  f_r2 = EXTRACT_MSB0_UINT (insn, 32, 12, 4); \
522
  f_simm16 = EXTRACT_MSB0_INT (insn, 32, 16, 16); \
523
 
524
#define EXTRACT_IFMT_JC_VARS \
525
  UINT f_op1; \
526
  UINT f_r1; \
527
  UINT f_op2; \
528
  UINT f_r2; \
529
  unsigned int length;
530
#define EXTRACT_IFMT_JC_CODE \
531
  length = 2; \
532
  f_op1 = EXTRACT_MSB0_UINT (insn, 16, 0, 4); \
533
  f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4); \
534
  f_op2 = EXTRACT_MSB0_UINT (insn, 16, 8, 4); \
535
  f_r2 = EXTRACT_MSB0_UINT (insn, 16, 12, 4); \
536
 
537
#define EXTRACT_IFMT_LD24_VARS \
538
  UINT f_op1; \
539
  UINT f_r1; \
540
  UINT f_uimm24; \
541
  unsigned int length;
542
#define EXTRACT_IFMT_LD24_CODE \
543
  length = 4; \
544
  f_op1 = EXTRACT_MSB0_UINT (insn, 32, 0, 4); \
545
  f_r1 = EXTRACT_MSB0_UINT (insn, 32, 4, 4); \
546
  f_uimm24 = EXTRACT_MSB0_UINT (insn, 32, 8, 24); \
547
 
548
#define EXTRACT_IFMT_LDI16_VARS \
549
  UINT f_op1; \
550
  UINT f_r1; \
551
  UINT f_op2; \
552
  UINT f_r2; \
553
  INT f_simm16; \
554
  unsigned int length;
555
#define EXTRACT_IFMT_LDI16_CODE \
556
  length = 4; \
557
  f_op1 = EXTRACT_MSB0_UINT (insn, 32, 0, 4); \
558
  f_r1 = EXTRACT_MSB0_UINT (insn, 32, 4, 4); \
559
  f_op2 = EXTRACT_MSB0_UINT (insn, 32, 8, 4); \
560
  f_r2 = EXTRACT_MSB0_UINT (insn, 32, 12, 4); \
561
  f_simm16 = EXTRACT_MSB0_INT (insn, 32, 16, 16); \
562
 
563
#define EXTRACT_IFMT_MACHI_A_VARS \
564
  UINT f_op1; \
565
  UINT f_r1; \
566
  UINT f_acc; \
567
  UINT f_op23; \
568
  UINT f_r2; \
569
  unsigned int length;
570
#define EXTRACT_IFMT_MACHI_A_CODE \
571
  length = 2; \
572
  f_op1 = EXTRACT_MSB0_UINT (insn, 16, 0, 4); \
573
  f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4); \
574
  f_acc = EXTRACT_MSB0_UINT (insn, 16, 8, 1); \
575
  f_op23 = EXTRACT_MSB0_UINT (insn, 16, 9, 3); \
576
  f_r2 = EXTRACT_MSB0_UINT (insn, 16, 12, 4); \
577
 
578
#define EXTRACT_IFMT_MVFACHI_A_VARS \
579
  UINT f_op1; \
580
  UINT f_r1; \
581
  UINT f_op2; \
582
  UINT f_accs; \
583
  UINT f_op3; \
584
  unsigned int length;
585
#define EXTRACT_IFMT_MVFACHI_A_CODE \
586
  length = 2; \
587
  f_op1 = EXTRACT_MSB0_UINT (insn, 16, 0, 4); \
588
  f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4); \
589
  f_op2 = EXTRACT_MSB0_UINT (insn, 16, 8, 4); \
590
  f_accs = EXTRACT_MSB0_UINT (insn, 16, 12, 2); \
591
  f_op3 = EXTRACT_MSB0_UINT (insn, 16, 14, 2); \
592
 
593
#define EXTRACT_IFMT_MVFC_VARS \
594
  UINT f_op1; \
595
  UINT f_r1; \
596
  UINT f_op2; \
597
  UINT f_r2; \
598
  unsigned int length;
599
#define EXTRACT_IFMT_MVFC_CODE \
600
  length = 2; \
601
  f_op1 = EXTRACT_MSB0_UINT (insn, 16, 0, 4); \
602
  f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4); \
603
  f_op2 = EXTRACT_MSB0_UINT (insn, 16, 8, 4); \
604
  f_r2 = EXTRACT_MSB0_UINT (insn, 16, 12, 4); \
605
 
606
#define EXTRACT_IFMT_MVTACHI_A_VARS \
607
  UINT f_op1; \
608
  UINT f_r1; \
609
  UINT f_op2; \
610
  UINT f_accs; \
611
  UINT f_op3; \
612
  unsigned int length;
613
#define EXTRACT_IFMT_MVTACHI_A_CODE \
614
  length = 2; \
615
  f_op1 = EXTRACT_MSB0_UINT (insn, 16, 0, 4); \
616
  f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4); \
617
  f_op2 = EXTRACT_MSB0_UINT (insn, 16, 8, 4); \
618
  f_accs = EXTRACT_MSB0_UINT (insn, 16, 12, 2); \
619
  f_op3 = EXTRACT_MSB0_UINT (insn, 16, 14, 2); \
620
 
621
#define EXTRACT_IFMT_MVTC_VARS \
622
  UINT f_op1; \
623
  UINT f_r1; \
624
  UINT f_op2; \
625
  UINT f_r2; \
626
  unsigned int length;
627
#define EXTRACT_IFMT_MVTC_CODE \
628
  length = 2; \
629
  f_op1 = EXTRACT_MSB0_UINT (insn, 16, 0, 4); \
630
  f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4); \
631
  f_op2 = EXTRACT_MSB0_UINT (insn, 16, 8, 4); \
632
  f_r2 = EXTRACT_MSB0_UINT (insn, 16, 12, 4); \
633
 
634
#define EXTRACT_IFMT_NOP_VARS \
635
  UINT f_op1; \
636
  UINT f_r1; \
637
  UINT f_op2; \
638
  UINT f_r2; \
639
  unsigned int length;
640
#define EXTRACT_IFMT_NOP_CODE \
641
  length = 2; \
642
  f_op1 = EXTRACT_MSB0_UINT (insn, 16, 0, 4); \
643
  f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4); \
644
  f_op2 = EXTRACT_MSB0_UINT (insn, 16, 8, 4); \
645
  f_r2 = EXTRACT_MSB0_UINT (insn, 16, 12, 4); \
646
 
647
#define EXTRACT_IFMT_RAC_DSI_VARS \
648
  UINT f_op1; \
649
  UINT f_accd; \
650
  UINT f_bits67; \
651
  UINT f_op2; \
652
  UINT f_accs; \
653
  UINT f_bit14; \
654
  SI f_imm1; \
655
  unsigned int length;
656
#define EXTRACT_IFMT_RAC_DSI_CODE \
657
  length = 2; \
658
  f_op1 = EXTRACT_MSB0_UINT (insn, 16, 0, 4); \
659
  f_accd = EXTRACT_MSB0_UINT (insn, 16, 4, 2); \
660
  f_bits67 = EXTRACT_MSB0_UINT (insn, 16, 6, 2); \
661
  f_op2 = EXTRACT_MSB0_UINT (insn, 16, 8, 4); \
662
  f_accs = EXTRACT_MSB0_UINT (insn, 16, 12, 2); \
663
  f_bit14 = EXTRACT_MSB0_UINT (insn, 16, 14, 1); \
664
  f_imm1 = ((EXTRACT_MSB0_UINT (insn, 16, 15, 1)) + (1)); \
665
 
666
#define EXTRACT_IFMT_SETH_VARS \
667
  UINT f_op1; \
668
  UINT f_r1; \
669
  UINT f_op2; \
670
  UINT f_r2; \
671
  UINT f_hi16; \
672
  unsigned int length;
673
#define EXTRACT_IFMT_SETH_CODE \
674
  length = 4; \
675
  f_op1 = EXTRACT_MSB0_UINT (insn, 32, 0, 4); \
676
  f_r1 = EXTRACT_MSB0_UINT (insn, 32, 4, 4); \
677
  f_op2 = EXTRACT_MSB0_UINT (insn, 32, 8, 4); \
678
  f_r2 = EXTRACT_MSB0_UINT (insn, 32, 12, 4); \
679
  f_hi16 = EXTRACT_MSB0_UINT (insn, 32, 16, 16); \
680
 
681
#define EXTRACT_IFMT_SLLI_VARS \
682
  UINT f_op1; \
683
  UINT f_r1; \
684
  UINT f_shift_op2; \
685
  UINT f_uimm5; \
686
  unsigned int length;
687
#define EXTRACT_IFMT_SLLI_CODE \
688
  length = 2; \
689
  f_op1 = EXTRACT_MSB0_UINT (insn, 16, 0, 4); \
690
  f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4); \
691
  f_shift_op2 = EXTRACT_MSB0_UINT (insn, 16, 8, 3); \
692
  f_uimm5 = EXTRACT_MSB0_UINT (insn, 16, 11, 5); \
693
 
694
#define EXTRACT_IFMT_ST_D_VARS \
695
  UINT f_op1; \
696
  UINT f_r1; \
697
  UINT f_op2; \
698
  UINT f_r2; \
699
  INT f_simm16; \
700
  unsigned int length;
701
#define EXTRACT_IFMT_ST_D_CODE \
702
  length = 4; \
703
  f_op1 = EXTRACT_MSB0_UINT (insn, 32, 0, 4); \
704
  f_r1 = EXTRACT_MSB0_UINT (insn, 32, 4, 4); \
705
  f_op2 = EXTRACT_MSB0_UINT (insn, 32, 8, 4); \
706
  f_r2 = EXTRACT_MSB0_UINT (insn, 32, 12, 4); \
707
  f_simm16 = EXTRACT_MSB0_INT (insn, 32, 16, 16); \
708
 
709
#define EXTRACT_IFMT_TRAP_VARS \
710
  UINT f_op1; \
711
  UINT f_r1; \
712
  UINT f_op2; \
713
  UINT f_uimm4; \
714
  unsigned int length;
715
#define EXTRACT_IFMT_TRAP_CODE \
716
  length = 2; \
717
  f_op1 = EXTRACT_MSB0_UINT (insn, 16, 0, 4); \
718
  f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4); \
719
  f_op2 = EXTRACT_MSB0_UINT (insn, 16, 8, 4); \
720
  f_uimm4 = EXTRACT_MSB0_UINT (insn, 16, 12, 4); \
721
 
722
#define EXTRACT_IFMT_SATB_VARS \
723
  UINT f_op1; \
724
  UINT f_r1; \
725
  UINT f_op2; \
726
  UINT f_r2; \
727
  UINT f_uimm16; \
728
  unsigned int length;
729
#define EXTRACT_IFMT_SATB_CODE \
730
  length = 4; \
731
  f_op1 = EXTRACT_MSB0_UINT (insn, 32, 0, 4); \
732
  f_r1 = EXTRACT_MSB0_UINT (insn, 32, 4, 4); \
733
  f_op2 = EXTRACT_MSB0_UINT (insn, 32, 8, 4); \
734
  f_r2 = EXTRACT_MSB0_UINT (insn, 32, 12, 4); \
735
  f_uimm16 = EXTRACT_MSB0_UINT (insn, 32, 16, 16); \
736
 
737
#define EXTRACT_IFMT_CLRPSW_VARS \
738
  UINT f_op1; \
739
  UINT f_r1; \
740
  UINT f_uimm8; \
741
  unsigned int length;
742
#define EXTRACT_IFMT_CLRPSW_CODE \
743
  length = 2; \
744
  f_op1 = EXTRACT_MSB0_UINT (insn, 16, 0, 4); \
745
  f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4); \
746
  f_uimm8 = EXTRACT_MSB0_UINT (insn, 16, 8, 8); \
747
 
748
#define EXTRACT_IFMT_BSET_VARS \
749
  UINT f_op1; \
750
  UINT f_bit4; \
751
  UINT f_uimm3; \
752
  UINT f_op2; \
753
  UINT f_r2; \
754
  INT f_simm16; \
755
  unsigned int length;
756
#define EXTRACT_IFMT_BSET_CODE \
757
  length = 4; \
758
  f_op1 = EXTRACT_MSB0_UINT (insn, 32, 0, 4); \
759
  f_bit4 = EXTRACT_MSB0_UINT (insn, 32, 4, 1); \
760
  f_uimm3 = EXTRACT_MSB0_UINT (insn, 32, 5, 3); \
761
  f_op2 = EXTRACT_MSB0_UINT (insn, 32, 8, 4); \
762
  f_r2 = EXTRACT_MSB0_UINT (insn, 32, 12, 4); \
763
  f_simm16 = EXTRACT_MSB0_INT (insn, 32, 16, 16); \
764
 
765
#define EXTRACT_IFMT_BTST_VARS \
766
  UINT f_op1; \
767
  UINT f_bit4; \
768
  UINT f_uimm3; \
769
  UINT f_op2; \
770
  UINT f_r2; \
771
  unsigned int length;
772
#define EXTRACT_IFMT_BTST_CODE \
773
  length = 2; \
774
  f_op1 = EXTRACT_MSB0_UINT (insn, 16, 0, 4); \
775
  f_bit4 = EXTRACT_MSB0_UINT (insn, 16, 4, 1); \
776
  f_uimm3 = EXTRACT_MSB0_UINT (insn, 16, 5, 3); \
777
  f_op2 = EXTRACT_MSB0_UINT (insn, 16, 8, 4); \
778
  f_r2 = EXTRACT_MSB0_UINT (insn, 16, 12, 4); \
779
 
780
/* Queued output values of an instruction.  */
781
 
782
struct parexec {
783
  union {
784
    struct { /* empty sformat for unspecified field list */
785
      int empty;
786
    } sfmt_empty;
787
    struct { /* e.g. add $dr,$sr */
788
      SI dr;
789
    } sfmt_add;
790
    struct { /* e.g. add3 $dr,$sr,$hash$slo16 */
791
      SI dr;
792
    } sfmt_add3;
793
    struct { /* e.g. and3 $dr,$sr,$uimm16 */
794
      SI dr;
795
    } sfmt_and3;
796
    struct { /* e.g. or3 $dr,$sr,$hash$ulo16 */
797
      SI dr;
798
    } sfmt_or3;
799
    struct { /* e.g. addi $dr,$simm8 */
800
      SI dr;
801
    } sfmt_addi;
802
    struct { /* e.g. addv $dr,$sr */
803
      BI condbit;
804
      SI dr;
805
    } sfmt_addv;
806
    struct { /* e.g. addv3 $dr,$sr,$simm16 */
807
      BI condbit;
808
      SI dr;
809
    } sfmt_addv3;
810
    struct { /* e.g. addx $dr,$sr */
811
      BI condbit;
812
      SI dr;
813
    } sfmt_addx;
814
    struct { /* e.g. bc.s $disp8 */
815
      USI pc;
816
    } sfmt_bc8;
817
    struct { /* e.g. bc.l $disp24 */
818
      USI pc;
819
    } sfmt_bc24;
820
    struct { /* e.g. beq $src1,$src2,$disp16 */
821
      USI pc;
822
    } sfmt_beq;
823
    struct { /* e.g. beqz $src2,$disp16 */
824
      USI pc;
825
    } sfmt_beqz;
826
    struct { /* e.g. bl.s $disp8 */
827
      SI h_gr_SI_14;
828
      USI pc;
829
    } sfmt_bl8;
830
    struct { /* e.g. bl.l $disp24 */
831
      SI h_gr_SI_14;
832
      USI pc;
833
    } sfmt_bl24;
834
    struct { /* e.g. bcl.s $disp8 */
835
      SI h_gr_SI_14;
836
      USI pc;
837
    } sfmt_bcl8;
838
    struct { /* e.g. bcl.l $disp24 */
839
      SI h_gr_SI_14;
840
      USI pc;
841
    } sfmt_bcl24;
842
    struct { /* e.g. bra.s $disp8 */
843
      USI pc;
844
    } sfmt_bra8;
845
    struct { /* e.g. bra.l $disp24 */
846
      USI pc;
847
    } sfmt_bra24;
848
    struct { /* e.g. cmp $src1,$src2 */
849
      BI condbit;
850
    } sfmt_cmp;
851
    struct { /* e.g. cmpi $src2,$simm16 */
852
      BI condbit;
853
    } sfmt_cmpi;
854
    struct { /* e.g. cmpz $src2 */
855
      BI condbit;
856
    } sfmt_cmpz;
857
    struct { /* e.g. div $dr,$sr */
858
      SI dr;
859
    } sfmt_div;
860
    struct { /* e.g. jc $sr */
861
      USI pc;
862
    } sfmt_jc;
863
    struct { /* e.g. jl $sr */
864
      SI h_gr_SI_14;
865
      USI pc;
866
    } sfmt_jl;
867
    struct { /* e.g. jmp $sr */
868
      USI pc;
869
    } sfmt_jmp;
870
    struct { /* e.g. ld $dr,@$sr */
871
      SI dr;
872
    } sfmt_ld;
873
    struct { /* e.g. ld $dr,@($slo16,$sr) */
874
      SI dr;
875
    } sfmt_ld_d;
876
    struct { /* e.g. ldb $dr,@$sr */
877
      SI dr;
878
    } sfmt_ldb;
879
    struct { /* e.g. ldb $dr,@($slo16,$sr) */
880
      SI dr;
881
    } sfmt_ldb_d;
882
    struct { /* e.g. ldh $dr,@$sr */
883
      SI dr;
884
    } sfmt_ldh;
885
    struct { /* e.g. ldh $dr,@($slo16,$sr) */
886
      SI dr;
887
    } sfmt_ldh_d;
888
    struct { /* e.g. ld $dr,@$sr+ */
889
      SI dr;
890
      SI sr;
891
    } sfmt_ld_plus;
892
    struct { /* e.g. ld24 $dr,$uimm24 */
893
      SI dr;
894
    } sfmt_ld24;
895
    struct { /* e.g. ldi8 $dr,$simm8 */
896
      SI dr;
897
    } sfmt_ldi8;
898
    struct { /* e.g. ldi16 $dr,$hash$slo16 */
899
      SI dr;
900
    } sfmt_ldi16;
901
    struct { /* e.g. lock $dr,@$sr */
902
      SI dr;
903
      BI h_lock_BI;
904
    } sfmt_lock;
905
    struct { /* e.g. machi $src1,$src2,$acc */
906
      DI acc;
907
    } sfmt_machi_a;
908
    struct { /* e.g. mulhi $src1,$src2,$acc */
909
      DI acc;
910
    } sfmt_mulhi_a;
911
    struct { /* e.g. mv $dr,$sr */
912
      SI dr;
913
    } sfmt_mv;
914
    struct { /* e.g. mvfachi $dr,$accs */
915
      SI dr;
916
    } sfmt_mvfachi_a;
917
    struct { /* e.g. mvfc $dr,$scr */
918
      SI dr;
919
    } sfmt_mvfc;
920
    struct { /* e.g. mvtachi $src1,$accs */
921
      DI accs;
922
    } sfmt_mvtachi_a;
923
    struct { /* e.g. mvtc $sr,$dcr */
924
      USI dcr;
925
    } sfmt_mvtc;
926
    struct { /* e.g. nop */
927
      int empty;
928
    } sfmt_nop;
929
    struct { /* e.g. rac $accd,$accs,$imm1 */
930
      DI accd;
931
    } sfmt_rac_dsi;
932
    struct { /* e.g. rte */
933
      UQI h_bpsw_UQI;
934
      USI h_cr_USI_6;
935
      UQI h_psw_UQI;
936
      USI pc;
937
    } sfmt_rte;
938
    struct { /* e.g. seth $dr,$hash$hi16 */
939
      SI dr;
940
    } sfmt_seth;
941
    struct { /* e.g. sll3 $dr,$sr,$simm16 */
942
      SI dr;
943
    } sfmt_sll3;
944
    struct { /* e.g. slli $dr,$uimm5 */
945
      SI dr;
946
    } sfmt_slli;
947
    struct { /* e.g. st $src1,@$src2 */
948
      SI h_memory_SI_src2;
949
      USI h_memory_SI_src2_idx;
950
    } sfmt_st;
951
    struct { /* e.g. st $src1,@($slo16,$src2) */
952
      SI h_memory_SI_add__DFLT_src2_slo16;
953
      USI h_memory_SI_add__DFLT_src2_slo16_idx;
954
    } sfmt_st_d;
955
    struct { /* e.g. stb $src1,@$src2 */
956
      QI h_memory_QI_src2;
957
      USI h_memory_QI_src2_idx;
958
    } sfmt_stb;
959
    struct { /* e.g. stb $src1,@($slo16,$src2) */
960
      QI h_memory_QI_add__DFLT_src2_slo16;
961
      USI h_memory_QI_add__DFLT_src2_slo16_idx;
962
    } sfmt_stb_d;
963
    struct { /* e.g. sth $src1,@$src2 */
964
      HI h_memory_HI_src2;
965
      USI h_memory_HI_src2_idx;
966
    } sfmt_sth;
967
    struct { /* e.g. sth $src1,@($slo16,$src2) */
968
      HI h_memory_HI_add__DFLT_src2_slo16;
969
      USI h_memory_HI_add__DFLT_src2_slo16_idx;
970
    } sfmt_sth_d;
971
    struct { /* e.g. st $src1,@+$src2 */
972
      SI h_memory_SI_new_src2;
973
      USI h_memory_SI_new_src2_idx;
974
      SI src2;
975
    } sfmt_st_plus;
976
    struct { /* e.g. sth $src1,@$src2+ */
977
      HI h_memory_HI_new_src2;
978
      USI h_memory_HI_new_src2_idx;
979
      SI src2;
980
    } sfmt_sth_plus;
981
    struct { /* e.g. stb $src1,@$src2+ */
982
      QI h_memory_QI_new_src2;
983
      USI h_memory_QI_new_src2_idx;
984
      SI src2;
985
    } sfmt_stb_plus;
986
    struct { /* e.g. trap $uimm4 */
987
      UQI h_bbpsw_UQI;
988
      UQI h_bpsw_UQI;
989
      USI h_cr_USI_14;
990
      USI h_cr_USI_6;
991
      UQI h_psw_UQI;
992
      SI pc;
993
    } sfmt_trap;
994
    struct { /* e.g. unlock $src1,@$src2 */
995
      BI h_lock_BI;
996
      SI h_memory_SI_src2;
997
      USI h_memory_SI_src2_idx;
998
    } sfmt_unlock;
999
    struct { /* e.g. satb $dr,$sr */
1000
      SI dr;
1001
    } sfmt_satb;
1002
    struct { /* e.g. sat $dr,$sr */
1003
      SI dr;
1004
    } sfmt_sat;
1005
    struct { /* e.g. sadd */
1006
      DI h_accums_DI_0;
1007
    } sfmt_sadd;
1008
    struct { /* e.g. macwu1 $src1,$src2 */
1009
      DI h_accums_DI_1;
1010
    } sfmt_macwu1;
1011
    struct { /* e.g. msblo $src1,$src2 */
1012
      DI accum;
1013
    } sfmt_msblo;
1014
    struct { /* e.g. mulwu1 $src1,$src2 */
1015
      DI h_accums_DI_1;
1016
    } sfmt_mulwu1;
1017
    struct { /* e.g. sc */
1018
      int empty;
1019
    } sfmt_sc;
1020
    struct { /* e.g. clrpsw $uimm8 */
1021
      USI h_cr_USI_0;
1022
    } sfmt_clrpsw;
1023
    struct { /* e.g. setpsw $uimm8 */
1024
      USI h_cr_USI_0;
1025
    } sfmt_setpsw;
1026
    struct { /* e.g. bset $uimm3,@($slo16,$sr) */
1027
      QI h_memory_QI_add__DFLT_sr_slo16;
1028
      USI h_memory_QI_add__DFLT_sr_slo16_idx;
1029
    } sfmt_bset;
1030
    struct { /* e.g. btst $uimm3,$sr */
1031
      BI condbit;
1032
    } sfmt_btst;
1033
  } operands;
1034
  /* For conditionally written operands, bitmask of which ones were.  */
1035
  int written;
1036
};
1037
 
1038
/* Collection of various things for the trace handler to use.  */
1039
 
1040
typedef struct trace_record {
1041
  IADDR pc;
1042
  /* FIXME:wip */
1043
} TRACE_RECORD;
1044
 
1045
#endif /* CPU_M32R2F_H */

powered by: WebSVN 2.1.0

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