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

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [gnu-stable/] [gdb-7.2/] [sim/] [m32r/] [cpu2.h] - Blame information for rev 861

Go to most recent revision | Details | Compare with Previous | View Log

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

powered by: WebSVN 2.1.0

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