1 /* Simulator model support for crisv32f.
3 THIS FILE IS MACHINE GENERATED WITH CGEN.
5 Copyright 1996-2005 Free Software Foundation, Inc.
7 This file is part of the GNU simulators.
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 2, or (at your option)
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.
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.
25 #define WANT_CPU crisv32f
26 #define WANT_CPU_CRISV32F
30 /* The profiling data is recorded here, but is accessed via the profiling
31 mechanism. After all, this is information for profiling. */
33 #if WITH_PROFILE_MODEL_P
35 /* Model handlers for each insn. */
38 model_crisv32_move_b_r (SIM_CPU
*current_cpu
, void *sem_arg
)
40 #define FLD(f) abuf->fields.sfmt_addc_m.f
41 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
42 const IDESC
* UNUSED idesc
= abuf
->idesc
;
46 int UNUSED insn_referenced
= abuf
->written
;
52 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
59 model_crisv32_move_w_r (SIM_CPU
*current_cpu
, void *sem_arg
)
61 #define FLD(f) abuf->fields.sfmt_addc_m.f
62 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
63 const IDESC
* UNUSED idesc
= abuf
->idesc
;
67 int UNUSED insn_referenced
= abuf
->written
;
73 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
80 model_crisv32_move_d_r (SIM_CPU
*current_cpu
, void *sem_arg
)
82 #define FLD(f) abuf->fields.sfmt_addc_m.f
83 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
84 const IDESC
* UNUSED idesc
= abuf
->idesc
;
88 int UNUSED insn_referenced
= abuf
->written
;
94 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
101 model_crisv32_moveq (SIM_CPU
*current_cpu
, void *sem_arg
)
103 #define FLD(f) abuf->fields.sfmt_moveq.f
104 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
105 const IDESC
* UNUSED idesc
= abuf
->idesc
;
109 int UNUSED insn_referenced
= abuf
->written
;
113 out_Rd
= FLD (out_Rd
);
114 referenced
|= 1 << 2;
115 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
122 model_crisv32_movs_b_r (SIM_CPU
*current_cpu
, void *sem_arg
)
124 #define FLD(f) abuf->fields.sfmt_muls_b.f
125 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
126 const IDESC
* UNUSED idesc
= abuf
->idesc
;
130 int UNUSED insn_referenced
= abuf
->written
;
135 out_Rd
= FLD (out_Rd
);
136 referenced
|= 1 << 1;
137 referenced
|= 1 << 2;
138 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
145 model_crisv32_movs_w_r (SIM_CPU
*current_cpu
, void *sem_arg
)
147 #define FLD(f) abuf->fields.sfmt_muls_b.f
148 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
149 const IDESC
* UNUSED idesc
= abuf
->idesc
;
153 int UNUSED insn_referenced
= abuf
->written
;
158 out_Rd
= FLD (out_Rd
);
159 referenced
|= 1 << 1;
160 referenced
|= 1 << 2;
161 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
168 model_crisv32_movu_b_r (SIM_CPU
*current_cpu
, void *sem_arg
)
170 #define FLD(f) abuf->fields.sfmt_muls_b.f
171 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
172 const IDESC
* UNUSED idesc
= abuf
->idesc
;
176 int UNUSED insn_referenced
= abuf
->written
;
181 out_Rd
= FLD (out_Rd
);
182 referenced
|= 1 << 1;
183 referenced
|= 1 << 2;
184 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
191 model_crisv32_movu_w_r (SIM_CPU
*current_cpu
, void *sem_arg
)
193 #define FLD(f) abuf->fields.sfmt_muls_b.f
194 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
195 const IDESC
* UNUSED idesc
= abuf
->idesc
;
199 int UNUSED insn_referenced
= abuf
->written
;
204 out_Rd
= FLD (out_Rd
);
205 referenced
|= 1 << 1;
206 referenced
|= 1 << 2;
207 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
214 model_crisv32_movecbr (SIM_CPU
*current_cpu
, void *sem_arg
)
216 #define FLD(f) abuf->fields.sfmt_addcbr.f
217 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
218 const IDESC
* UNUSED idesc
= abuf
->idesc
;
222 int UNUSED insn_referenced
= abuf
->written
;
223 cycles
+= crisv32f_model_crisv32_u_const16 (current_cpu
, idesc
, 0, referenced
);
227 int UNUSED insn_referenced
= abuf
->written
;
231 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
238 model_crisv32_movecwr (SIM_CPU
*current_cpu
, void *sem_arg
)
240 #define FLD(f) abuf->fields.sfmt_addcwr.f
241 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
242 const IDESC
* UNUSED idesc
= abuf
->idesc
;
246 int UNUSED insn_referenced
= abuf
->written
;
247 cycles
+= crisv32f_model_crisv32_u_const16 (current_cpu
, idesc
, 0, referenced
);
251 int UNUSED insn_referenced
= abuf
->written
;
255 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
262 model_crisv32_movecdr (SIM_CPU
*current_cpu
, void *sem_arg
)
264 #define FLD(f) abuf->fields.sfmt_bound_cd.f
265 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
266 const IDESC
* UNUSED idesc
= abuf
->idesc
;
270 int UNUSED insn_referenced
= abuf
->written
;
271 cycles
+= crisv32f_model_crisv32_u_const32 (current_cpu
, idesc
, 0, referenced
);
275 int UNUSED insn_referenced
= abuf
->written
;
279 out_Rd
= FLD (out_Rd
);
280 referenced
|= 1 << 2;
281 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
288 model_crisv32_movscbr (SIM_CPU
*current_cpu
, void *sem_arg
)
290 #define FLD(f) abuf->fields.sfmt_bound_cb.f
291 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
292 const IDESC
* UNUSED idesc
= abuf
->idesc
;
296 int UNUSED insn_referenced
= abuf
->written
;
297 cycles
+= crisv32f_model_crisv32_u_const16 (current_cpu
, idesc
, 0, referenced
);
301 int UNUSED insn_referenced
= abuf
->written
;
305 out_Rd
= FLD (out_Rd
);
306 referenced
|= 1 << 2;
307 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
314 model_crisv32_movscwr (SIM_CPU
*current_cpu
, void *sem_arg
)
316 #define FLD(f) abuf->fields.sfmt_bound_cw.f
317 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
318 const IDESC
* UNUSED idesc
= abuf
->idesc
;
322 int UNUSED insn_referenced
= abuf
->written
;
323 cycles
+= crisv32f_model_crisv32_u_const16 (current_cpu
, idesc
, 0, referenced
);
327 int UNUSED insn_referenced
= abuf
->written
;
331 out_Rd
= FLD (out_Rd
);
332 referenced
|= 1 << 2;
333 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
340 model_crisv32_movucbr (SIM_CPU
*current_cpu
, void *sem_arg
)
342 #define FLD(f) abuf->fields.sfmt_bound_cb.f
343 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
344 const IDESC
* UNUSED idesc
= abuf
->idesc
;
348 int UNUSED insn_referenced
= abuf
->written
;
349 cycles
+= crisv32f_model_crisv32_u_const16 (current_cpu
, idesc
, 0, referenced
);
353 int UNUSED insn_referenced
= abuf
->written
;
357 out_Rd
= FLD (out_Rd
);
358 referenced
|= 1 << 2;
359 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
366 model_crisv32_movucwr (SIM_CPU
*current_cpu
, void *sem_arg
)
368 #define FLD(f) abuf->fields.sfmt_bound_cw.f
369 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
370 const IDESC
* UNUSED idesc
= abuf
->idesc
;
374 int UNUSED insn_referenced
= abuf
->written
;
375 cycles
+= crisv32f_model_crisv32_u_const16 (current_cpu
, idesc
, 0, referenced
);
379 int UNUSED insn_referenced
= abuf
->written
;
383 out_Rd
= FLD (out_Rd
);
384 referenced
|= 1 << 2;
385 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
392 model_crisv32_addq (SIM_CPU
*current_cpu
, void *sem_arg
)
394 #define FLD(f) abuf->fields.sfmt_addq.f
395 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
396 const IDESC
* UNUSED idesc
= abuf
->idesc
;
400 int UNUSED insn_referenced
= abuf
->written
;
405 referenced
|= 1 << 0;
406 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
413 model_crisv32_subq (SIM_CPU
*current_cpu
, void *sem_arg
)
415 #define FLD(f) abuf->fields.sfmt_addq.f
416 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
417 const IDESC
* UNUSED idesc
= abuf
->idesc
;
421 int UNUSED insn_referenced
= abuf
->written
;
426 referenced
|= 1 << 0;
427 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
434 model_crisv32_cmp_r_b_r (SIM_CPU
*current_cpu
, void *sem_arg
)
436 #define FLD(f) abuf->fields.sfmt_muls_b.f
437 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
438 const IDESC
* UNUSED idesc
= abuf
->idesc
;
442 int UNUSED insn_referenced
= abuf
->written
;
448 referenced
|= 1 << 0;
449 referenced
|= 1 << 1;
450 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
457 model_crisv32_cmp_r_w_r (SIM_CPU
*current_cpu
, void *sem_arg
)
459 #define FLD(f) abuf->fields.sfmt_muls_b.f
460 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
461 const IDESC
* UNUSED idesc
= abuf
->idesc
;
465 int UNUSED insn_referenced
= abuf
->written
;
471 referenced
|= 1 << 0;
472 referenced
|= 1 << 1;
473 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
480 model_crisv32_cmp_r_d_r (SIM_CPU
*current_cpu
, void *sem_arg
)
482 #define FLD(f) abuf->fields.sfmt_muls_b.f
483 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
484 const IDESC
* UNUSED idesc
= abuf
->idesc
;
488 int UNUSED insn_referenced
= abuf
->written
;
494 referenced
|= 1 << 0;
495 referenced
|= 1 << 1;
496 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
503 model_crisv32_cmp_m_b_m (SIM_CPU
*current_cpu
, void *sem_arg
)
505 #define FLD(f) abuf->fields.sfmt_addc_m.f
506 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
507 const IDESC
* UNUSED idesc
= abuf
->idesc
;
511 int UNUSED insn_referenced
= abuf
->written
;
514 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 0;
515 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
519 int UNUSED insn_referenced
= abuf
->written
;
520 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
524 int UNUSED insn_referenced
= abuf
->written
;
530 referenced
|= 1 << 0;
531 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 1;
532 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
539 model_crisv32_cmp_m_w_m (SIM_CPU
*current_cpu
, void *sem_arg
)
541 #define FLD(f) abuf->fields.sfmt_addc_m.f
542 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
543 const IDESC
* UNUSED idesc
= abuf
->idesc
;
547 int UNUSED insn_referenced
= abuf
->written
;
550 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 0;
551 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
555 int UNUSED insn_referenced
= abuf
->written
;
556 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
560 int UNUSED insn_referenced
= abuf
->written
;
566 referenced
|= 1 << 0;
567 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 1;
568 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
575 model_crisv32_cmp_m_d_m (SIM_CPU
*current_cpu
, void *sem_arg
)
577 #define FLD(f) abuf->fields.sfmt_addc_m.f
578 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
579 const IDESC
* UNUSED idesc
= abuf
->idesc
;
583 int UNUSED insn_referenced
= abuf
->written
;
586 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 0;
587 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
591 int UNUSED insn_referenced
= abuf
->written
;
592 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
596 int UNUSED insn_referenced
= abuf
->written
;
602 referenced
|= 1 << 0;
603 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 1;
604 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
611 model_crisv32_cmpcbr (SIM_CPU
*current_cpu
, void *sem_arg
)
613 #define FLD(f) abuf->fields.sfmt_bound_cb.f
614 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
615 const IDESC
* UNUSED idesc
= abuf
->idesc
;
619 int UNUSED insn_referenced
= abuf
->written
;
620 cycles
+= crisv32f_model_crisv32_u_const16 (current_cpu
, idesc
, 0, referenced
);
624 int UNUSED insn_referenced
= abuf
->written
;
629 referenced
|= 1 << 0;
630 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
637 model_crisv32_cmpcwr (SIM_CPU
*current_cpu
, void *sem_arg
)
639 #define FLD(f) abuf->fields.sfmt_bound_cw.f
640 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
641 const IDESC
* UNUSED idesc
= abuf
->idesc
;
645 int UNUSED insn_referenced
= abuf
->written
;
646 cycles
+= crisv32f_model_crisv32_u_const16 (current_cpu
, idesc
, 0, referenced
);
650 int UNUSED insn_referenced
= abuf
->written
;
655 referenced
|= 1 << 0;
656 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
663 model_crisv32_cmpcdr (SIM_CPU
*current_cpu
, void *sem_arg
)
665 #define FLD(f) abuf->fields.sfmt_bound_cd.f
666 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
667 const IDESC
* UNUSED idesc
= abuf
->idesc
;
671 int UNUSED insn_referenced
= abuf
->written
;
672 cycles
+= crisv32f_model_crisv32_u_const32 (current_cpu
, idesc
, 0, referenced
);
676 int UNUSED insn_referenced
= abuf
->written
;
681 referenced
|= 1 << 0;
682 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
689 model_crisv32_cmpq (SIM_CPU
*current_cpu
, void *sem_arg
)
691 #define FLD(f) abuf->fields.sfmt_andq.f
692 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
693 const IDESC
* UNUSED idesc
= abuf
->idesc
;
697 int UNUSED insn_referenced
= abuf
->written
;
702 referenced
|= 1 << 0;
703 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
710 model_crisv32_cmps_m_b_m (SIM_CPU
*current_cpu
, void *sem_arg
)
712 #define FLD(f) abuf->fields.sfmt_addc_m.f
713 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
714 const IDESC
* UNUSED idesc
= abuf
->idesc
;
718 int UNUSED insn_referenced
= abuf
->written
;
721 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 0;
722 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
726 int UNUSED insn_referenced
= abuf
->written
;
727 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
731 int UNUSED insn_referenced
= abuf
->written
;
737 referenced
|= 1 << 0;
738 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 1;
739 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
746 model_crisv32_cmps_m_w_m (SIM_CPU
*current_cpu
, void *sem_arg
)
748 #define FLD(f) abuf->fields.sfmt_addc_m.f
749 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
750 const IDESC
* UNUSED idesc
= abuf
->idesc
;
754 int UNUSED insn_referenced
= abuf
->written
;
757 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 0;
758 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
762 int UNUSED insn_referenced
= abuf
->written
;
763 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
767 int UNUSED insn_referenced
= abuf
->written
;
773 referenced
|= 1 << 0;
774 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 1;
775 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
782 model_crisv32_cmpscbr (SIM_CPU
*current_cpu
, void *sem_arg
)
784 #define FLD(f) abuf->fields.sfmt_bound_cb.f
785 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
786 const IDESC
* UNUSED idesc
= abuf
->idesc
;
790 int UNUSED insn_referenced
= abuf
->written
;
791 cycles
+= crisv32f_model_crisv32_u_const16 (current_cpu
, idesc
, 0, referenced
);
795 int UNUSED insn_referenced
= abuf
->written
;
800 referenced
|= 1 << 0;
801 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
808 model_crisv32_cmpscwr (SIM_CPU
*current_cpu
, void *sem_arg
)
810 #define FLD(f) abuf->fields.sfmt_bound_cw.f
811 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
812 const IDESC
* UNUSED idesc
= abuf
->idesc
;
816 int UNUSED insn_referenced
= abuf
->written
;
817 cycles
+= crisv32f_model_crisv32_u_const16 (current_cpu
, idesc
, 0, referenced
);
821 int UNUSED insn_referenced
= abuf
->written
;
826 referenced
|= 1 << 0;
827 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
834 model_crisv32_cmpu_m_b_m (SIM_CPU
*current_cpu
, void *sem_arg
)
836 #define FLD(f) abuf->fields.sfmt_addc_m.f
837 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
838 const IDESC
* UNUSED idesc
= abuf
->idesc
;
842 int UNUSED insn_referenced
= abuf
->written
;
845 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 0;
846 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
850 int UNUSED insn_referenced
= abuf
->written
;
851 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
855 int UNUSED insn_referenced
= abuf
->written
;
861 referenced
|= 1 << 0;
862 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 1;
863 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
870 model_crisv32_cmpu_m_w_m (SIM_CPU
*current_cpu
, void *sem_arg
)
872 #define FLD(f) abuf->fields.sfmt_addc_m.f
873 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
874 const IDESC
* UNUSED idesc
= abuf
->idesc
;
878 int UNUSED insn_referenced
= abuf
->written
;
881 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 0;
882 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
886 int UNUSED insn_referenced
= abuf
->written
;
887 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
891 int UNUSED insn_referenced
= abuf
->written
;
897 referenced
|= 1 << 0;
898 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 1;
899 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
906 model_crisv32_cmpucbr (SIM_CPU
*current_cpu
, void *sem_arg
)
908 #define FLD(f) abuf->fields.sfmt_bound_cb.f
909 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
910 const IDESC
* UNUSED idesc
= abuf
->idesc
;
914 int UNUSED insn_referenced
= abuf
->written
;
915 cycles
+= crisv32f_model_crisv32_u_const16 (current_cpu
, idesc
, 0, referenced
);
919 int UNUSED insn_referenced
= abuf
->written
;
924 referenced
|= 1 << 0;
925 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
932 model_crisv32_cmpucwr (SIM_CPU
*current_cpu
, void *sem_arg
)
934 #define FLD(f) abuf->fields.sfmt_bound_cw.f
935 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
936 const IDESC
* UNUSED idesc
= abuf
->idesc
;
940 int UNUSED insn_referenced
= abuf
->written
;
941 cycles
+= crisv32f_model_crisv32_u_const16 (current_cpu
, idesc
, 0, referenced
);
945 int UNUSED insn_referenced
= abuf
->written
;
950 referenced
|= 1 << 0;
951 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
958 model_crisv32_move_m_b_m (SIM_CPU
*current_cpu
, void *sem_arg
)
960 #define FLD(f) abuf->fields.sfmt_add_m_b_m.f
961 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
962 const IDESC
* UNUSED idesc
= abuf
->idesc
;
966 int UNUSED insn_referenced
= abuf
->written
;
969 if (insn_referenced
& (1 << 0)) referenced
|= 1 << 0;
970 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
974 int UNUSED insn_referenced
= abuf
->written
;
975 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
979 int UNUSED insn_referenced
= abuf
->written
;
984 if (insn_referenced
& (1 << 0)) referenced
|= 1 << 1;
985 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
992 model_crisv32_move_m_w_m (SIM_CPU
*current_cpu
, void *sem_arg
)
994 #define FLD(f) abuf->fields.sfmt_add_m_b_m.f
995 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
996 const IDESC
* UNUSED idesc
= abuf
->idesc
;
1000 int UNUSED insn_referenced
= abuf
->written
;
1002 in_Rs
= FLD (in_Rs
);
1003 if (insn_referenced
& (1 << 0)) referenced
|= 1 << 0;
1004 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
1008 int UNUSED insn_referenced
= abuf
->written
;
1009 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
1013 int UNUSED insn_referenced
= abuf
->written
;
1017 in_Rs
= FLD (in_Rs
);
1018 if (insn_referenced
& (1 << 0)) referenced
|= 1 << 1;
1019 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
1026 model_crisv32_move_m_d_m (SIM_CPU
*current_cpu
, void *sem_arg
)
1028 #define FLD(f) abuf->fields.sfmt_add_m_b_m.f
1029 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
1030 const IDESC
* UNUSED idesc
= abuf
->idesc
;
1034 int UNUSED insn_referenced
= abuf
->written
;
1036 in_Rs
= FLD (in_Rs
);
1037 if (insn_referenced
& (1 << 0)) referenced
|= 1 << 0;
1038 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
1042 int UNUSED insn_referenced
= abuf
->written
;
1043 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
1047 int UNUSED insn_referenced
= abuf
->written
;
1051 in_Rs
= FLD (in_Rs
);
1052 if (insn_referenced
& (1 << 0)) referenced
|= 1 << 1;
1053 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
1060 model_crisv32_movs_m_b_m (SIM_CPU
*current_cpu
, void *sem_arg
)
1062 #define FLD(f) abuf->fields.sfmt_movs_m_b_m.f
1063 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
1064 const IDESC
* UNUSED idesc
= abuf
->idesc
;
1068 int UNUSED insn_referenced
= abuf
->written
;
1070 in_Rs
= FLD (in_Rs
);
1071 if (insn_referenced
& (1 << 0)) referenced
|= 1 << 0;
1072 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
1076 int UNUSED insn_referenced
= abuf
->written
;
1077 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
1081 int UNUSED insn_referenced
= abuf
->written
;
1085 in_Rs
= FLD (in_Rs
);
1086 out_Rd
= FLD (out_Rd
);
1087 if (insn_referenced
& (1 << 0)) referenced
|= 1 << 1;
1088 if (insn_referenced
& (1 << 7)) referenced
|= 1 << 2;
1089 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
1096 model_crisv32_movs_m_w_m (SIM_CPU
*current_cpu
, void *sem_arg
)
1098 #define FLD(f) abuf->fields.sfmt_movs_m_b_m.f
1099 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
1100 const IDESC
* UNUSED idesc
= abuf
->idesc
;
1104 int UNUSED insn_referenced
= abuf
->written
;
1106 in_Rs
= FLD (in_Rs
);
1107 if (insn_referenced
& (1 << 0)) referenced
|= 1 << 0;
1108 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
1112 int UNUSED insn_referenced
= abuf
->written
;
1113 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
1117 int UNUSED insn_referenced
= abuf
->written
;
1121 in_Rs
= FLD (in_Rs
);
1122 out_Rd
= FLD (out_Rd
);
1123 if (insn_referenced
& (1 << 0)) referenced
|= 1 << 1;
1124 if (insn_referenced
& (1 << 7)) referenced
|= 1 << 2;
1125 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
1132 model_crisv32_movu_m_b_m (SIM_CPU
*current_cpu
, void *sem_arg
)
1134 #define FLD(f) abuf->fields.sfmt_movs_m_b_m.f
1135 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
1136 const IDESC
* UNUSED idesc
= abuf
->idesc
;
1140 int UNUSED insn_referenced
= abuf
->written
;
1142 in_Rs
= FLD (in_Rs
);
1143 if (insn_referenced
& (1 << 0)) referenced
|= 1 << 0;
1144 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
1148 int UNUSED insn_referenced
= abuf
->written
;
1149 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
1153 int UNUSED insn_referenced
= abuf
->written
;
1157 in_Rs
= FLD (in_Rs
);
1158 out_Rd
= FLD (out_Rd
);
1159 if (insn_referenced
& (1 << 0)) referenced
|= 1 << 1;
1160 if (insn_referenced
& (1 << 7)) referenced
|= 1 << 2;
1161 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
1168 model_crisv32_movu_m_w_m (SIM_CPU
*current_cpu
, void *sem_arg
)
1170 #define FLD(f) abuf->fields.sfmt_movs_m_b_m.f
1171 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
1172 const IDESC
* UNUSED idesc
= abuf
->idesc
;
1176 int UNUSED insn_referenced
= abuf
->written
;
1178 in_Rs
= FLD (in_Rs
);
1179 if (insn_referenced
& (1 << 0)) referenced
|= 1 << 0;
1180 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
1184 int UNUSED insn_referenced
= abuf
->written
;
1185 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
1189 int UNUSED insn_referenced
= abuf
->written
;
1193 in_Rs
= FLD (in_Rs
);
1194 out_Rd
= FLD (out_Rd
);
1195 if (insn_referenced
& (1 << 0)) referenced
|= 1 << 1;
1196 if (insn_referenced
& (1 << 7)) referenced
|= 1 << 2;
1197 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
1204 model_crisv32_move_r_sprv32 (SIM_CPU
*current_cpu
, void *sem_arg
)
1206 #define FLD(f) abuf->fields.sfmt_move_m_sprv32.f
1207 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
1208 const IDESC
* UNUSED idesc
= abuf
->idesc
;
1212 int UNUSED insn_referenced
= abuf
->written
;
1215 in_Rs
= FLD (in_Rs
);
1216 out_Pd
= FLD (out_Pd
);
1217 referenced
|= 1 << 0;
1218 if (insn_referenced
& (1 << 2)) referenced
|= 1 << 1;
1219 cycles
+= crisv32f_model_crisv32_u_exec_to_sr (current_cpu
, idesc
, 0, referenced
, in_Rs
, out_Pd
);
1226 model_crisv32_move_spr_rv32 (SIM_CPU
*current_cpu
, void *sem_arg
)
1228 #define FLD(f) abuf->fields.sfmt_mcp.f
1229 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
1230 const IDESC
* UNUSED idesc
= abuf
->idesc
;
1234 int UNUSED insn_referenced
= abuf
->written
;
1238 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
1245 model_crisv32_move_m_sprv32 (SIM_CPU
*current_cpu
, void *sem_arg
)
1247 #define FLD(f) abuf->fields.sfmt_move_m_sprv32.f
1248 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
1249 const IDESC
* UNUSED idesc
= abuf
->idesc
;
1253 int UNUSED insn_referenced
= abuf
->written
;
1255 in_Rs
= FLD (in_Rs
);
1256 if (insn_referenced
& (1 << 0)) referenced
|= 1 << 0;
1257 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
1261 int UNUSED insn_referenced
= abuf
->written
;
1262 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
1266 int UNUSED insn_referenced
= abuf
->written
;
1269 in_Rs
= FLD (in_Rs
);
1270 out_Pd
= FLD (out_Pd
);
1271 if (insn_referenced
& (1 << 0)) referenced
|= 1 << 0;
1272 referenced
|= 1 << 1;
1273 cycles
+= crisv32f_model_crisv32_u_exec_to_sr (current_cpu
, idesc
, 2, referenced
, in_Rs
, out_Pd
);
1280 model_crisv32_move_c_sprv32_p2 (SIM_CPU
*current_cpu
, void *sem_arg
)
1282 #define FLD(f) abuf->fields.sfmt_move_c_sprv32_p2.f
1283 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
1284 const IDESC
* UNUSED idesc
= abuf
->idesc
;
1288 int UNUSED insn_referenced
= abuf
->written
;
1289 cycles
+= crisv32f_model_crisv32_u_const32 (current_cpu
, idesc
, 0, referenced
);
1293 int UNUSED insn_referenced
= abuf
->written
;
1296 out_Pd
= FLD (out_Pd
);
1297 referenced
|= 1 << 1;
1298 cycles
+= crisv32f_model_crisv32_u_exec_to_sr (current_cpu
, idesc
, 1, referenced
, in_Rs
, out_Pd
);
1305 model_crisv32_move_c_sprv32_p3 (SIM_CPU
*current_cpu
, void *sem_arg
)
1307 #define FLD(f) abuf->fields.sfmt_move_c_sprv32_p2.f
1308 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
1309 const IDESC
* UNUSED idesc
= abuf
->idesc
;
1313 int UNUSED insn_referenced
= abuf
->written
;
1314 cycles
+= crisv32f_model_crisv32_u_const32 (current_cpu
, idesc
, 0, referenced
);
1318 int UNUSED insn_referenced
= abuf
->written
;
1321 out_Pd
= FLD (out_Pd
);
1322 referenced
|= 1 << 1;
1323 cycles
+= crisv32f_model_crisv32_u_exec_to_sr (current_cpu
, idesc
, 1, referenced
, in_Rs
, out_Pd
);
1330 model_crisv32_move_c_sprv32_p5 (SIM_CPU
*current_cpu
, void *sem_arg
)
1332 #define FLD(f) abuf->fields.sfmt_move_c_sprv32_p2.f
1333 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
1334 const IDESC
* UNUSED idesc
= abuf
->idesc
;
1338 int UNUSED insn_referenced
= abuf
->written
;
1339 cycles
+= crisv32f_model_crisv32_u_const32 (current_cpu
, idesc
, 0, referenced
);
1343 int UNUSED insn_referenced
= abuf
->written
;
1346 out_Pd
= FLD (out_Pd
);
1347 referenced
|= 1 << 1;
1348 cycles
+= crisv32f_model_crisv32_u_exec_to_sr (current_cpu
, idesc
, 1, referenced
, in_Rs
, out_Pd
);
1355 model_crisv32_move_c_sprv32_p6 (SIM_CPU
*current_cpu
, void *sem_arg
)
1357 #define FLD(f) abuf->fields.sfmt_move_c_sprv32_p2.f
1358 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
1359 const IDESC
* UNUSED idesc
= abuf
->idesc
;
1363 int UNUSED insn_referenced
= abuf
->written
;
1364 cycles
+= crisv32f_model_crisv32_u_const32 (current_cpu
, idesc
, 0, referenced
);
1368 int UNUSED insn_referenced
= abuf
->written
;
1371 out_Pd
= FLD (out_Pd
);
1372 referenced
|= 1 << 1;
1373 cycles
+= crisv32f_model_crisv32_u_exec_to_sr (current_cpu
, idesc
, 1, referenced
, in_Rs
, out_Pd
);
1380 model_crisv32_move_c_sprv32_p7 (SIM_CPU
*current_cpu
, void *sem_arg
)
1382 #define FLD(f) abuf->fields.sfmt_move_c_sprv32_p2.f
1383 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
1384 const IDESC
* UNUSED idesc
= abuf
->idesc
;
1388 int UNUSED insn_referenced
= abuf
->written
;
1389 cycles
+= crisv32f_model_crisv32_u_const32 (current_cpu
, idesc
, 0, referenced
);
1393 int UNUSED insn_referenced
= abuf
->written
;
1396 out_Pd
= FLD (out_Pd
);
1397 referenced
|= 1 << 1;
1398 cycles
+= crisv32f_model_crisv32_u_exec_to_sr (current_cpu
, idesc
, 1, referenced
, in_Rs
, out_Pd
);
1405 model_crisv32_move_c_sprv32_p9 (SIM_CPU
*current_cpu
, void *sem_arg
)
1407 #define FLD(f) abuf->fields.sfmt_move_c_sprv32_p2.f
1408 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
1409 const IDESC
* UNUSED idesc
= abuf
->idesc
;
1413 int UNUSED insn_referenced
= abuf
->written
;
1414 cycles
+= crisv32f_model_crisv32_u_const32 (current_cpu
, idesc
, 0, referenced
);
1418 int UNUSED insn_referenced
= abuf
->written
;
1421 out_Pd
= FLD (out_Pd
);
1422 referenced
|= 1 << 1;
1423 cycles
+= crisv32f_model_crisv32_u_exec_to_sr (current_cpu
, idesc
, 1, referenced
, in_Rs
, out_Pd
);
1430 model_crisv32_move_c_sprv32_p10 (SIM_CPU
*current_cpu
, void *sem_arg
)
1432 #define FLD(f) abuf->fields.sfmt_move_c_sprv32_p2.f
1433 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
1434 const IDESC
* UNUSED idesc
= abuf
->idesc
;
1438 int UNUSED insn_referenced
= abuf
->written
;
1439 cycles
+= crisv32f_model_crisv32_u_const32 (current_cpu
, idesc
, 0, referenced
);
1443 int UNUSED insn_referenced
= abuf
->written
;
1446 out_Pd
= FLD (out_Pd
);
1447 referenced
|= 1 << 1;
1448 cycles
+= crisv32f_model_crisv32_u_exec_to_sr (current_cpu
, idesc
, 1, referenced
, in_Rs
, out_Pd
);
1455 model_crisv32_move_c_sprv32_p11 (SIM_CPU
*current_cpu
, void *sem_arg
)
1457 #define FLD(f) abuf->fields.sfmt_move_c_sprv32_p2.f
1458 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
1459 const IDESC
* UNUSED idesc
= abuf
->idesc
;
1463 int UNUSED insn_referenced
= abuf
->written
;
1464 cycles
+= crisv32f_model_crisv32_u_const32 (current_cpu
, idesc
, 0, referenced
);
1468 int UNUSED insn_referenced
= abuf
->written
;
1471 out_Pd
= FLD (out_Pd
);
1472 referenced
|= 1 << 1;
1473 cycles
+= crisv32f_model_crisv32_u_exec_to_sr (current_cpu
, idesc
, 1, referenced
, in_Rs
, out_Pd
);
1480 model_crisv32_move_c_sprv32_p12 (SIM_CPU
*current_cpu
, void *sem_arg
)
1482 #define FLD(f) abuf->fields.sfmt_move_c_sprv32_p2.f
1483 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
1484 const IDESC
* UNUSED idesc
= abuf
->idesc
;
1488 int UNUSED insn_referenced
= abuf
->written
;
1489 cycles
+= crisv32f_model_crisv32_u_const32 (current_cpu
, idesc
, 0, referenced
);
1493 int UNUSED insn_referenced
= abuf
->written
;
1496 out_Pd
= FLD (out_Pd
);
1497 referenced
|= 1 << 1;
1498 cycles
+= crisv32f_model_crisv32_u_exec_to_sr (current_cpu
, idesc
, 1, referenced
, in_Rs
, out_Pd
);
1505 model_crisv32_move_c_sprv32_p13 (SIM_CPU
*current_cpu
, void *sem_arg
)
1507 #define FLD(f) abuf->fields.sfmt_move_c_sprv32_p2.f
1508 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
1509 const IDESC
* UNUSED idesc
= abuf
->idesc
;
1513 int UNUSED insn_referenced
= abuf
->written
;
1514 cycles
+= crisv32f_model_crisv32_u_const32 (current_cpu
, idesc
, 0, referenced
);
1518 int UNUSED insn_referenced
= abuf
->written
;
1521 out_Pd
= FLD (out_Pd
);
1522 referenced
|= 1 << 1;
1523 cycles
+= crisv32f_model_crisv32_u_exec_to_sr (current_cpu
, idesc
, 1, referenced
, in_Rs
, out_Pd
);
1530 model_crisv32_move_c_sprv32_p14 (SIM_CPU
*current_cpu
, void *sem_arg
)
1532 #define FLD(f) abuf->fields.sfmt_move_c_sprv32_p2.f
1533 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
1534 const IDESC
* UNUSED idesc
= abuf
->idesc
;
1538 int UNUSED insn_referenced
= abuf
->written
;
1539 cycles
+= crisv32f_model_crisv32_u_const32 (current_cpu
, idesc
, 0, referenced
);
1543 int UNUSED insn_referenced
= abuf
->written
;
1546 out_Pd
= FLD (out_Pd
);
1547 referenced
|= 1 << 1;
1548 cycles
+= crisv32f_model_crisv32_u_exec_to_sr (current_cpu
, idesc
, 1, referenced
, in_Rs
, out_Pd
);
1555 model_crisv32_move_c_sprv32_p15 (SIM_CPU
*current_cpu
, void *sem_arg
)
1557 #define FLD(f) abuf->fields.sfmt_move_c_sprv32_p2.f
1558 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
1559 const IDESC
* UNUSED idesc
= abuf
->idesc
;
1563 int UNUSED insn_referenced
= abuf
->written
;
1564 cycles
+= crisv32f_model_crisv32_u_const32 (current_cpu
, idesc
, 0, referenced
);
1568 int UNUSED insn_referenced
= abuf
->written
;
1571 out_Pd
= FLD (out_Pd
);
1572 referenced
|= 1 << 1;
1573 cycles
+= crisv32f_model_crisv32_u_exec_to_sr (current_cpu
, idesc
, 1, referenced
, in_Rs
, out_Pd
);
1580 model_crisv32_move_spr_mv32 (SIM_CPU
*current_cpu
, void *sem_arg
)
1582 #define FLD(f) abuf->fields.sfmt_move_spr_mv32.f
1583 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
1584 const IDESC
* UNUSED idesc
= abuf
->idesc
;
1588 int UNUSED insn_referenced
= abuf
->written
;
1590 in_Rs
= FLD (in_Rs
);
1591 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 0;
1592 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
1596 int UNUSED insn_referenced
= abuf
->written
;
1600 in_Rs
= FLD (in_Rs
);
1601 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 1;
1602 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
1606 int UNUSED insn_referenced
= abuf
->written
;
1607 cycles
+= crisv32f_model_crisv32_u_mem_w (current_cpu
, idesc
, 2, referenced
);
1614 model_crisv32_move_ss_r (SIM_CPU
*current_cpu
, void *sem_arg
)
1616 #define FLD(f) abuf->fields.sfmt_move_spr_mv32.f
1617 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
1618 const IDESC
* UNUSED idesc
= abuf
->idesc
;
1622 int UNUSED insn_referenced
= abuf
->written
;
1626 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
1633 model_crisv32_move_r_ss (SIM_CPU
*current_cpu
, void *sem_arg
)
1635 #define FLD(f) abuf->fields.sfmt_mcp.f
1636 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
1637 const IDESC
* UNUSED idesc
= abuf
->idesc
;
1641 int UNUSED insn_referenced
= abuf
->written
;
1645 in_Rs
= FLD (in_Rs
);
1646 referenced
|= 1 << 1;
1647 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
1654 model_crisv32_movem_r_m_v32 (SIM_CPU
*current_cpu
, void *sem_arg
)
1656 #define FLD(f) abuf->fields.sfmt_movem_r_m_v32.f
1657 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
1658 const IDESC
* UNUSED idesc
= abuf
->idesc
;
1662 int UNUSED insn_referenced
= abuf
->written
;
1664 in_Rs
= FLD (in_Rs
);
1665 referenced
|= 1 << 0;
1666 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
1670 int UNUSED insn_referenced
= abuf
->written
;
1673 in_Rs
= FLD (in_Rs
);
1674 in_Rd
= FLD (in_Rd
);
1675 referenced
|= 1 << 0;
1676 referenced
|= 1 << 1;
1677 cycles
+= crisv32f_model_crisv32_u_movem_rtom (current_cpu
, idesc
, 1, referenced
, in_Rs
, in_Rd
);
1681 int UNUSED insn_referenced
= abuf
->written
;
1684 in_Rs
= FLD (in_Rs
);
1685 referenced
|= 1 << 0;
1686 cycles
+= crisv32f_model_crisv32_u_exec_movem (current_cpu
, idesc
, 2, referenced
, in_Rs
, out_Rd
);
1690 int UNUSED insn_referenced
= abuf
->written
;
1691 cycles
+= crisv32f_model_crisv32_u_mem_w (current_cpu
, idesc
, 3, referenced
);
1698 model_crisv32_movem_m_r_v32 (SIM_CPU
*current_cpu
, void *sem_arg
)
1700 #define FLD(f) abuf->fields.sfmt_movem_m_r_v32.f
1701 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
1702 const IDESC
* UNUSED idesc
= abuf
->idesc
;
1706 int UNUSED insn_referenced
= abuf
->written
;
1708 in_Rs
= FLD (in_Rs
);
1709 referenced
|= 1 << 0;
1710 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
1714 int UNUSED insn_referenced
= abuf
->written
;
1715 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
1719 int UNUSED insn_referenced
= abuf
->written
;
1722 in_Rs
= FLD (in_Rs
);
1723 in_Rd
= FLD (in_Rd
);
1724 referenced
|= 1 << 0;
1725 referenced
|= 1 << 1;
1726 cycles
+= crisv32f_model_crisv32_u_movem_mtor (current_cpu
, idesc
, 2, referenced
, in_Rs
, in_Rd
);
1730 int UNUSED insn_referenced
= abuf
->written
;
1733 in_Rs
= FLD (in_Rs
);
1734 referenced
|= 1 << 0;
1735 cycles
+= crisv32f_model_crisv32_u_exec_movem (current_cpu
, idesc
, 3, referenced
, in_Rs
, out_Rd
);
1742 model_crisv32_add_b_r (SIM_CPU
*current_cpu
, void *sem_arg
)
1744 #define FLD(f) abuf->fields.sfmt_addc_m.f
1745 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
1746 const IDESC
* UNUSED idesc
= abuf
->idesc
;
1750 int UNUSED insn_referenced
= abuf
->written
;
1754 in_Rd
= FLD (in_Rd
);
1755 in_Rs
= FLD (in_Rs
);
1756 referenced
|= 1 << 0;
1757 referenced
|= 1 << 1;
1758 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
1765 model_crisv32_add_w_r (SIM_CPU
*current_cpu
, void *sem_arg
)
1767 #define FLD(f) abuf->fields.sfmt_addc_m.f
1768 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
1769 const IDESC
* UNUSED idesc
= abuf
->idesc
;
1773 int UNUSED insn_referenced
= abuf
->written
;
1777 in_Rd
= FLD (in_Rd
);
1778 in_Rs
= FLD (in_Rs
);
1779 referenced
|= 1 << 0;
1780 referenced
|= 1 << 1;
1781 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
1788 model_crisv32_add_d_r (SIM_CPU
*current_cpu
, void *sem_arg
)
1790 #define FLD(f) abuf->fields.sfmt_addc_m.f
1791 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
1792 const IDESC
* UNUSED idesc
= abuf
->idesc
;
1796 int UNUSED insn_referenced
= abuf
->written
;
1800 in_Rd
= FLD (in_Rd
);
1801 in_Rs
= FLD (in_Rs
);
1802 referenced
|= 1 << 0;
1803 referenced
|= 1 << 1;
1804 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
1811 model_crisv32_add_m_b_m (SIM_CPU
*current_cpu
, void *sem_arg
)
1813 #define FLD(f) abuf->fields.sfmt_add_m_b_m.f
1814 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
1815 const IDESC
* UNUSED idesc
= abuf
->idesc
;
1819 int UNUSED insn_referenced
= abuf
->written
;
1821 in_Rs
= FLD (in_Rs
);
1822 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 0;
1823 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
1827 int UNUSED insn_referenced
= abuf
->written
;
1828 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
1832 int UNUSED insn_referenced
= abuf
->written
;
1836 in_Rd
= FLD (in_Rd
);
1837 in_Rs
= FLD (in_Rs
);
1838 referenced
|= 1 << 0;
1839 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 1;
1840 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
1847 model_crisv32_add_m_w_m (SIM_CPU
*current_cpu
, void *sem_arg
)
1849 #define FLD(f) abuf->fields.sfmt_add_m_b_m.f
1850 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
1851 const IDESC
* UNUSED idesc
= abuf
->idesc
;
1855 int UNUSED insn_referenced
= abuf
->written
;
1857 in_Rs
= FLD (in_Rs
);
1858 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 0;
1859 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
1863 int UNUSED insn_referenced
= abuf
->written
;
1864 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
1868 int UNUSED insn_referenced
= abuf
->written
;
1872 in_Rd
= FLD (in_Rd
);
1873 in_Rs
= FLD (in_Rs
);
1874 referenced
|= 1 << 0;
1875 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 1;
1876 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
1883 model_crisv32_add_m_d_m (SIM_CPU
*current_cpu
, void *sem_arg
)
1885 #define FLD(f) abuf->fields.sfmt_add_m_b_m.f
1886 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
1887 const IDESC
* UNUSED idesc
= abuf
->idesc
;
1891 int UNUSED insn_referenced
= abuf
->written
;
1893 in_Rs
= FLD (in_Rs
);
1894 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 0;
1895 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
1899 int UNUSED insn_referenced
= abuf
->written
;
1900 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
1904 int UNUSED insn_referenced
= abuf
->written
;
1908 in_Rd
= FLD (in_Rd
);
1909 in_Rs
= FLD (in_Rs
);
1910 referenced
|= 1 << 0;
1911 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 1;
1912 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
1919 model_crisv32_addcbr (SIM_CPU
*current_cpu
, void *sem_arg
)
1921 #define FLD(f) abuf->fields.sfmt_addcbr.f
1922 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
1923 const IDESC
* UNUSED idesc
= abuf
->idesc
;
1927 int UNUSED insn_referenced
= abuf
->written
;
1928 cycles
+= crisv32f_model_crisv32_u_const16 (current_cpu
, idesc
, 0, referenced
);
1932 int UNUSED insn_referenced
= abuf
->written
;
1936 in_Rd
= FLD (in_Rd
);
1937 referenced
|= 1 << 0;
1938 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
1945 model_crisv32_addcwr (SIM_CPU
*current_cpu
, void *sem_arg
)
1947 #define FLD(f) abuf->fields.sfmt_addcwr.f
1948 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
1949 const IDESC
* UNUSED idesc
= abuf
->idesc
;
1953 int UNUSED insn_referenced
= abuf
->written
;
1954 cycles
+= crisv32f_model_crisv32_u_const16 (current_cpu
, idesc
, 0, referenced
);
1958 int UNUSED insn_referenced
= abuf
->written
;
1962 in_Rd
= FLD (in_Rd
);
1963 referenced
|= 1 << 0;
1964 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
1971 model_crisv32_addcdr (SIM_CPU
*current_cpu
, void *sem_arg
)
1973 #define FLD(f) abuf->fields.sfmt_addcdr.f
1974 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
1975 const IDESC
* UNUSED idesc
= abuf
->idesc
;
1979 int UNUSED insn_referenced
= abuf
->written
;
1980 cycles
+= crisv32f_model_crisv32_u_const32 (current_cpu
, idesc
, 0, referenced
);
1984 int UNUSED insn_referenced
= abuf
->written
;
1988 in_Rd
= FLD (in_Rd
);
1989 referenced
|= 1 << 0;
1990 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
1997 model_crisv32_adds_b_r (SIM_CPU
*current_cpu
, void *sem_arg
)
1999 #define FLD(f) abuf->fields.sfmt_addc_m.f
2000 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
2001 const IDESC
* UNUSED idesc
= abuf
->idesc
;
2005 int UNUSED insn_referenced
= abuf
->written
;
2009 in_Rd
= FLD (in_Rd
);
2010 in_Rs
= FLD (in_Rs
);
2011 referenced
|= 1 << 0;
2012 referenced
|= 1 << 1;
2013 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
2020 model_crisv32_adds_w_r (SIM_CPU
*current_cpu
, void *sem_arg
)
2022 #define FLD(f) abuf->fields.sfmt_addc_m.f
2023 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
2024 const IDESC
* UNUSED idesc
= abuf
->idesc
;
2028 int UNUSED insn_referenced
= abuf
->written
;
2032 in_Rd
= FLD (in_Rd
);
2033 in_Rs
= FLD (in_Rs
);
2034 referenced
|= 1 << 0;
2035 referenced
|= 1 << 1;
2036 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
2043 model_crisv32_adds_m_b_m (SIM_CPU
*current_cpu
, void *sem_arg
)
2045 #define FLD(f) abuf->fields.sfmt_add_m_b_m.f
2046 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
2047 const IDESC
* UNUSED idesc
= abuf
->idesc
;
2051 int UNUSED insn_referenced
= abuf
->written
;
2053 in_Rs
= FLD (in_Rs
);
2054 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 0;
2055 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
2059 int UNUSED insn_referenced
= abuf
->written
;
2060 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
2064 int UNUSED insn_referenced
= abuf
->written
;
2068 in_Rd
= FLD (in_Rd
);
2069 in_Rs
= FLD (in_Rs
);
2070 referenced
|= 1 << 0;
2071 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 1;
2072 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
2079 model_crisv32_adds_m_w_m (SIM_CPU
*current_cpu
, void *sem_arg
)
2081 #define FLD(f) abuf->fields.sfmt_add_m_b_m.f
2082 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
2083 const IDESC
* UNUSED idesc
= abuf
->idesc
;
2087 int UNUSED insn_referenced
= abuf
->written
;
2089 in_Rs
= FLD (in_Rs
);
2090 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 0;
2091 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
2095 int UNUSED insn_referenced
= abuf
->written
;
2096 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
2100 int UNUSED insn_referenced
= abuf
->written
;
2104 in_Rd
= FLD (in_Rd
);
2105 in_Rs
= FLD (in_Rs
);
2106 referenced
|= 1 << 0;
2107 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 1;
2108 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
2115 model_crisv32_addscbr (SIM_CPU
*current_cpu
, void *sem_arg
)
2117 #define FLD(f) abuf->fields.sfmt_addcbr.f
2118 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
2119 const IDESC
* UNUSED idesc
= abuf
->idesc
;
2123 int UNUSED insn_referenced
= abuf
->written
;
2124 cycles
+= crisv32f_model_crisv32_u_const16 (current_cpu
, idesc
, 0, referenced
);
2128 int UNUSED insn_referenced
= abuf
->written
;
2132 in_Rd
= FLD (in_Rd
);
2133 referenced
|= 1 << 0;
2134 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
2141 model_crisv32_addscwr (SIM_CPU
*current_cpu
, void *sem_arg
)
2143 #define FLD(f) abuf->fields.sfmt_addcwr.f
2144 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
2145 const IDESC
* UNUSED idesc
= abuf
->idesc
;
2149 int UNUSED insn_referenced
= abuf
->written
;
2150 cycles
+= crisv32f_model_crisv32_u_const16 (current_cpu
, idesc
, 0, referenced
);
2154 int UNUSED insn_referenced
= abuf
->written
;
2158 in_Rd
= FLD (in_Rd
);
2159 referenced
|= 1 << 0;
2160 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
2167 model_crisv32_addu_b_r (SIM_CPU
*current_cpu
, void *sem_arg
)
2169 #define FLD(f) abuf->fields.sfmt_addc_m.f
2170 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
2171 const IDESC
* UNUSED idesc
= abuf
->idesc
;
2175 int UNUSED insn_referenced
= abuf
->written
;
2179 in_Rd
= FLD (in_Rd
);
2180 in_Rs
= FLD (in_Rs
);
2181 referenced
|= 1 << 0;
2182 referenced
|= 1 << 1;
2183 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
2190 model_crisv32_addu_w_r (SIM_CPU
*current_cpu
, void *sem_arg
)
2192 #define FLD(f) abuf->fields.sfmt_addc_m.f
2193 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
2194 const IDESC
* UNUSED idesc
= abuf
->idesc
;
2198 int UNUSED insn_referenced
= abuf
->written
;
2202 in_Rd
= FLD (in_Rd
);
2203 in_Rs
= FLD (in_Rs
);
2204 referenced
|= 1 << 0;
2205 referenced
|= 1 << 1;
2206 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
2213 model_crisv32_addu_m_b_m (SIM_CPU
*current_cpu
, void *sem_arg
)
2215 #define FLD(f) abuf->fields.sfmt_add_m_b_m.f
2216 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
2217 const IDESC
* UNUSED idesc
= abuf
->idesc
;
2221 int UNUSED insn_referenced
= abuf
->written
;
2223 in_Rs
= FLD (in_Rs
);
2224 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 0;
2225 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
2229 int UNUSED insn_referenced
= abuf
->written
;
2230 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
2234 int UNUSED insn_referenced
= abuf
->written
;
2238 in_Rd
= FLD (in_Rd
);
2239 in_Rs
= FLD (in_Rs
);
2240 referenced
|= 1 << 0;
2241 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 1;
2242 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
2249 model_crisv32_addu_m_w_m (SIM_CPU
*current_cpu
, void *sem_arg
)
2251 #define FLD(f) abuf->fields.sfmt_add_m_b_m.f
2252 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
2253 const IDESC
* UNUSED idesc
= abuf
->idesc
;
2257 int UNUSED insn_referenced
= abuf
->written
;
2259 in_Rs
= FLD (in_Rs
);
2260 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 0;
2261 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
2265 int UNUSED insn_referenced
= abuf
->written
;
2266 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
2270 int UNUSED insn_referenced
= abuf
->written
;
2274 in_Rd
= FLD (in_Rd
);
2275 in_Rs
= FLD (in_Rs
);
2276 referenced
|= 1 << 0;
2277 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 1;
2278 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
2285 model_crisv32_adducbr (SIM_CPU
*current_cpu
, void *sem_arg
)
2287 #define FLD(f) abuf->fields.sfmt_addcbr.f
2288 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
2289 const IDESC
* UNUSED idesc
= abuf
->idesc
;
2293 int UNUSED insn_referenced
= abuf
->written
;
2294 cycles
+= crisv32f_model_crisv32_u_const16 (current_cpu
, idesc
, 0, referenced
);
2298 int UNUSED insn_referenced
= abuf
->written
;
2302 in_Rd
= FLD (in_Rd
);
2303 referenced
|= 1 << 0;
2304 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
2311 model_crisv32_adducwr (SIM_CPU
*current_cpu
, void *sem_arg
)
2313 #define FLD(f) abuf->fields.sfmt_addcwr.f
2314 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
2315 const IDESC
* UNUSED idesc
= abuf
->idesc
;
2319 int UNUSED insn_referenced
= abuf
->written
;
2320 cycles
+= crisv32f_model_crisv32_u_const16 (current_cpu
, idesc
, 0, referenced
);
2324 int UNUSED insn_referenced
= abuf
->written
;
2328 in_Rd
= FLD (in_Rd
);
2329 referenced
|= 1 << 0;
2330 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
2337 model_crisv32_sub_b_r (SIM_CPU
*current_cpu
, void *sem_arg
)
2339 #define FLD(f) abuf->fields.sfmt_addc_m.f
2340 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
2341 const IDESC
* UNUSED idesc
= abuf
->idesc
;
2345 int UNUSED insn_referenced
= abuf
->written
;
2349 in_Rd
= FLD (in_Rd
);
2350 in_Rs
= FLD (in_Rs
);
2351 referenced
|= 1 << 0;
2352 referenced
|= 1 << 1;
2353 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
2360 model_crisv32_sub_w_r (SIM_CPU
*current_cpu
, void *sem_arg
)
2362 #define FLD(f) abuf->fields.sfmt_addc_m.f
2363 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
2364 const IDESC
* UNUSED idesc
= abuf
->idesc
;
2368 int UNUSED insn_referenced
= abuf
->written
;
2372 in_Rd
= FLD (in_Rd
);
2373 in_Rs
= FLD (in_Rs
);
2374 referenced
|= 1 << 0;
2375 referenced
|= 1 << 1;
2376 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
2383 model_crisv32_sub_d_r (SIM_CPU
*current_cpu
, void *sem_arg
)
2385 #define FLD(f) abuf->fields.sfmt_addc_m.f
2386 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
2387 const IDESC
* UNUSED idesc
= abuf
->idesc
;
2391 int UNUSED insn_referenced
= abuf
->written
;
2395 in_Rd
= FLD (in_Rd
);
2396 in_Rs
= FLD (in_Rs
);
2397 referenced
|= 1 << 0;
2398 referenced
|= 1 << 1;
2399 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
2406 model_crisv32_sub_m_b_m (SIM_CPU
*current_cpu
, void *sem_arg
)
2408 #define FLD(f) abuf->fields.sfmt_add_m_b_m.f
2409 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
2410 const IDESC
* UNUSED idesc
= abuf
->idesc
;
2414 int UNUSED insn_referenced
= abuf
->written
;
2416 in_Rs
= FLD (in_Rs
);
2417 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 0;
2418 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
2422 int UNUSED insn_referenced
= abuf
->written
;
2423 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
2427 int UNUSED insn_referenced
= abuf
->written
;
2431 in_Rd
= FLD (in_Rd
);
2432 in_Rs
= FLD (in_Rs
);
2433 referenced
|= 1 << 0;
2434 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 1;
2435 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
2442 model_crisv32_sub_m_w_m (SIM_CPU
*current_cpu
, void *sem_arg
)
2444 #define FLD(f) abuf->fields.sfmt_add_m_b_m.f
2445 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
2446 const IDESC
* UNUSED idesc
= abuf
->idesc
;
2450 int UNUSED insn_referenced
= abuf
->written
;
2452 in_Rs
= FLD (in_Rs
);
2453 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 0;
2454 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
2458 int UNUSED insn_referenced
= abuf
->written
;
2459 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
2463 int UNUSED insn_referenced
= abuf
->written
;
2467 in_Rd
= FLD (in_Rd
);
2468 in_Rs
= FLD (in_Rs
);
2469 referenced
|= 1 << 0;
2470 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 1;
2471 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
2478 model_crisv32_sub_m_d_m (SIM_CPU
*current_cpu
, void *sem_arg
)
2480 #define FLD(f) abuf->fields.sfmt_add_m_b_m.f
2481 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
2482 const IDESC
* UNUSED idesc
= abuf
->idesc
;
2486 int UNUSED insn_referenced
= abuf
->written
;
2488 in_Rs
= FLD (in_Rs
);
2489 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 0;
2490 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
2494 int UNUSED insn_referenced
= abuf
->written
;
2495 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
2499 int UNUSED insn_referenced
= abuf
->written
;
2503 in_Rd
= FLD (in_Rd
);
2504 in_Rs
= FLD (in_Rs
);
2505 referenced
|= 1 << 0;
2506 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 1;
2507 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
2514 model_crisv32_subcbr (SIM_CPU
*current_cpu
, void *sem_arg
)
2516 #define FLD(f) abuf->fields.sfmt_addcbr.f
2517 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
2518 const IDESC
* UNUSED idesc
= abuf
->idesc
;
2522 int UNUSED insn_referenced
= abuf
->written
;
2523 cycles
+= crisv32f_model_crisv32_u_const16 (current_cpu
, idesc
, 0, referenced
);
2527 int UNUSED insn_referenced
= abuf
->written
;
2531 in_Rd
= FLD (in_Rd
);
2532 referenced
|= 1 << 0;
2533 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
2540 model_crisv32_subcwr (SIM_CPU
*current_cpu
, void *sem_arg
)
2542 #define FLD(f) abuf->fields.sfmt_addcwr.f
2543 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
2544 const IDESC
* UNUSED idesc
= abuf
->idesc
;
2548 int UNUSED insn_referenced
= abuf
->written
;
2549 cycles
+= crisv32f_model_crisv32_u_const16 (current_cpu
, idesc
, 0, referenced
);
2553 int UNUSED insn_referenced
= abuf
->written
;
2557 in_Rd
= FLD (in_Rd
);
2558 referenced
|= 1 << 0;
2559 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
2566 model_crisv32_subcdr (SIM_CPU
*current_cpu
, void *sem_arg
)
2568 #define FLD(f) abuf->fields.sfmt_addcdr.f
2569 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
2570 const IDESC
* UNUSED idesc
= abuf
->idesc
;
2574 int UNUSED insn_referenced
= abuf
->written
;
2575 cycles
+= crisv32f_model_crisv32_u_const32 (current_cpu
, idesc
, 0, referenced
);
2579 int UNUSED insn_referenced
= abuf
->written
;
2583 in_Rd
= FLD (in_Rd
);
2584 referenced
|= 1 << 0;
2585 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
2592 model_crisv32_subs_b_r (SIM_CPU
*current_cpu
, void *sem_arg
)
2594 #define FLD(f) abuf->fields.sfmt_addc_m.f
2595 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
2596 const IDESC
* UNUSED idesc
= abuf
->idesc
;
2600 int UNUSED insn_referenced
= abuf
->written
;
2604 in_Rd
= FLD (in_Rd
);
2605 in_Rs
= FLD (in_Rs
);
2606 referenced
|= 1 << 0;
2607 referenced
|= 1 << 1;
2608 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
2615 model_crisv32_subs_w_r (SIM_CPU
*current_cpu
, void *sem_arg
)
2617 #define FLD(f) abuf->fields.sfmt_addc_m.f
2618 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
2619 const IDESC
* UNUSED idesc
= abuf
->idesc
;
2623 int UNUSED insn_referenced
= abuf
->written
;
2627 in_Rd
= FLD (in_Rd
);
2628 in_Rs
= FLD (in_Rs
);
2629 referenced
|= 1 << 0;
2630 referenced
|= 1 << 1;
2631 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
2638 model_crisv32_subs_m_b_m (SIM_CPU
*current_cpu
, void *sem_arg
)
2640 #define FLD(f) abuf->fields.sfmt_add_m_b_m.f
2641 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
2642 const IDESC
* UNUSED idesc
= abuf
->idesc
;
2646 int UNUSED insn_referenced
= abuf
->written
;
2648 in_Rs
= FLD (in_Rs
);
2649 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 0;
2650 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
2654 int UNUSED insn_referenced
= abuf
->written
;
2655 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
2659 int UNUSED insn_referenced
= abuf
->written
;
2663 in_Rd
= FLD (in_Rd
);
2664 in_Rs
= FLD (in_Rs
);
2665 referenced
|= 1 << 0;
2666 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 1;
2667 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
2674 model_crisv32_subs_m_w_m (SIM_CPU
*current_cpu
, void *sem_arg
)
2676 #define FLD(f) abuf->fields.sfmt_add_m_b_m.f
2677 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
2678 const IDESC
* UNUSED idesc
= abuf
->idesc
;
2682 int UNUSED insn_referenced
= abuf
->written
;
2684 in_Rs
= FLD (in_Rs
);
2685 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 0;
2686 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
2690 int UNUSED insn_referenced
= abuf
->written
;
2691 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
2695 int UNUSED insn_referenced
= abuf
->written
;
2699 in_Rd
= FLD (in_Rd
);
2700 in_Rs
= FLD (in_Rs
);
2701 referenced
|= 1 << 0;
2702 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 1;
2703 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
2710 model_crisv32_subscbr (SIM_CPU
*current_cpu
, void *sem_arg
)
2712 #define FLD(f) abuf->fields.sfmt_addcbr.f
2713 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
2714 const IDESC
* UNUSED idesc
= abuf
->idesc
;
2718 int UNUSED insn_referenced
= abuf
->written
;
2719 cycles
+= crisv32f_model_crisv32_u_const16 (current_cpu
, idesc
, 0, referenced
);
2723 int UNUSED insn_referenced
= abuf
->written
;
2727 in_Rd
= FLD (in_Rd
);
2728 referenced
|= 1 << 0;
2729 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
2736 model_crisv32_subscwr (SIM_CPU
*current_cpu
, void *sem_arg
)
2738 #define FLD(f) abuf->fields.sfmt_addcwr.f
2739 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
2740 const IDESC
* UNUSED idesc
= abuf
->idesc
;
2744 int UNUSED insn_referenced
= abuf
->written
;
2745 cycles
+= crisv32f_model_crisv32_u_const16 (current_cpu
, idesc
, 0, referenced
);
2749 int UNUSED insn_referenced
= abuf
->written
;
2753 in_Rd
= FLD (in_Rd
);
2754 referenced
|= 1 << 0;
2755 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
2762 model_crisv32_subu_b_r (SIM_CPU
*current_cpu
, void *sem_arg
)
2764 #define FLD(f) abuf->fields.sfmt_addc_m.f
2765 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
2766 const IDESC
* UNUSED idesc
= abuf
->idesc
;
2770 int UNUSED insn_referenced
= abuf
->written
;
2774 in_Rd
= FLD (in_Rd
);
2775 in_Rs
= FLD (in_Rs
);
2776 referenced
|= 1 << 0;
2777 referenced
|= 1 << 1;
2778 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
2785 model_crisv32_subu_w_r (SIM_CPU
*current_cpu
, void *sem_arg
)
2787 #define FLD(f) abuf->fields.sfmt_addc_m.f
2788 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
2789 const IDESC
* UNUSED idesc
= abuf
->idesc
;
2793 int UNUSED insn_referenced
= abuf
->written
;
2797 in_Rd
= FLD (in_Rd
);
2798 in_Rs
= FLD (in_Rs
);
2799 referenced
|= 1 << 0;
2800 referenced
|= 1 << 1;
2801 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
2808 model_crisv32_subu_m_b_m (SIM_CPU
*current_cpu
, void *sem_arg
)
2810 #define FLD(f) abuf->fields.sfmt_add_m_b_m.f
2811 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
2812 const IDESC
* UNUSED idesc
= abuf
->idesc
;
2816 int UNUSED insn_referenced
= abuf
->written
;
2818 in_Rs
= FLD (in_Rs
);
2819 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 0;
2820 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
2824 int UNUSED insn_referenced
= abuf
->written
;
2825 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
2829 int UNUSED insn_referenced
= abuf
->written
;
2833 in_Rd
= FLD (in_Rd
);
2834 in_Rs
= FLD (in_Rs
);
2835 referenced
|= 1 << 0;
2836 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 1;
2837 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
2844 model_crisv32_subu_m_w_m (SIM_CPU
*current_cpu
, void *sem_arg
)
2846 #define FLD(f) abuf->fields.sfmt_add_m_b_m.f
2847 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
2848 const IDESC
* UNUSED idesc
= abuf
->idesc
;
2852 int UNUSED insn_referenced
= abuf
->written
;
2854 in_Rs
= FLD (in_Rs
);
2855 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 0;
2856 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
2860 int UNUSED insn_referenced
= abuf
->written
;
2861 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
2865 int UNUSED insn_referenced
= abuf
->written
;
2869 in_Rd
= FLD (in_Rd
);
2870 in_Rs
= FLD (in_Rs
);
2871 referenced
|= 1 << 0;
2872 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 1;
2873 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
2880 model_crisv32_subucbr (SIM_CPU
*current_cpu
, void *sem_arg
)
2882 #define FLD(f) abuf->fields.sfmt_addcbr.f
2883 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
2884 const IDESC
* UNUSED idesc
= abuf
->idesc
;
2888 int UNUSED insn_referenced
= abuf
->written
;
2889 cycles
+= crisv32f_model_crisv32_u_const16 (current_cpu
, idesc
, 0, referenced
);
2893 int UNUSED insn_referenced
= abuf
->written
;
2897 in_Rd
= FLD (in_Rd
);
2898 referenced
|= 1 << 0;
2899 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
2906 model_crisv32_subucwr (SIM_CPU
*current_cpu
, void *sem_arg
)
2908 #define FLD(f) abuf->fields.sfmt_addcwr.f
2909 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
2910 const IDESC
* UNUSED idesc
= abuf
->idesc
;
2914 int UNUSED insn_referenced
= abuf
->written
;
2915 cycles
+= crisv32f_model_crisv32_u_const16 (current_cpu
, idesc
, 0, referenced
);
2919 int UNUSED insn_referenced
= abuf
->written
;
2923 in_Rd
= FLD (in_Rd
);
2924 referenced
|= 1 << 0;
2925 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
2932 model_crisv32_addc_r (SIM_CPU
*current_cpu
, void *sem_arg
)
2934 #define FLD(f) abuf->fields.sfmt_addc_m.f
2935 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
2936 const IDESC
* UNUSED idesc
= abuf
->idesc
;
2940 int UNUSED insn_referenced
= abuf
->written
;
2944 in_Rd
= FLD (in_Rd
);
2945 in_Rs
= FLD (in_Rs
);
2946 referenced
|= 1 << 0;
2947 referenced
|= 1 << 1;
2948 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
2955 model_crisv32_addc_m (SIM_CPU
*current_cpu
, void *sem_arg
)
2957 #define FLD(f) abuf->fields.sfmt_addc_m.f
2958 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
2959 const IDESC
* UNUSED idesc
= abuf
->idesc
;
2963 int UNUSED insn_referenced
= abuf
->written
;
2965 in_Rs
= FLD (in_Rs
);
2966 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 0;
2967 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
2971 int UNUSED insn_referenced
= abuf
->written
;
2972 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
2976 int UNUSED insn_referenced
= abuf
->written
;
2980 in_Rd
= FLD (in_Rd
);
2981 in_Rs
= FLD (in_Rs
);
2982 referenced
|= 1 << 0;
2983 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 1;
2984 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
2991 model_crisv32_addc_c (SIM_CPU
*current_cpu
, void *sem_arg
)
2993 #define FLD(f) abuf->fields.sfmt_addcdr.f
2994 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
2995 const IDESC
* UNUSED idesc
= abuf
->idesc
;
2999 int UNUSED insn_referenced
= abuf
->written
;
3000 cycles
+= crisv32f_model_crisv32_u_const32 (current_cpu
, idesc
, 0, referenced
);
3004 int UNUSED insn_referenced
= abuf
->written
;
3008 in_Rd
= FLD (in_Rd
);
3009 referenced
|= 1 << 0;
3010 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
3017 model_crisv32_lapc_d (SIM_CPU
*current_cpu
, void *sem_arg
)
3019 #define FLD(f) abuf->fields.sfmt_lapc_d.f
3020 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
3021 const IDESC
* UNUSED idesc
= abuf
->idesc
;
3025 int UNUSED insn_referenced
= abuf
->written
;
3026 cycles
+= crisv32f_model_crisv32_u_const32 (current_cpu
, idesc
, 0, referenced
);
3030 int UNUSED insn_referenced
= abuf
->written
;
3034 out_Rd
= FLD (out_Rd
);
3035 referenced
|= 1 << 2;
3036 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
3043 model_crisv32_lapcq (SIM_CPU
*current_cpu
, void *sem_arg
)
3045 #define FLD(f) abuf->fields.sfmt_lapcq.f
3046 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
3047 const IDESC
* UNUSED idesc
= abuf
->idesc
;
3051 int UNUSED insn_referenced
= abuf
->written
;
3055 out_Rd
= FLD (out_Rd
);
3056 referenced
|= 1 << 2;
3057 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
3064 model_crisv32_addi_b_r (SIM_CPU
*current_cpu
, void *sem_arg
)
3066 #define FLD(f) abuf->fields.sfmt_addc_m.f
3067 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
3068 const IDESC
* UNUSED idesc
= abuf
->idesc
;
3072 int UNUSED insn_referenced
= abuf
->written
;
3076 in_Rd
= FLD (in_Rd
);
3077 in_Rs
= FLD (in_Rs
);
3078 referenced
|= 1 << 0;
3079 referenced
|= 1 << 1;
3080 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
3087 model_crisv32_addi_w_r (SIM_CPU
*current_cpu
, void *sem_arg
)
3089 #define FLD(f) abuf->fields.sfmt_addc_m.f
3090 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
3091 const IDESC
* UNUSED idesc
= abuf
->idesc
;
3095 int UNUSED insn_referenced
= abuf
->written
;
3099 in_Rd
= FLD (in_Rd
);
3100 in_Rs
= FLD (in_Rs
);
3101 referenced
|= 1 << 0;
3102 referenced
|= 1 << 1;
3103 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
3110 model_crisv32_addi_d_r (SIM_CPU
*current_cpu
, void *sem_arg
)
3112 #define FLD(f) abuf->fields.sfmt_addc_m.f
3113 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
3114 const IDESC
* UNUSED idesc
= abuf
->idesc
;
3118 int UNUSED insn_referenced
= abuf
->written
;
3122 in_Rd
= FLD (in_Rd
);
3123 in_Rs
= FLD (in_Rs
);
3124 referenced
|= 1 << 0;
3125 referenced
|= 1 << 1;
3126 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
3133 model_crisv32_neg_b_r (SIM_CPU
*current_cpu
, void *sem_arg
)
3135 #define FLD(f) abuf->fields.sfmt_addc_m.f
3136 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
3137 const IDESC
* UNUSED idesc
= abuf
->idesc
;
3141 int UNUSED insn_referenced
= abuf
->written
;
3145 in_Rs
= FLD (in_Rs
);
3146 referenced
|= 1 << 1;
3147 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
3154 model_crisv32_neg_w_r (SIM_CPU
*current_cpu
, void *sem_arg
)
3156 #define FLD(f) abuf->fields.sfmt_addc_m.f
3157 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
3158 const IDESC
* UNUSED idesc
= abuf
->idesc
;
3162 int UNUSED insn_referenced
= abuf
->written
;
3166 in_Rs
= FLD (in_Rs
);
3167 referenced
|= 1 << 1;
3168 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
3175 model_crisv32_neg_d_r (SIM_CPU
*current_cpu
, void *sem_arg
)
3177 #define FLD(f) abuf->fields.sfmt_addc_m.f
3178 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
3179 const IDESC
* UNUSED idesc
= abuf
->idesc
;
3183 int UNUSED insn_referenced
= abuf
->written
;
3187 in_Rs
= FLD (in_Rs
);
3188 referenced
|= 1 << 1;
3189 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
3196 model_crisv32_test_m_b_m (SIM_CPU
*current_cpu
, void *sem_arg
)
3198 #define FLD(f) abuf->fields.sfmt_move_spr_mv32.f
3199 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
3200 const IDESC
* UNUSED idesc
= abuf
->idesc
;
3204 int UNUSED insn_referenced
= abuf
->written
;
3206 in_Rs
= FLD (in_Rs
);
3207 if (insn_referenced
& (1 << 0)) referenced
|= 1 << 0;
3208 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
3212 int UNUSED insn_referenced
= abuf
->written
;
3213 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
3217 int UNUSED insn_referenced
= abuf
->written
;
3221 in_Rs
= FLD (in_Rs
);
3222 if (insn_referenced
& (1 << 0)) referenced
|= 1 << 1;
3223 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
3230 model_crisv32_test_m_w_m (SIM_CPU
*current_cpu
, void *sem_arg
)
3232 #define FLD(f) abuf->fields.sfmt_move_spr_mv32.f
3233 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
3234 const IDESC
* UNUSED idesc
= abuf
->idesc
;
3238 int UNUSED insn_referenced
= abuf
->written
;
3240 in_Rs
= FLD (in_Rs
);
3241 if (insn_referenced
& (1 << 0)) referenced
|= 1 << 0;
3242 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
3246 int UNUSED insn_referenced
= abuf
->written
;
3247 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
3251 int UNUSED insn_referenced
= abuf
->written
;
3255 in_Rs
= FLD (in_Rs
);
3256 if (insn_referenced
& (1 << 0)) referenced
|= 1 << 1;
3257 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
3264 model_crisv32_test_m_d_m (SIM_CPU
*current_cpu
, void *sem_arg
)
3266 #define FLD(f) abuf->fields.sfmt_move_spr_mv32.f
3267 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
3268 const IDESC
* UNUSED idesc
= abuf
->idesc
;
3272 int UNUSED insn_referenced
= abuf
->written
;
3274 in_Rs
= FLD (in_Rs
);
3275 if (insn_referenced
& (1 << 0)) referenced
|= 1 << 0;
3276 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
3280 int UNUSED insn_referenced
= abuf
->written
;
3281 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
3285 int UNUSED insn_referenced
= abuf
->written
;
3289 in_Rs
= FLD (in_Rs
);
3290 if (insn_referenced
& (1 << 0)) referenced
|= 1 << 1;
3291 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
3298 model_crisv32_move_r_m_b_m (SIM_CPU
*current_cpu
, void *sem_arg
)
3300 #define FLD(f) abuf->fields.sfmt_addc_m.f
3301 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
3302 const IDESC
* UNUSED idesc
= abuf
->idesc
;
3306 int UNUSED insn_referenced
= abuf
->written
;
3308 in_Rs
= FLD (in_Rs
);
3309 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 0;
3310 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
3314 int UNUSED insn_referenced
= abuf
->written
;
3318 in_Rd
= FLD (in_Rd
);
3319 in_Rs
= FLD (in_Rs
);
3320 referenced
|= 1 << 0;
3321 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 1;
3322 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
3326 int UNUSED insn_referenced
= abuf
->written
;
3327 cycles
+= crisv32f_model_crisv32_u_mem_w (current_cpu
, idesc
, 2, referenced
);
3334 model_crisv32_move_r_m_w_m (SIM_CPU
*current_cpu
, void *sem_arg
)
3336 #define FLD(f) abuf->fields.sfmt_addc_m.f
3337 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
3338 const IDESC
* UNUSED idesc
= abuf
->idesc
;
3342 int UNUSED insn_referenced
= abuf
->written
;
3344 in_Rs
= FLD (in_Rs
);
3345 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 0;
3346 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
3350 int UNUSED insn_referenced
= abuf
->written
;
3354 in_Rd
= FLD (in_Rd
);
3355 in_Rs
= FLD (in_Rs
);
3356 referenced
|= 1 << 0;
3357 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 1;
3358 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
3362 int UNUSED insn_referenced
= abuf
->written
;
3363 cycles
+= crisv32f_model_crisv32_u_mem_w (current_cpu
, idesc
, 2, referenced
);
3370 model_crisv32_move_r_m_d_m (SIM_CPU
*current_cpu
, void *sem_arg
)
3372 #define FLD(f) abuf->fields.sfmt_addc_m.f
3373 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
3374 const IDESC
* UNUSED idesc
= abuf
->idesc
;
3378 int UNUSED insn_referenced
= abuf
->written
;
3380 in_Rs
= FLD (in_Rs
);
3381 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 0;
3382 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
3386 int UNUSED insn_referenced
= abuf
->written
;
3390 in_Rd
= FLD (in_Rd
);
3391 in_Rs
= FLD (in_Rs
);
3392 referenced
|= 1 << 0;
3393 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 1;
3394 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
3398 int UNUSED insn_referenced
= abuf
->written
;
3399 cycles
+= crisv32f_model_crisv32_u_mem_w (current_cpu
, idesc
, 2, referenced
);
3406 model_crisv32_muls_b (SIM_CPU
*current_cpu
, void *sem_arg
)
3408 #define FLD(f) abuf->fields.sfmt_muls_b.f
3409 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
3410 const IDESC
* UNUSED idesc
= abuf
->idesc
;
3414 int UNUSED insn_referenced
= abuf
->written
;
3417 in_Rs
= FLD (in_Rs
);
3418 in_Rd
= FLD (in_Rd
);
3419 referenced
|= 1 << 0;
3420 referenced
|= 1 << 1;
3421 cycles
+= crisv32f_model_crisv32_u_multiply (current_cpu
, idesc
, 0, referenced
, in_Rs
, in_Rd
);
3425 int UNUSED insn_referenced
= abuf
->written
;
3429 in_Rd
= FLD (in_Rd
);
3430 in_Rs
= FLD (in_Rs
);
3431 out_Rd
= FLD (out_Rd
);
3432 referenced
|= 1 << 0;
3433 referenced
|= 1 << 1;
3434 referenced
|= 1 << 2;
3435 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
3442 model_crisv32_muls_w (SIM_CPU
*current_cpu
, void *sem_arg
)
3444 #define FLD(f) abuf->fields.sfmt_muls_b.f
3445 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
3446 const IDESC
* UNUSED idesc
= abuf
->idesc
;
3450 int UNUSED insn_referenced
= abuf
->written
;
3453 in_Rs
= FLD (in_Rs
);
3454 in_Rd
= FLD (in_Rd
);
3455 referenced
|= 1 << 0;
3456 referenced
|= 1 << 1;
3457 cycles
+= crisv32f_model_crisv32_u_multiply (current_cpu
, idesc
, 0, referenced
, in_Rs
, in_Rd
);
3461 int UNUSED insn_referenced
= abuf
->written
;
3465 in_Rd
= FLD (in_Rd
);
3466 in_Rs
= FLD (in_Rs
);
3467 out_Rd
= FLD (out_Rd
);
3468 referenced
|= 1 << 0;
3469 referenced
|= 1 << 1;
3470 referenced
|= 1 << 2;
3471 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
3478 model_crisv32_muls_d (SIM_CPU
*current_cpu
, void *sem_arg
)
3480 #define FLD(f) abuf->fields.sfmt_muls_b.f
3481 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
3482 const IDESC
* UNUSED idesc
= abuf
->idesc
;
3486 int UNUSED insn_referenced
= abuf
->written
;
3489 in_Rs
= FLD (in_Rs
);
3490 in_Rd
= FLD (in_Rd
);
3491 referenced
|= 1 << 0;
3492 referenced
|= 1 << 1;
3493 cycles
+= crisv32f_model_crisv32_u_multiply (current_cpu
, idesc
, 0, referenced
, in_Rs
, in_Rd
);
3497 int UNUSED insn_referenced
= abuf
->written
;
3501 in_Rd
= FLD (in_Rd
);
3502 in_Rs
= FLD (in_Rs
);
3503 out_Rd
= FLD (out_Rd
);
3504 referenced
|= 1 << 0;
3505 referenced
|= 1 << 1;
3506 referenced
|= 1 << 2;
3507 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
3514 model_crisv32_mulu_b (SIM_CPU
*current_cpu
, void *sem_arg
)
3516 #define FLD(f) abuf->fields.sfmt_muls_b.f
3517 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
3518 const IDESC
* UNUSED idesc
= abuf
->idesc
;
3522 int UNUSED insn_referenced
= abuf
->written
;
3525 in_Rs
= FLD (in_Rs
);
3526 in_Rd
= FLD (in_Rd
);
3527 referenced
|= 1 << 0;
3528 referenced
|= 1 << 1;
3529 cycles
+= crisv32f_model_crisv32_u_multiply (current_cpu
, idesc
, 0, referenced
, in_Rs
, in_Rd
);
3533 int UNUSED insn_referenced
= abuf
->written
;
3537 in_Rd
= FLD (in_Rd
);
3538 in_Rs
= FLD (in_Rs
);
3539 out_Rd
= FLD (out_Rd
);
3540 referenced
|= 1 << 0;
3541 referenced
|= 1 << 1;
3542 referenced
|= 1 << 2;
3543 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
3550 model_crisv32_mulu_w (SIM_CPU
*current_cpu
, void *sem_arg
)
3552 #define FLD(f) abuf->fields.sfmt_muls_b.f
3553 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
3554 const IDESC
* UNUSED idesc
= abuf
->idesc
;
3558 int UNUSED insn_referenced
= abuf
->written
;
3561 in_Rs
= FLD (in_Rs
);
3562 in_Rd
= FLD (in_Rd
);
3563 referenced
|= 1 << 0;
3564 referenced
|= 1 << 1;
3565 cycles
+= crisv32f_model_crisv32_u_multiply (current_cpu
, idesc
, 0, referenced
, in_Rs
, in_Rd
);
3569 int UNUSED insn_referenced
= abuf
->written
;
3573 in_Rd
= FLD (in_Rd
);
3574 in_Rs
= FLD (in_Rs
);
3575 out_Rd
= FLD (out_Rd
);
3576 referenced
|= 1 << 0;
3577 referenced
|= 1 << 1;
3578 referenced
|= 1 << 2;
3579 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
3586 model_crisv32_mulu_d (SIM_CPU
*current_cpu
, void *sem_arg
)
3588 #define FLD(f) abuf->fields.sfmt_muls_b.f
3589 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
3590 const IDESC
* UNUSED idesc
= abuf
->idesc
;
3594 int UNUSED insn_referenced
= abuf
->written
;
3597 in_Rs
= FLD (in_Rs
);
3598 in_Rd
= FLD (in_Rd
);
3599 referenced
|= 1 << 0;
3600 referenced
|= 1 << 1;
3601 cycles
+= crisv32f_model_crisv32_u_multiply (current_cpu
, idesc
, 0, referenced
, in_Rs
, in_Rd
);
3605 int UNUSED insn_referenced
= abuf
->written
;
3609 in_Rd
= FLD (in_Rd
);
3610 in_Rs
= FLD (in_Rs
);
3611 out_Rd
= FLD (out_Rd
);
3612 referenced
|= 1 << 0;
3613 referenced
|= 1 << 1;
3614 referenced
|= 1 << 2;
3615 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
3622 model_crisv32_mcp (SIM_CPU
*current_cpu
, void *sem_arg
)
3624 #define FLD(f) abuf->fields.sfmt_mcp.f
3625 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
3626 const IDESC
* UNUSED idesc
= abuf
->idesc
;
3630 int UNUSED insn_referenced
= abuf
->written
;
3634 in_Rs
= FLD (in_Rs
);
3635 referenced
|= 1 << 1;
3636 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
3643 model_crisv32_dstep (SIM_CPU
*current_cpu
, void *sem_arg
)
3645 #define FLD(f) abuf->fields.sfmt_muls_b.f
3646 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
3647 const IDESC
* UNUSED idesc
= abuf
->idesc
;
3651 int UNUSED insn_referenced
= abuf
->written
;
3655 in_Rd
= FLD (in_Rd
);
3656 in_Rs
= FLD (in_Rs
);
3657 out_Rd
= FLD (out_Rd
);
3658 referenced
|= 1 << 0;
3659 referenced
|= 1 << 1;
3660 referenced
|= 1 << 2;
3661 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
3668 model_crisv32_abs (SIM_CPU
*current_cpu
, void *sem_arg
)
3670 #define FLD(f) abuf->fields.sfmt_muls_b.f
3671 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
3672 const IDESC
* UNUSED idesc
= abuf
->idesc
;
3676 int UNUSED insn_referenced
= abuf
->written
;
3680 in_Rs
= FLD (in_Rs
);
3681 out_Rd
= FLD (out_Rd
);
3682 referenced
|= 1 << 1;
3683 referenced
|= 1 << 2;
3684 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
3691 model_crisv32_and_b_r (SIM_CPU
*current_cpu
, void *sem_arg
)
3693 #define FLD(f) abuf->fields.sfmt_addc_m.f
3694 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
3695 const IDESC
* UNUSED idesc
= abuf
->idesc
;
3699 int UNUSED insn_referenced
= abuf
->written
;
3703 in_Rd
= FLD (in_Rd
);
3704 in_Rs
= FLD (in_Rs
);
3705 referenced
|= 1 << 0;
3706 referenced
|= 1 << 1;
3707 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
3714 model_crisv32_and_w_r (SIM_CPU
*current_cpu
, void *sem_arg
)
3716 #define FLD(f) abuf->fields.sfmt_addc_m.f
3717 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
3718 const IDESC
* UNUSED idesc
= abuf
->idesc
;
3722 int UNUSED insn_referenced
= abuf
->written
;
3726 in_Rd
= FLD (in_Rd
);
3727 in_Rs
= FLD (in_Rs
);
3728 referenced
|= 1 << 0;
3729 referenced
|= 1 << 1;
3730 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
3737 model_crisv32_and_d_r (SIM_CPU
*current_cpu
, void *sem_arg
)
3739 #define FLD(f) abuf->fields.sfmt_addc_m.f
3740 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
3741 const IDESC
* UNUSED idesc
= abuf
->idesc
;
3745 int UNUSED insn_referenced
= abuf
->written
;
3749 in_Rd
= FLD (in_Rd
);
3750 in_Rs
= FLD (in_Rs
);
3751 referenced
|= 1 << 0;
3752 referenced
|= 1 << 1;
3753 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
3760 model_crisv32_and_m_b_m (SIM_CPU
*current_cpu
, void *sem_arg
)
3762 #define FLD(f) abuf->fields.sfmt_add_m_b_m.f
3763 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
3764 const IDESC
* UNUSED idesc
= abuf
->idesc
;
3768 int UNUSED insn_referenced
= abuf
->written
;
3770 in_Rs
= FLD (in_Rs
);
3771 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 0;
3772 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
3776 int UNUSED insn_referenced
= abuf
->written
;
3777 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
3781 int UNUSED insn_referenced
= abuf
->written
;
3785 in_Rd
= FLD (in_Rd
);
3786 in_Rs
= FLD (in_Rs
);
3787 referenced
|= 1 << 0;
3788 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 1;
3789 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
3796 model_crisv32_and_m_w_m (SIM_CPU
*current_cpu
, void *sem_arg
)
3798 #define FLD(f) abuf->fields.sfmt_add_m_b_m.f
3799 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
3800 const IDESC
* UNUSED idesc
= abuf
->idesc
;
3804 int UNUSED insn_referenced
= abuf
->written
;
3806 in_Rs
= FLD (in_Rs
);
3807 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 0;
3808 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
3812 int UNUSED insn_referenced
= abuf
->written
;
3813 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
3817 int UNUSED insn_referenced
= abuf
->written
;
3821 in_Rd
= FLD (in_Rd
);
3822 in_Rs
= FLD (in_Rs
);
3823 referenced
|= 1 << 0;
3824 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 1;
3825 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
3832 model_crisv32_and_m_d_m (SIM_CPU
*current_cpu
, void *sem_arg
)
3834 #define FLD(f) abuf->fields.sfmt_add_m_b_m.f
3835 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
3836 const IDESC
* UNUSED idesc
= abuf
->idesc
;
3840 int UNUSED insn_referenced
= abuf
->written
;
3842 in_Rs
= FLD (in_Rs
);
3843 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 0;
3844 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
3848 int UNUSED insn_referenced
= abuf
->written
;
3849 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
3853 int UNUSED insn_referenced
= abuf
->written
;
3857 in_Rd
= FLD (in_Rd
);
3858 in_Rs
= FLD (in_Rs
);
3859 referenced
|= 1 << 0;
3860 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 1;
3861 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
3868 model_crisv32_andcbr (SIM_CPU
*current_cpu
, void *sem_arg
)
3870 #define FLD(f) abuf->fields.sfmt_addcbr.f
3871 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
3872 const IDESC
* UNUSED idesc
= abuf
->idesc
;
3876 int UNUSED insn_referenced
= abuf
->written
;
3877 cycles
+= crisv32f_model_crisv32_u_const16 (current_cpu
, idesc
, 0, referenced
);
3881 int UNUSED insn_referenced
= abuf
->written
;
3885 in_Rd
= FLD (in_Rd
);
3886 referenced
|= 1 << 0;
3887 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
3894 model_crisv32_andcwr (SIM_CPU
*current_cpu
, void *sem_arg
)
3896 #define FLD(f) abuf->fields.sfmt_addcwr.f
3897 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
3898 const IDESC
* UNUSED idesc
= abuf
->idesc
;
3902 int UNUSED insn_referenced
= abuf
->written
;
3903 cycles
+= crisv32f_model_crisv32_u_const16 (current_cpu
, idesc
, 0, referenced
);
3907 int UNUSED insn_referenced
= abuf
->written
;
3911 in_Rd
= FLD (in_Rd
);
3912 referenced
|= 1 << 0;
3913 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
3920 model_crisv32_andcdr (SIM_CPU
*current_cpu
, void *sem_arg
)
3922 #define FLD(f) abuf->fields.sfmt_addcdr.f
3923 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
3924 const IDESC
* UNUSED idesc
= abuf
->idesc
;
3928 int UNUSED insn_referenced
= abuf
->written
;
3929 cycles
+= crisv32f_model_crisv32_u_const32 (current_cpu
, idesc
, 0, referenced
);
3933 int UNUSED insn_referenced
= abuf
->written
;
3937 in_Rd
= FLD (in_Rd
);
3938 referenced
|= 1 << 0;
3939 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
3946 model_crisv32_andq (SIM_CPU
*current_cpu
, void *sem_arg
)
3948 #define FLD(f) abuf->fields.sfmt_andq.f
3949 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
3950 const IDESC
* UNUSED idesc
= abuf
->idesc
;
3954 int UNUSED insn_referenced
= abuf
->written
;
3958 in_Rd
= FLD (in_Rd
);
3959 referenced
|= 1 << 0;
3960 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
3967 model_crisv32_orr_b_r (SIM_CPU
*current_cpu
, void *sem_arg
)
3969 #define FLD(f) abuf->fields.sfmt_addc_m.f
3970 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
3971 const IDESC
* UNUSED idesc
= abuf
->idesc
;
3975 int UNUSED insn_referenced
= abuf
->written
;
3979 in_Rd
= FLD (in_Rd
);
3980 in_Rs
= FLD (in_Rs
);
3981 referenced
|= 1 << 0;
3982 referenced
|= 1 << 1;
3983 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
3990 model_crisv32_orr_w_r (SIM_CPU
*current_cpu
, void *sem_arg
)
3992 #define FLD(f) abuf->fields.sfmt_addc_m.f
3993 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
3994 const IDESC
* UNUSED idesc
= abuf
->idesc
;
3998 int UNUSED insn_referenced
= abuf
->written
;
4002 in_Rd
= FLD (in_Rd
);
4003 in_Rs
= FLD (in_Rs
);
4004 referenced
|= 1 << 0;
4005 referenced
|= 1 << 1;
4006 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
4013 model_crisv32_orr_d_r (SIM_CPU
*current_cpu
, void *sem_arg
)
4015 #define FLD(f) abuf->fields.sfmt_addc_m.f
4016 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4017 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4021 int UNUSED insn_referenced
= abuf
->written
;
4025 in_Rd
= FLD (in_Rd
);
4026 in_Rs
= FLD (in_Rs
);
4027 referenced
|= 1 << 0;
4028 referenced
|= 1 << 1;
4029 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
4036 model_crisv32_or_m_b_m (SIM_CPU
*current_cpu
, void *sem_arg
)
4038 #define FLD(f) abuf->fields.sfmt_add_m_b_m.f
4039 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4040 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4044 int UNUSED insn_referenced
= abuf
->written
;
4046 in_Rs
= FLD (in_Rs
);
4047 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 0;
4048 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
4052 int UNUSED insn_referenced
= abuf
->written
;
4053 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
4057 int UNUSED insn_referenced
= abuf
->written
;
4061 in_Rd
= FLD (in_Rd
);
4062 in_Rs
= FLD (in_Rs
);
4063 referenced
|= 1 << 0;
4064 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 1;
4065 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
4072 model_crisv32_or_m_w_m (SIM_CPU
*current_cpu
, void *sem_arg
)
4074 #define FLD(f) abuf->fields.sfmt_add_m_b_m.f
4075 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4076 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4080 int UNUSED insn_referenced
= abuf
->written
;
4082 in_Rs
= FLD (in_Rs
);
4083 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 0;
4084 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
4088 int UNUSED insn_referenced
= abuf
->written
;
4089 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
4093 int UNUSED insn_referenced
= abuf
->written
;
4097 in_Rd
= FLD (in_Rd
);
4098 in_Rs
= FLD (in_Rs
);
4099 referenced
|= 1 << 0;
4100 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 1;
4101 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
4108 model_crisv32_or_m_d_m (SIM_CPU
*current_cpu
, void *sem_arg
)
4110 #define FLD(f) abuf->fields.sfmt_add_m_b_m.f
4111 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4112 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4116 int UNUSED insn_referenced
= abuf
->written
;
4118 in_Rs
= FLD (in_Rs
);
4119 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 0;
4120 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
4124 int UNUSED insn_referenced
= abuf
->written
;
4125 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
4129 int UNUSED insn_referenced
= abuf
->written
;
4133 in_Rd
= FLD (in_Rd
);
4134 in_Rs
= FLD (in_Rs
);
4135 referenced
|= 1 << 0;
4136 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 1;
4137 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
4144 model_crisv32_orcbr (SIM_CPU
*current_cpu
, void *sem_arg
)
4146 #define FLD(f) abuf->fields.sfmt_addcbr.f
4147 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4148 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4152 int UNUSED insn_referenced
= abuf
->written
;
4153 cycles
+= crisv32f_model_crisv32_u_const16 (current_cpu
, idesc
, 0, referenced
);
4157 int UNUSED insn_referenced
= abuf
->written
;
4161 in_Rd
= FLD (in_Rd
);
4162 referenced
|= 1 << 0;
4163 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
4170 model_crisv32_orcwr (SIM_CPU
*current_cpu
, void *sem_arg
)
4172 #define FLD(f) abuf->fields.sfmt_addcwr.f
4173 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4174 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4178 int UNUSED insn_referenced
= abuf
->written
;
4179 cycles
+= crisv32f_model_crisv32_u_const16 (current_cpu
, idesc
, 0, referenced
);
4183 int UNUSED insn_referenced
= abuf
->written
;
4187 in_Rd
= FLD (in_Rd
);
4188 referenced
|= 1 << 0;
4189 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
4196 model_crisv32_orcdr (SIM_CPU
*current_cpu
, void *sem_arg
)
4198 #define FLD(f) abuf->fields.sfmt_addcdr.f
4199 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4200 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4204 int UNUSED insn_referenced
= abuf
->written
;
4205 cycles
+= crisv32f_model_crisv32_u_const32 (current_cpu
, idesc
, 0, referenced
);
4209 int UNUSED insn_referenced
= abuf
->written
;
4213 in_Rd
= FLD (in_Rd
);
4214 referenced
|= 1 << 0;
4215 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
4222 model_crisv32_orq (SIM_CPU
*current_cpu
, void *sem_arg
)
4224 #define FLD(f) abuf->fields.sfmt_andq.f
4225 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4226 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4230 int UNUSED insn_referenced
= abuf
->written
;
4234 in_Rd
= FLD (in_Rd
);
4235 referenced
|= 1 << 0;
4236 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
4243 model_crisv32_xor (SIM_CPU
*current_cpu
, void *sem_arg
)
4245 #define FLD(f) abuf->fields.sfmt_muls_b.f
4246 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4247 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4251 int UNUSED insn_referenced
= abuf
->written
;
4255 in_Rd
= FLD (in_Rd
);
4256 in_Rs
= FLD (in_Rs
);
4257 out_Rd
= FLD (out_Rd
);
4258 referenced
|= 1 << 0;
4259 referenced
|= 1 << 1;
4260 referenced
|= 1 << 2;
4261 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
4268 model_crisv32_swap (SIM_CPU
*current_cpu
, void *sem_arg
)
4270 #define FLD(f) abuf->fields.sfmt_move_spr_mv32.f
4271 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4272 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4276 int UNUSED insn_referenced
= abuf
->written
;
4280 in_Rs
= FLD (in_Rs
);
4281 referenced
|= 1 << 1;
4282 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
4289 model_crisv32_asrr_b_r (SIM_CPU
*current_cpu
, void *sem_arg
)
4291 #define FLD(f) abuf->fields.sfmt_addc_m.f
4292 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4293 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4297 int UNUSED insn_referenced
= abuf
->written
;
4301 in_Rd
= FLD (in_Rd
);
4302 in_Rs
= FLD (in_Rs
);
4303 referenced
|= 1 << 0;
4304 referenced
|= 1 << 1;
4305 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
4312 model_crisv32_asrr_w_r (SIM_CPU
*current_cpu
, void *sem_arg
)
4314 #define FLD(f) abuf->fields.sfmt_addc_m.f
4315 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4316 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4320 int UNUSED insn_referenced
= abuf
->written
;
4324 in_Rd
= FLD (in_Rd
);
4325 in_Rs
= FLD (in_Rs
);
4326 referenced
|= 1 << 0;
4327 referenced
|= 1 << 1;
4328 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
4335 model_crisv32_asrr_d_r (SIM_CPU
*current_cpu
, void *sem_arg
)
4337 #define FLD(f) abuf->fields.sfmt_addc_m.f
4338 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4339 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4343 int UNUSED insn_referenced
= abuf
->written
;
4347 in_Rd
= FLD (in_Rd
);
4348 in_Rs
= FLD (in_Rs
);
4349 referenced
|= 1 << 0;
4350 referenced
|= 1 << 1;
4351 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
4358 model_crisv32_asrq (SIM_CPU
*current_cpu
, void *sem_arg
)
4360 #define FLD(f) abuf->fields.sfmt_asrq.f
4361 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4362 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4366 int UNUSED insn_referenced
= abuf
->written
;
4370 in_Rd
= FLD (in_Rd
);
4371 out_Rd
= FLD (out_Rd
);
4372 referenced
|= 1 << 0;
4373 referenced
|= 1 << 2;
4374 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
4381 model_crisv32_lsrr_b_r (SIM_CPU
*current_cpu
, void *sem_arg
)
4383 #define FLD(f) abuf->fields.sfmt_addc_m.f
4384 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4385 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4389 int UNUSED insn_referenced
= abuf
->written
;
4393 in_Rd
= FLD (in_Rd
);
4394 in_Rs
= FLD (in_Rs
);
4395 if (insn_referenced
& (1 << 0)) referenced
|= 1 << 0;
4396 referenced
|= 1 << 1;
4397 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
4404 model_crisv32_lsrr_w_r (SIM_CPU
*current_cpu
, void *sem_arg
)
4406 #define FLD(f) abuf->fields.sfmt_addc_m.f
4407 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4408 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4412 int UNUSED insn_referenced
= abuf
->written
;
4416 in_Rd
= FLD (in_Rd
);
4417 in_Rs
= FLD (in_Rs
);
4418 if (insn_referenced
& (1 << 0)) referenced
|= 1 << 0;
4419 referenced
|= 1 << 1;
4420 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
4427 model_crisv32_lsrr_d_r (SIM_CPU
*current_cpu
, void *sem_arg
)
4429 #define FLD(f) abuf->fields.sfmt_addc_m.f
4430 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4431 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4435 int UNUSED insn_referenced
= abuf
->written
;
4439 in_Rd
= FLD (in_Rd
);
4440 in_Rs
= FLD (in_Rs
);
4441 if (insn_referenced
& (1 << 0)) referenced
|= 1 << 0;
4442 referenced
|= 1 << 1;
4443 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
4450 model_crisv32_lsrq (SIM_CPU
*current_cpu
, void *sem_arg
)
4452 #define FLD(f) abuf->fields.sfmt_asrq.f
4453 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4454 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4458 int UNUSED insn_referenced
= abuf
->written
;
4462 in_Rd
= FLD (in_Rd
);
4463 out_Rd
= FLD (out_Rd
);
4464 referenced
|= 1 << 0;
4465 referenced
|= 1 << 2;
4466 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
4473 model_crisv32_lslr_b_r (SIM_CPU
*current_cpu
, void *sem_arg
)
4475 #define FLD(f) abuf->fields.sfmt_addc_m.f
4476 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4477 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4481 int UNUSED insn_referenced
= abuf
->written
;
4485 in_Rd
= FLD (in_Rd
);
4486 in_Rs
= FLD (in_Rs
);
4487 if (insn_referenced
& (1 << 0)) referenced
|= 1 << 0;
4488 referenced
|= 1 << 1;
4489 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
4496 model_crisv32_lslr_w_r (SIM_CPU
*current_cpu
, void *sem_arg
)
4498 #define FLD(f) abuf->fields.sfmt_addc_m.f
4499 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4500 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4504 int UNUSED insn_referenced
= abuf
->written
;
4508 in_Rd
= FLD (in_Rd
);
4509 in_Rs
= FLD (in_Rs
);
4510 if (insn_referenced
& (1 << 0)) referenced
|= 1 << 0;
4511 referenced
|= 1 << 1;
4512 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
4519 model_crisv32_lslr_d_r (SIM_CPU
*current_cpu
, void *sem_arg
)
4521 #define FLD(f) abuf->fields.sfmt_addc_m.f
4522 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4523 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4527 int UNUSED insn_referenced
= abuf
->written
;
4531 in_Rd
= FLD (in_Rd
);
4532 in_Rs
= FLD (in_Rs
);
4533 if (insn_referenced
& (1 << 0)) referenced
|= 1 << 0;
4534 referenced
|= 1 << 1;
4535 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
4542 model_crisv32_lslq (SIM_CPU
*current_cpu
, void *sem_arg
)
4544 #define FLD(f) abuf->fields.sfmt_asrq.f
4545 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4546 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4550 int UNUSED insn_referenced
= abuf
->written
;
4554 in_Rd
= FLD (in_Rd
);
4555 out_Rd
= FLD (out_Rd
);
4556 referenced
|= 1 << 0;
4557 referenced
|= 1 << 2;
4558 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
4565 model_crisv32_btst (SIM_CPU
*current_cpu
, void *sem_arg
)
4567 #define FLD(f) abuf->fields.sfmt_muls_b.f
4568 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4569 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4573 int UNUSED insn_referenced
= abuf
->written
;
4577 in_Rd
= FLD (in_Rd
);
4578 in_Rs
= FLD (in_Rs
);
4579 referenced
|= 1 << 0;
4580 referenced
|= 1 << 1;
4581 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
4588 model_crisv32_btstq (SIM_CPU
*current_cpu
, void *sem_arg
)
4590 #define FLD(f) abuf->fields.sfmt_asrq.f
4591 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4592 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4596 int UNUSED insn_referenced
= abuf
->written
;
4600 in_Rd
= FLD (in_Rd
);
4601 referenced
|= 1 << 0;
4602 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
4609 model_crisv32_setf (SIM_CPU
*current_cpu
, void *sem_arg
)
4611 #define FLD(f) abuf->fields.sfmt_setf.f
4612 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4613 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4617 int UNUSED insn_referenced
= abuf
->written
;
4621 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
4628 model_crisv32_clearf (SIM_CPU
*current_cpu
, void *sem_arg
)
4630 #define FLD(f) abuf->fields.sfmt_setf.f
4631 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4632 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4636 int UNUSED insn_referenced
= abuf
->written
;
4640 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
4647 model_crisv32_rfe (SIM_CPU
*current_cpu
, void *sem_arg
)
4649 #define FLD(f) abuf->fields.sfmt_rfe.f
4650 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4651 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4655 int UNUSED insn_referenced
= abuf
->written
;
4659 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
4666 model_crisv32_sfe (SIM_CPU
*current_cpu
, void *sem_arg
)
4668 #define FLD(f) abuf->fields.sfmt_rfe.f
4669 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4670 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4674 int UNUSED insn_referenced
= abuf
->written
;
4678 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
4685 model_crisv32_rfg (SIM_CPU
*current_cpu
, void *sem_arg
)
4687 #define FLD(f) abuf->fields.fmt_empty.f
4688 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4689 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4693 int UNUSED insn_referenced
= abuf
->written
;
4697 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
4704 model_crisv32_rfn (SIM_CPU
*current_cpu
, void *sem_arg
)
4706 #define FLD(f) abuf->fields.sfmt_rfe.f
4707 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4708 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4712 int UNUSED insn_referenced
= abuf
->written
;
4716 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
4723 model_crisv32_halt (SIM_CPU
*current_cpu
, void *sem_arg
)
4725 #define FLD(f) abuf->fields.fmt_empty.f
4726 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4727 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4731 int UNUSED insn_referenced
= abuf
->written
;
4735 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
4742 model_crisv32_bcc_b (SIM_CPU
*current_cpu
, void *sem_arg
)
4744 #define FLD(f) abuf->fields.sfmt_bcc_b.f
4745 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4746 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4750 int UNUSED insn_referenced
= abuf
->written
;
4751 cycles
+= crisv32f_model_crisv32_u_branch (current_cpu
, idesc
, 0, referenced
);
4755 int UNUSED insn_referenced
= abuf
->written
;
4759 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
4766 model_crisv32_ba_b (SIM_CPU
*current_cpu
, void *sem_arg
)
4768 #define FLD(f) abuf->fields.sfmt_bcc_b.f
4769 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4770 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4774 int UNUSED insn_referenced
= abuf
->written
;
4776 cycles
+= crisv32f_model_crisv32_u_jump (current_cpu
, idesc
, 0, referenced
, out_Pd
);
4780 int UNUSED insn_referenced
= abuf
->written
;
4784 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
4791 model_crisv32_bcc_w (SIM_CPU
*current_cpu
, void *sem_arg
)
4793 #define FLD(f) abuf->fields.sfmt_bcc_w.f
4794 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4795 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4799 int UNUSED insn_referenced
= abuf
->written
;
4800 cycles
+= crisv32f_model_crisv32_u_const16 (current_cpu
, idesc
, 0, referenced
);
4804 int UNUSED insn_referenced
= abuf
->written
;
4805 cycles
+= crisv32f_model_crisv32_u_branch (current_cpu
, idesc
, 1, referenced
);
4809 int UNUSED insn_referenced
= abuf
->written
;
4813 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
4820 model_crisv32_ba_w (SIM_CPU
*current_cpu
, void *sem_arg
)
4822 #define FLD(f) abuf->fields.sfmt_bcc_w.f
4823 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4824 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4828 int UNUSED insn_referenced
= abuf
->written
;
4829 cycles
+= crisv32f_model_crisv32_u_const16 (current_cpu
, idesc
, 0, referenced
);
4833 int UNUSED insn_referenced
= abuf
->written
;
4835 cycles
+= crisv32f_model_crisv32_u_jump (current_cpu
, idesc
, 1, referenced
, out_Pd
);
4839 int UNUSED insn_referenced
= abuf
->written
;
4843 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
4850 model_crisv32_jas_r (SIM_CPU
*current_cpu
, void *sem_arg
)
4852 #define FLD(f) abuf->fields.sfmt_move_m_sprv32.f
4853 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4854 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4858 int UNUSED insn_referenced
= abuf
->written
;
4860 in_Rs
= FLD (in_Rs
);
4861 referenced
|= 1 << 0;
4862 cycles
+= crisv32f_model_crisv32_u_jump_r (current_cpu
, idesc
, 0, referenced
, in_Rs
);
4866 int UNUSED insn_referenced
= abuf
->written
;
4868 out_Pd
= FLD (out_Pd
);
4869 referenced
|= 1 << 0;
4870 cycles
+= crisv32f_model_crisv32_u_jump (current_cpu
, idesc
, 1, referenced
, out_Pd
);
4874 int UNUSED insn_referenced
= abuf
->written
;
4878 in_Rs
= FLD (in_Rs
);
4879 referenced
|= 1 << 1;
4880 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
4887 model_crisv32_jas_c (SIM_CPU
*current_cpu
, void *sem_arg
)
4889 #define FLD(f) abuf->fields.sfmt_move_c_sprv32_p2.f
4890 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4891 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4895 int UNUSED insn_referenced
= abuf
->written
;
4896 cycles
+= crisv32f_model_crisv32_u_const32 (current_cpu
, idesc
, 0, referenced
);
4900 int UNUSED insn_referenced
= abuf
->written
;
4902 out_Pd
= FLD (out_Pd
);
4903 referenced
|= 1 << 0;
4904 cycles
+= crisv32f_model_crisv32_u_jump (current_cpu
, idesc
, 1, referenced
, out_Pd
);
4908 int UNUSED insn_referenced
= abuf
->written
;
4912 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
4919 model_crisv32_jump_p (SIM_CPU
*current_cpu
, void *sem_arg
)
4921 #define FLD(f) abuf->fields.sfmt_mcp.f
4922 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4923 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4927 int UNUSED insn_referenced
= abuf
->written
;
4929 in_Ps
= FLD (in_Ps
);
4930 referenced
|= 1 << 0;
4931 cycles
+= crisv32f_model_crisv32_u_jump_sr (current_cpu
, idesc
, 0, referenced
, in_Ps
);
4935 int UNUSED insn_referenced
= abuf
->written
;
4939 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
4946 model_crisv32_bas_c (SIM_CPU
*current_cpu
, void *sem_arg
)
4948 #define FLD(f) abuf->fields.sfmt_bas_c.f
4949 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4950 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4954 int UNUSED insn_referenced
= abuf
->written
;
4955 cycles
+= crisv32f_model_crisv32_u_const32 (current_cpu
, idesc
, 0, referenced
);
4959 int UNUSED insn_referenced
= abuf
->written
;
4961 out_Pd
= FLD (out_Pd
);
4962 referenced
|= 1 << 0;
4963 cycles
+= crisv32f_model_crisv32_u_jump (current_cpu
, idesc
, 1, referenced
, out_Pd
);
4967 int UNUSED insn_referenced
= abuf
->written
;
4971 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
4978 model_crisv32_jasc_r (SIM_CPU
*current_cpu
, void *sem_arg
)
4980 #define FLD(f) abuf->fields.sfmt_move_m_sprv32.f
4981 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
4982 const IDESC
* UNUSED idesc
= abuf
->idesc
;
4986 int UNUSED insn_referenced
= abuf
->written
;
4988 in_Rs
= FLD (in_Rs
);
4989 referenced
|= 1 << 0;
4990 cycles
+= crisv32f_model_crisv32_u_jump_r (current_cpu
, idesc
, 0, referenced
, in_Rs
);
4994 int UNUSED insn_referenced
= abuf
->written
;
4995 cycles
+= crisv32f_model_crisv32_u_skip4 (current_cpu
, idesc
, 1, referenced
);
4999 int UNUSED insn_referenced
= abuf
->written
;
5001 out_Pd
= FLD (out_Pd
);
5002 referenced
|= 1 << 0;
5003 cycles
+= crisv32f_model_crisv32_u_jump (current_cpu
, idesc
, 2, referenced
, out_Pd
);
5007 int UNUSED insn_referenced
= abuf
->written
;
5011 in_Rs
= FLD (in_Rs
);
5012 referenced
|= 1 << 1;
5013 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 3, referenced
, in_Rd
, in_Rs
, out_Rd
);
5020 model_crisv32_jasc_c (SIM_CPU
*current_cpu
, void *sem_arg
)
5022 #define FLD(f) abuf->fields.sfmt_move_c_sprv32_p2.f
5023 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
5024 const IDESC
* UNUSED idesc
= abuf
->idesc
;
5028 int UNUSED insn_referenced
= abuf
->written
;
5029 cycles
+= crisv32f_model_crisv32_u_const32 (current_cpu
, idesc
, 0, referenced
);
5033 int UNUSED insn_referenced
= abuf
->written
;
5034 cycles
+= crisv32f_model_crisv32_u_skip4 (current_cpu
, idesc
, 1, referenced
);
5038 int UNUSED insn_referenced
= abuf
->written
;
5040 out_Pd
= FLD (out_Pd
);
5041 referenced
|= 1 << 0;
5042 cycles
+= crisv32f_model_crisv32_u_jump (current_cpu
, idesc
, 2, referenced
, out_Pd
);
5046 int UNUSED insn_referenced
= abuf
->written
;
5050 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 3, referenced
, in_Rd
, in_Rs
, out_Rd
);
5057 model_crisv32_basc_c (SIM_CPU
*current_cpu
, void *sem_arg
)
5059 #define FLD(f) abuf->fields.sfmt_bas_c.f
5060 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
5061 const IDESC
* UNUSED idesc
= abuf
->idesc
;
5065 int UNUSED insn_referenced
= abuf
->written
;
5066 cycles
+= crisv32f_model_crisv32_u_const32 (current_cpu
, idesc
, 0, referenced
);
5070 int UNUSED insn_referenced
= abuf
->written
;
5071 cycles
+= crisv32f_model_crisv32_u_skip4 (current_cpu
, idesc
, 1, referenced
);
5075 int UNUSED insn_referenced
= abuf
->written
;
5077 out_Pd
= FLD (out_Pd
);
5078 referenced
|= 1 << 0;
5079 cycles
+= crisv32f_model_crisv32_u_jump (current_cpu
, idesc
, 2, referenced
, out_Pd
);
5083 int UNUSED insn_referenced
= abuf
->written
;
5087 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 3, referenced
, in_Rd
, in_Rs
, out_Rd
);
5094 model_crisv32_break (SIM_CPU
*current_cpu
, void *sem_arg
)
5096 #define FLD(f) abuf->fields.sfmt_break.f
5097 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
5098 const IDESC
* UNUSED idesc
= abuf
->idesc
;
5102 int UNUSED insn_referenced
= abuf
->written
;
5106 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
5113 model_crisv32_bound_r_b_r (SIM_CPU
*current_cpu
, void *sem_arg
)
5115 #define FLD(f) abuf->fields.sfmt_muls_b.f
5116 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
5117 const IDESC
* UNUSED idesc
= abuf
->idesc
;
5121 int UNUSED insn_referenced
= abuf
->written
;
5125 in_Rd
= FLD (in_Rd
);
5126 in_Rs
= FLD (in_Rs
);
5127 out_Rd
= FLD (out_Rd
);
5128 referenced
|= 1 << 0;
5129 referenced
|= 1 << 1;
5130 referenced
|= 1 << 2;
5131 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
5138 model_crisv32_bound_r_w_r (SIM_CPU
*current_cpu
, void *sem_arg
)
5140 #define FLD(f) abuf->fields.sfmt_muls_b.f
5141 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
5142 const IDESC
* UNUSED idesc
= abuf
->idesc
;
5146 int UNUSED insn_referenced
= abuf
->written
;
5150 in_Rd
= FLD (in_Rd
);
5151 in_Rs
= FLD (in_Rs
);
5152 out_Rd
= FLD (out_Rd
);
5153 referenced
|= 1 << 0;
5154 referenced
|= 1 << 1;
5155 referenced
|= 1 << 2;
5156 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
5163 model_crisv32_bound_r_d_r (SIM_CPU
*current_cpu
, void *sem_arg
)
5165 #define FLD(f) abuf->fields.sfmt_muls_b.f
5166 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
5167 const IDESC
* UNUSED idesc
= abuf
->idesc
;
5171 int UNUSED insn_referenced
= abuf
->written
;
5175 in_Rd
= FLD (in_Rd
);
5176 in_Rs
= FLD (in_Rs
);
5177 out_Rd
= FLD (out_Rd
);
5178 referenced
|= 1 << 0;
5179 referenced
|= 1 << 1;
5180 referenced
|= 1 << 2;
5181 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
5188 model_crisv32_bound_cb (SIM_CPU
*current_cpu
, void *sem_arg
)
5190 #define FLD(f) abuf->fields.sfmt_bound_cb.f
5191 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
5192 const IDESC
* UNUSED idesc
= abuf
->idesc
;
5196 int UNUSED insn_referenced
= abuf
->written
;
5197 cycles
+= crisv32f_model_crisv32_u_const16 (current_cpu
, idesc
, 0, referenced
);
5201 int UNUSED insn_referenced
= abuf
->written
;
5205 in_Rd
= FLD (in_Rd
);
5206 out_Rd
= FLD (out_Rd
);
5207 referenced
|= 1 << 0;
5208 referenced
|= 1 << 2;
5209 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
5216 model_crisv32_bound_cw (SIM_CPU
*current_cpu
, void *sem_arg
)
5218 #define FLD(f) abuf->fields.sfmt_bound_cw.f
5219 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
5220 const IDESC
* UNUSED idesc
= abuf
->idesc
;
5224 int UNUSED insn_referenced
= abuf
->written
;
5225 cycles
+= crisv32f_model_crisv32_u_const16 (current_cpu
, idesc
, 0, referenced
);
5229 int UNUSED insn_referenced
= abuf
->written
;
5233 in_Rd
= FLD (in_Rd
);
5234 out_Rd
= FLD (out_Rd
);
5235 referenced
|= 1 << 0;
5236 referenced
|= 1 << 2;
5237 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
5244 model_crisv32_bound_cd (SIM_CPU
*current_cpu
, void *sem_arg
)
5246 #define FLD(f) abuf->fields.sfmt_bound_cd.f
5247 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
5248 const IDESC
* UNUSED idesc
= abuf
->idesc
;
5252 int UNUSED insn_referenced
= abuf
->written
;
5253 cycles
+= crisv32f_model_crisv32_u_const32 (current_cpu
, idesc
, 0, referenced
);
5257 int UNUSED insn_referenced
= abuf
->written
;
5261 in_Rd
= FLD (in_Rd
);
5262 out_Rd
= FLD (out_Rd
);
5263 referenced
|= 1 << 0;
5264 referenced
|= 1 << 2;
5265 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
5272 model_crisv32_scc (SIM_CPU
*current_cpu
, void *sem_arg
)
5274 #define FLD(f) abuf->fields.sfmt_move_spr_mv32.f
5275 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
5276 const IDESC
* UNUSED idesc
= abuf
->idesc
;
5280 int UNUSED insn_referenced
= abuf
->written
;
5284 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
5291 model_crisv32_lz (SIM_CPU
*current_cpu
, void *sem_arg
)
5293 #define FLD(f) abuf->fields.sfmt_muls_b.f
5294 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
5295 const IDESC
* UNUSED idesc
= abuf
->idesc
;
5299 int UNUSED insn_referenced
= abuf
->written
;
5303 in_Rs
= FLD (in_Rs
);
5304 out_Rd
= FLD (out_Rd
);
5305 referenced
|= 1 << 1;
5306 referenced
|= 1 << 2;
5307 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
5314 model_crisv32_addoq (SIM_CPU
*current_cpu
, void *sem_arg
)
5316 #define FLD(f) abuf->fields.sfmt_addoq.f
5317 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
5318 const IDESC
* UNUSED idesc
= abuf
->idesc
;
5322 int UNUSED insn_referenced
= abuf
->written
;
5326 in_Rd
= FLD (in_Rd
);
5327 referenced
|= 1 << 0;
5328 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
5335 model_crisv32_addo_m_b_m (SIM_CPU
*current_cpu
, void *sem_arg
)
5337 #define FLD(f) abuf->fields.sfmt_addc_m.f
5338 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
5339 const IDESC
* UNUSED idesc
= abuf
->idesc
;
5343 int UNUSED insn_referenced
= abuf
->written
;
5345 in_Rs
= FLD (in_Rs
);
5346 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 0;
5347 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
5351 int UNUSED insn_referenced
= abuf
->written
;
5352 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
5356 int UNUSED insn_referenced
= abuf
->written
;
5360 in_Rd
= FLD (in_Rd
);
5361 in_Rs
= FLD (in_Rs
);
5362 referenced
|= 1 << 0;
5363 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 1;
5364 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
5371 model_crisv32_addo_m_w_m (SIM_CPU
*current_cpu
, void *sem_arg
)
5373 #define FLD(f) abuf->fields.sfmt_addc_m.f
5374 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
5375 const IDESC
* UNUSED idesc
= abuf
->idesc
;
5379 int UNUSED insn_referenced
= abuf
->written
;
5381 in_Rs
= FLD (in_Rs
);
5382 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 0;
5383 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
5387 int UNUSED insn_referenced
= abuf
->written
;
5388 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
5392 int UNUSED insn_referenced
= abuf
->written
;
5396 in_Rd
= FLD (in_Rd
);
5397 in_Rs
= FLD (in_Rs
);
5398 referenced
|= 1 << 0;
5399 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 1;
5400 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
5407 model_crisv32_addo_m_d_m (SIM_CPU
*current_cpu
, void *sem_arg
)
5409 #define FLD(f) abuf->fields.sfmt_addc_m.f
5410 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
5411 const IDESC
* UNUSED idesc
= abuf
->idesc
;
5415 int UNUSED insn_referenced
= abuf
->written
;
5417 in_Rs
= FLD (in_Rs
);
5418 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 0;
5419 cycles
+= crisv32f_model_crisv32_u_mem (current_cpu
, idesc
, 0, referenced
, in_Rs
);
5423 int UNUSED insn_referenced
= abuf
->written
;
5424 cycles
+= crisv32f_model_crisv32_u_mem_r (current_cpu
, idesc
, 1, referenced
);
5428 int UNUSED insn_referenced
= abuf
->written
;
5432 in_Rd
= FLD (in_Rd
);
5433 in_Rs
= FLD (in_Rs
);
5434 referenced
|= 1 << 0;
5435 if (insn_referenced
& (1 << 1)) referenced
|= 1 << 1;
5436 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 2, referenced
, in_Rd
, in_Rs
, out_Rd
);
5443 model_crisv32_addo_cb (SIM_CPU
*current_cpu
, void *sem_arg
)
5445 #define FLD(f) abuf->fields.sfmt_bound_cb.f
5446 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
5447 const IDESC
* UNUSED idesc
= abuf
->idesc
;
5451 int UNUSED insn_referenced
= abuf
->written
;
5452 cycles
+= crisv32f_model_crisv32_u_const16 (current_cpu
, idesc
, 0, referenced
);
5456 int UNUSED insn_referenced
= abuf
->written
;
5460 in_Rd
= FLD (in_Rd
);
5461 referenced
|= 1 << 0;
5462 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
5469 model_crisv32_addo_cw (SIM_CPU
*current_cpu
, void *sem_arg
)
5471 #define FLD(f) abuf->fields.sfmt_bound_cw.f
5472 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
5473 const IDESC
* UNUSED idesc
= abuf
->idesc
;
5477 int UNUSED insn_referenced
= abuf
->written
;
5478 cycles
+= crisv32f_model_crisv32_u_const16 (current_cpu
, idesc
, 0, referenced
);
5482 int UNUSED insn_referenced
= abuf
->written
;
5486 in_Rd
= FLD (in_Rd
);
5487 referenced
|= 1 << 0;
5488 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
5495 model_crisv32_addo_cd (SIM_CPU
*current_cpu
, void *sem_arg
)
5497 #define FLD(f) abuf->fields.sfmt_bound_cd.f
5498 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
5499 const IDESC
* UNUSED idesc
= abuf
->idesc
;
5503 int UNUSED insn_referenced
= abuf
->written
;
5504 cycles
+= crisv32f_model_crisv32_u_const32 (current_cpu
, idesc
, 0, referenced
);
5508 int UNUSED insn_referenced
= abuf
->written
;
5512 in_Rd
= FLD (in_Rd
);
5513 referenced
|= 1 << 0;
5514 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 1, referenced
, in_Rd
, in_Rs
, out_Rd
);
5521 model_crisv32_addi_acr_b_r (SIM_CPU
*current_cpu
, void *sem_arg
)
5523 #define FLD(f) abuf->fields.sfmt_muls_b.f
5524 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
5525 const IDESC
* UNUSED idesc
= abuf
->idesc
;
5529 int UNUSED insn_referenced
= abuf
->written
;
5533 in_Rd
= FLD (in_Rd
);
5534 in_Rs
= FLD (in_Rs
);
5535 referenced
|= 1 << 0;
5536 referenced
|= 1 << 1;
5537 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
5544 model_crisv32_addi_acr_w_r (SIM_CPU
*current_cpu
, void *sem_arg
)
5546 #define FLD(f) abuf->fields.sfmt_muls_b.f
5547 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
5548 const IDESC
* UNUSED idesc
= abuf
->idesc
;
5552 int UNUSED insn_referenced
= abuf
->written
;
5556 in_Rd
= FLD (in_Rd
);
5557 in_Rs
= FLD (in_Rs
);
5558 referenced
|= 1 << 0;
5559 referenced
|= 1 << 1;
5560 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
5567 model_crisv32_addi_acr_d_r (SIM_CPU
*current_cpu
, void *sem_arg
)
5569 #define FLD(f) abuf->fields.sfmt_muls_b.f
5570 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
5571 const IDESC
* UNUSED idesc
= abuf
->idesc
;
5575 int UNUSED insn_referenced
= abuf
->written
;
5579 in_Rd
= FLD (in_Rd
);
5580 in_Rs
= FLD (in_Rs
);
5581 referenced
|= 1 << 0;
5582 referenced
|= 1 << 1;
5583 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
5590 model_crisv32_fidxi (SIM_CPU
*current_cpu
, void *sem_arg
)
5592 #define FLD(f) abuf->fields.sfmt_mcp.f
5593 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
5594 const IDESC
* UNUSED idesc
= abuf
->idesc
;
5598 int UNUSED insn_referenced
= abuf
->written
;
5602 in_Rs
= FLD (in_Rs
);
5603 referenced
|= 1 << 1;
5604 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
5611 model_crisv32_ftagi (SIM_CPU
*current_cpu
, void *sem_arg
)
5613 #define FLD(f) abuf->fields.sfmt_mcp.f
5614 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
5615 const IDESC
* UNUSED idesc
= abuf
->idesc
;
5619 int UNUSED insn_referenced
= abuf
->written
;
5623 in_Rs
= FLD (in_Rs
);
5624 referenced
|= 1 << 1;
5625 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
5632 model_crisv32_fidxd (SIM_CPU
*current_cpu
, void *sem_arg
)
5634 #define FLD(f) abuf->fields.sfmt_mcp.f
5635 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
5636 const IDESC
* UNUSED idesc
= abuf
->idesc
;
5640 int UNUSED insn_referenced
= abuf
->written
;
5644 in_Rs
= FLD (in_Rs
);
5645 referenced
|= 1 << 1;
5646 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
5653 model_crisv32_ftagd (SIM_CPU
*current_cpu
, void *sem_arg
)
5655 #define FLD(f) abuf->fields.sfmt_mcp.f
5656 const ARGBUF
* UNUSED abuf
= SEM_ARGBUF ((SEM_ARG
) sem_arg
);
5657 const IDESC
* UNUSED idesc
= abuf
->idesc
;
5661 int UNUSED insn_referenced
= abuf
->written
;
5665 in_Rs
= FLD (in_Rs
);
5666 referenced
|= 1 << 1;
5667 cycles
+= crisv32f_model_crisv32_u_exec (current_cpu
, idesc
, 0, referenced
, in_Rd
, in_Rs
, out_Rd
);
5673 /* We assume UNIT_NONE == 0 because the tables don't always terminate
5676 /* Model timing data for `crisv32'. */
5678 static const INSN_TIMING crisv32_timing
[] = {
5679 { CRISV32F_INSN_X_INVALID
, 0, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5680 { CRISV32F_INSN_X_AFTER
, 0, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5681 { CRISV32F_INSN_X_BEFORE
, 0, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5682 { CRISV32F_INSN_X_CTI_CHAIN
, 0, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5683 { CRISV32F_INSN_X_CHAIN
, 0, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5684 { CRISV32F_INSN_X_BEGIN
, 0, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5685 { CRISV32F_INSN_MOVE_B_R
, model_crisv32_move_b_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5686 { CRISV32F_INSN_MOVE_W_R
, model_crisv32_move_w_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5687 { CRISV32F_INSN_MOVE_D_R
, model_crisv32_move_d_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5688 { CRISV32F_INSN_MOVEQ
, model_crisv32_moveq
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5689 { CRISV32F_INSN_MOVS_B_R
, model_crisv32_movs_b_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5690 { CRISV32F_INSN_MOVS_W_R
, model_crisv32_movs_w_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5691 { CRISV32F_INSN_MOVU_B_R
, model_crisv32_movu_b_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5692 { CRISV32F_INSN_MOVU_W_R
, model_crisv32_movu_w_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5693 { CRISV32F_INSN_MOVECBR
, model_crisv32_movecbr
, { { (int) UNIT_CRISV32_U_CONST16
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5694 { CRISV32F_INSN_MOVECWR
, model_crisv32_movecwr
, { { (int) UNIT_CRISV32_U_CONST16
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5695 { CRISV32F_INSN_MOVECDR
, model_crisv32_movecdr
, { { (int) UNIT_CRISV32_U_CONST32
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5696 { CRISV32F_INSN_MOVSCBR
, model_crisv32_movscbr
, { { (int) UNIT_CRISV32_U_CONST16
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5697 { CRISV32F_INSN_MOVSCWR
, model_crisv32_movscwr
, { { (int) UNIT_CRISV32_U_CONST16
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5698 { CRISV32F_INSN_MOVUCBR
, model_crisv32_movucbr
, { { (int) UNIT_CRISV32_U_CONST16
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5699 { CRISV32F_INSN_MOVUCWR
, model_crisv32_movucwr
, { { (int) UNIT_CRISV32_U_CONST16
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5700 { CRISV32F_INSN_ADDQ
, model_crisv32_addq
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5701 { CRISV32F_INSN_SUBQ
, model_crisv32_subq
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5702 { CRISV32F_INSN_CMP_R_B_R
, model_crisv32_cmp_r_b_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5703 { CRISV32F_INSN_CMP_R_W_R
, model_crisv32_cmp_r_w_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5704 { CRISV32F_INSN_CMP_R_D_R
, model_crisv32_cmp_r_d_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5705 { CRISV32F_INSN_CMP_M_B_M
, model_crisv32_cmp_m_b_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5706 { CRISV32F_INSN_CMP_M_W_M
, model_crisv32_cmp_m_w_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5707 { CRISV32F_INSN_CMP_M_D_M
, model_crisv32_cmp_m_d_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5708 { CRISV32F_INSN_CMPCBR
, model_crisv32_cmpcbr
, { { (int) UNIT_CRISV32_U_CONST16
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5709 { CRISV32F_INSN_CMPCWR
, model_crisv32_cmpcwr
, { { (int) UNIT_CRISV32_U_CONST16
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5710 { CRISV32F_INSN_CMPCDR
, model_crisv32_cmpcdr
, { { (int) UNIT_CRISV32_U_CONST32
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5711 { CRISV32F_INSN_CMPQ
, model_crisv32_cmpq
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5712 { CRISV32F_INSN_CMPS_M_B_M
, model_crisv32_cmps_m_b_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5713 { CRISV32F_INSN_CMPS_M_W_M
, model_crisv32_cmps_m_w_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5714 { CRISV32F_INSN_CMPSCBR
, model_crisv32_cmpscbr
, { { (int) UNIT_CRISV32_U_CONST16
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5715 { CRISV32F_INSN_CMPSCWR
, model_crisv32_cmpscwr
, { { (int) UNIT_CRISV32_U_CONST16
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5716 { CRISV32F_INSN_CMPU_M_B_M
, model_crisv32_cmpu_m_b_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5717 { CRISV32F_INSN_CMPU_M_W_M
, model_crisv32_cmpu_m_w_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5718 { CRISV32F_INSN_CMPUCBR
, model_crisv32_cmpucbr
, { { (int) UNIT_CRISV32_U_CONST16
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5719 { CRISV32F_INSN_CMPUCWR
, model_crisv32_cmpucwr
, { { (int) UNIT_CRISV32_U_CONST16
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5720 { CRISV32F_INSN_MOVE_M_B_M
, model_crisv32_move_m_b_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5721 { CRISV32F_INSN_MOVE_M_W_M
, model_crisv32_move_m_w_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5722 { CRISV32F_INSN_MOVE_M_D_M
, model_crisv32_move_m_d_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5723 { CRISV32F_INSN_MOVS_M_B_M
, model_crisv32_movs_m_b_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5724 { CRISV32F_INSN_MOVS_M_W_M
, model_crisv32_movs_m_w_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5725 { CRISV32F_INSN_MOVU_M_B_M
, model_crisv32_movu_m_b_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5726 { CRISV32F_INSN_MOVU_M_W_M
, model_crisv32_movu_m_w_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5727 { CRISV32F_INSN_MOVE_R_SPRV32
, model_crisv32_move_r_sprv32
, { { (int) UNIT_CRISV32_U_EXEC_TO_SR
, 1, 1 } } },
5728 { CRISV32F_INSN_MOVE_SPR_RV32
, model_crisv32_move_spr_rv32
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5729 { CRISV32F_INSN_MOVE_M_SPRV32
, model_crisv32_move_m_sprv32
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC_TO_SR
, 1, 1 } } },
5730 { CRISV32F_INSN_MOVE_C_SPRV32_P2
, model_crisv32_move_c_sprv32_p2
, { { (int) UNIT_CRISV32_U_CONST32
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC_TO_SR
, 1, 1 } } },
5731 { CRISV32F_INSN_MOVE_C_SPRV32_P3
, model_crisv32_move_c_sprv32_p3
, { { (int) UNIT_CRISV32_U_CONST32
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC_TO_SR
, 1, 1 } } },
5732 { CRISV32F_INSN_MOVE_C_SPRV32_P5
, model_crisv32_move_c_sprv32_p5
, { { (int) UNIT_CRISV32_U_CONST32
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC_TO_SR
, 1, 1 } } },
5733 { CRISV32F_INSN_MOVE_C_SPRV32_P6
, model_crisv32_move_c_sprv32_p6
, { { (int) UNIT_CRISV32_U_CONST32
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC_TO_SR
, 1, 1 } } },
5734 { CRISV32F_INSN_MOVE_C_SPRV32_P7
, model_crisv32_move_c_sprv32_p7
, { { (int) UNIT_CRISV32_U_CONST32
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC_TO_SR
, 1, 1 } } },
5735 { CRISV32F_INSN_MOVE_C_SPRV32_P9
, model_crisv32_move_c_sprv32_p9
, { { (int) UNIT_CRISV32_U_CONST32
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC_TO_SR
, 1, 1 } } },
5736 { CRISV32F_INSN_MOVE_C_SPRV32_P10
, model_crisv32_move_c_sprv32_p10
, { { (int) UNIT_CRISV32_U_CONST32
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC_TO_SR
, 1, 1 } } },
5737 { CRISV32F_INSN_MOVE_C_SPRV32_P11
, model_crisv32_move_c_sprv32_p11
, { { (int) UNIT_CRISV32_U_CONST32
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC_TO_SR
, 1, 1 } } },
5738 { CRISV32F_INSN_MOVE_C_SPRV32_P12
, model_crisv32_move_c_sprv32_p12
, { { (int) UNIT_CRISV32_U_CONST32
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC_TO_SR
, 1, 1 } } },
5739 { CRISV32F_INSN_MOVE_C_SPRV32_P13
, model_crisv32_move_c_sprv32_p13
, { { (int) UNIT_CRISV32_U_CONST32
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC_TO_SR
, 1, 1 } } },
5740 { CRISV32F_INSN_MOVE_C_SPRV32_P14
, model_crisv32_move_c_sprv32_p14
, { { (int) UNIT_CRISV32_U_CONST32
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC_TO_SR
, 1, 1 } } },
5741 { CRISV32F_INSN_MOVE_C_SPRV32_P15
, model_crisv32_move_c_sprv32_p15
, { { (int) UNIT_CRISV32_U_CONST32
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC_TO_SR
, 1, 1 } } },
5742 { CRISV32F_INSN_MOVE_SPR_MV32
, model_crisv32_move_spr_mv32
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_W
, 1, 1 } } },
5743 { CRISV32F_INSN_MOVE_SS_R
, model_crisv32_move_ss_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5744 { CRISV32F_INSN_MOVE_R_SS
, model_crisv32_move_r_ss
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5745 { CRISV32F_INSN_MOVEM_R_M_V32
, model_crisv32_movem_r_m_v32
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MOVEM_RTOM
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC_MOVEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_W
, 1, 1 } } },
5746 { CRISV32F_INSN_MOVEM_M_R_V32
, model_crisv32_movem_m_r_v32
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_MOVEM_MTOR
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC_MOVEM
, 1, 1 } } },
5747 { CRISV32F_INSN_ADD_B_R
, model_crisv32_add_b_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5748 { CRISV32F_INSN_ADD_W_R
, model_crisv32_add_w_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5749 { CRISV32F_INSN_ADD_D_R
, model_crisv32_add_d_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5750 { CRISV32F_INSN_ADD_M_B_M
, model_crisv32_add_m_b_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5751 { CRISV32F_INSN_ADD_M_W_M
, model_crisv32_add_m_w_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5752 { CRISV32F_INSN_ADD_M_D_M
, model_crisv32_add_m_d_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5753 { CRISV32F_INSN_ADDCBR
, model_crisv32_addcbr
, { { (int) UNIT_CRISV32_U_CONST16
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5754 { CRISV32F_INSN_ADDCWR
, model_crisv32_addcwr
, { { (int) UNIT_CRISV32_U_CONST16
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5755 { CRISV32F_INSN_ADDCDR
, model_crisv32_addcdr
, { { (int) UNIT_CRISV32_U_CONST32
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5756 { CRISV32F_INSN_ADDS_B_R
, model_crisv32_adds_b_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5757 { CRISV32F_INSN_ADDS_W_R
, model_crisv32_adds_w_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5758 { CRISV32F_INSN_ADDS_M_B_M
, model_crisv32_adds_m_b_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5759 { CRISV32F_INSN_ADDS_M_W_M
, model_crisv32_adds_m_w_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5760 { CRISV32F_INSN_ADDSCBR
, model_crisv32_addscbr
, { { (int) UNIT_CRISV32_U_CONST16
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5761 { CRISV32F_INSN_ADDSCWR
, model_crisv32_addscwr
, { { (int) UNIT_CRISV32_U_CONST16
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5762 { CRISV32F_INSN_ADDU_B_R
, model_crisv32_addu_b_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5763 { CRISV32F_INSN_ADDU_W_R
, model_crisv32_addu_w_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5764 { CRISV32F_INSN_ADDU_M_B_M
, model_crisv32_addu_m_b_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5765 { CRISV32F_INSN_ADDU_M_W_M
, model_crisv32_addu_m_w_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5766 { CRISV32F_INSN_ADDUCBR
, model_crisv32_adducbr
, { { (int) UNIT_CRISV32_U_CONST16
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5767 { CRISV32F_INSN_ADDUCWR
, model_crisv32_adducwr
, { { (int) UNIT_CRISV32_U_CONST16
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5768 { CRISV32F_INSN_SUB_B_R
, model_crisv32_sub_b_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5769 { CRISV32F_INSN_SUB_W_R
, model_crisv32_sub_w_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5770 { CRISV32F_INSN_SUB_D_R
, model_crisv32_sub_d_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5771 { CRISV32F_INSN_SUB_M_B_M
, model_crisv32_sub_m_b_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5772 { CRISV32F_INSN_SUB_M_W_M
, model_crisv32_sub_m_w_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5773 { CRISV32F_INSN_SUB_M_D_M
, model_crisv32_sub_m_d_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5774 { CRISV32F_INSN_SUBCBR
, model_crisv32_subcbr
, { { (int) UNIT_CRISV32_U_CONST16
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5775 { CRISV32F_INSN_SUBCWR
, model_crisv32_subcwr
, { { (int) UNIT_CRISV32_U_CONST16
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5776 { CRISV32F_INSN_SUBCDR
, model_crisv32_subcdr
, { { (int) UNIT_CRISV32_U_CONST32
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5777 { CRISV32F_INSN_SUBS_B_R
, model_crisv32_subs_b_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5778 { CRISV32F_INSN_SUBS_W_R
, model_crisv32_subs_w_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5779 { CRISV32F_INSN_SUBS_M_B_M
, model_crisv32_subs_m_b_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5780 { CRISV32F_INSN_SUBS_M_W_M
, model_crisv32_subs_m_w_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5781 { CRISV32F_INSN_SUBSCBR
, model_crisv32_subscbr
, { { (int) UNIT_CRISV32_U_CONST16
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5782 { CRISV32F_INSN_SUBSCWR
, model_crisv32_subscwr
, { { (int) UNIT_CRISV32_U_CONST16
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5783 { CRISV32F_INSN_SUBU_B_R
, model_crisv32_subu_b_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5784 { CRISV32F_INSN_SUBU_W_R
, model_crisv32_subu_w_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5785 { CRISV32F_INSN_SUBU_M_B_M
, model_crisv32_subu_m_b_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5786 { CRISV32F_INSN_SUBU_M_W_M
, model_crisv32_subu_m_w_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5787 { CRISV32F_INSN_SUBUCBR
, model_crisv32_subucbr
, { { (int) UNIT_CRISV32_U_CONST16
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5788 { CRISV32F_INSN_SUBUCWR
, model_crisv32_subucwr
, { { (int) UNIT_CRISV32_U_CONST16
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5789 { CRISV32F_INSN_ADDC_R
, model_crisv32_addc_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5790 { CRISV32F_INSN_ADDC_M
, model_crisv32_addc_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5791 { CRISV32F_INSN_ADDC_C
, model_crisv32_addc_c
, { { (int) UNIT_CRISV32_U_CONST32
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5792 { CRISV32F_INSN_LAPC_D
, model_crisv32_lapc_d
, { { (int) UNIT_CRISV32_U_CONST32
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5793 { CRISV32F_INSN_LAPCQ
, model_crisv32_lapcq
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5794 { CRISV32F_INSN_ADDI_B_R
, model_crisv32_addi_b_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5795 { CRISV32F_INSN_ADDI_W_R
, model_crisv32_addi_w_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5796 { CRISV32F_INSN_ADDI_D_R
, model_crisv32_addi_d_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5797 { CRISV32F_INSN_NEG_B_R
, model_crisv32_neg_b_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5798 { CRISV32F_INSN_NEG_W_R
, model_crisv32_neg_w_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5799 { CRISV32F_INSN_NEG_D_R
, model_crisv32_neg_d_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5800 { CRISV32F_INSN_TEST_M_B_M
, model_crisv32_test_m_b_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5801 { CRISV32F_INSN_TEST_M_W_M
, model_crisv32_test_m_w_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5802 { CRISV32F_INSN_TEST_M_D_M
, model_crisv32_test_m_d_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5803 { CRISV32F_INSN_MOVE_R_M_B_M
, model_crisv32_move_r_m_b_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_W
, 1, 1 } } },
5804 { CRISV32F_INSN_MOVE_R_M_W_M
, model_crisv32_move_r_m_w_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_W
, 1, 1 } } },
5805 { CRISV32F_INSN_MOVE_R_M_D_M
, model_crisv32_move_r_m_d_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_W
, 1, 1 } } },
5806 { CRISV32F_INSN_MULS_B
, model_crisv32_muls_b
, { { (int) UNIT_CRISV32_U_MULTIPLY
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5807 { CRISV32F_INSN_MULS_W
, model_crisv32_muls_w
, { { (int) UNIT_CRISV32_U_MULTIPLY
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5808 { CRISV32F_INSN_MULS_D
, model_crisv32_muls_d
, { { (int) UNIT_CRISV32_U_MULTIPLY
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5809 { CRISV32F_INSN_MULU_B
, model_crisv32_mulu_b
, { { (int) UNIT_CRISV32_U_MULTIPLY
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5810 { CRISV32F_INSN_MULU_W
, model_crisv32_mulu_w
, { { (int) UNIT_CRISV32_U_MULTIPLY
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5811 { CRISV32F_INSN_MULU_D
, model_crisv32_mulu_d
, { { (int) UNIT_CRISV32_U_MULTIPLY
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5812 { CRISV32F_INSN_MCP
, model_crisv32_mcp
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5813 { CRISV32F_INSN_DSTEP
, model_crisv32_dstep
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5814 { CRISV32F_INSN_ABS
, model_crisv32_abs
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5815 { CRISV32F_INSN_AND_B_R
, model_crisv32_and_b_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5816 { CRISV32F_INSN_AND_W_R
, model_crisv32_and_w_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5817 { CRISV32F_INSN_AND_D_R
, model_crisv32_and_d_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5818 { CRISV32F_INSN_AND_M_B_M
, model_crisv32_and_m_b_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5819 { CRISV32F_INSN_AND_M_W_M
, model_crisv32_and_m_w_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5820 { CRISV32F_INSN_AND_M_D_M
, model_crisv32_and_m_d_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5821 { CRISV32F_INSN_ANDCBR
, model_crisv32_andcbr
, { { (int) UNIT_CRISV32_U_CONST16
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5822 { CRISV32F_INSN_ANDCWR
, model_crisv32_andcwr
, { { (int) UNIT_CRISV32_U_CONST16
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5823 { CRISV32F_INSN_ANDCDR
, model_crisv32_andcdr
, { { (int) UNIT_CRISV32_U_CONST32
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5824 { CRISV32F_INSN_ANDQ
, model_crisv32_andq
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5825 { CRISV32F_INSN_ORR_B_R
, model_crisv32_orr_b_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5826 { CRISV32F_INSN_ORR_W_R
, model_crisv32_orr_w_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5827 { CRISV32F_INSN_ORR_D_R
, model_crisv32_orr_d_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5828 { CRISV32F_INSN_OR_M_B_M
, model_crisv32_or_m_b_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5829 { CRISV32F_INSN_OR_M_W_M
, model_crisv32_or_m_w_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5830 { CRISV32F_INSN_OR_M_D_M
, model_crisv32_or_m_d_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5831 { CRISV32F_INSN_ORCBR
, model_crisv32_orcbr
, { { (int) UNIT_CRISV32_U_CONST16
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5832 { CRISV32F_INSN_ORCWR
, model_crisv32_orcwr
, { { (int) UNIT_CRISV32_U_CONST16
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5833 { CRISV32F_INSN_ORCDR
, model_crisv32_orcdr
, { { (int) UNIT_CRISV32_U_CONST32
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5834 { CRISV32F_INSN_ORQ
, model_crisv32_orq
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5835 { CRISV32F_INSN_XOR
, model_crisv32_xor
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5836 { CRISV32F_INSN_SWAP
, model_crisv32_swap
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5837 { CRISV32F_INSN_ASRR_B_R
, model_crisv32_asrr_b_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5838 { CRISV32F_INSN_ASRR_W_R
, model_crisv32_asrr_w_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5839 { CRISV32F_INSN_ASRR_D_R
, model_crisv32_asrr_d_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5840 { CRISV32F_INSN_ASRQ
, model_crisv32_asrq
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5841 { CRISV32F_INSN_LSRR_B_R
, model_crisv32_lsrr_b_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5842 { CRISV32F_INSN_LSRR_W_R
, model_crisv32_lsrr_w_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5843 { CRISV32F_INSN_LSRR_D_R
, model_crisv32_lsrr_d_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5844 { CRISV32F_INSN_LSRQ
, model_crisv32_lsrq
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5845 { CRISV32F_INSN_LSLR_B_R
, model_crisv32_lslr_b_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5846 { CRISV32F_INSN_LSLR_W_R
, model_crisv32_lslr_w_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5847 { CRISV32F_INSN_LSLR_D_R
, model_crisv32_lslr_d_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5848 { CRISV32F_INSN_LSLQ
, model_crisv32_lslq
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5849 { CRISV32F_INSN_BTST
, model_crisv32_btst
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5850 { CRISV32F_INSN_BTSTQ
, model_crisv32_btstq
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5851 { CRISV32F_INSN_SETF
, model_crisv32_setf
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5852 { CRISV32F_INSN_CLEARF
, model_crisv32_clearf
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5853 { CRISV32F_INSN_RFE
, model_crisv32_rfe
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5854 { CRISV32F_INSN_SFE
, model_crisv32_sfe
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5855 { CRISV32F_INSN_RFG
, model_crisv32_rfg
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5856 { CRISV32F_INSN_RFN
, model_crisv32_rfn
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5857 { CRISV32F_INSN_HALT
, model_crisv32_halt
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5858 { CRISV32F_INSN_BCC_B
, model_crisv32_bcc_b
, { { (int) UNIT_CRISV32_U_BRANCH
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5859 { CRISV32F_INSN_BA_B
, model_crisv32_ba_b
, { { (int) UNIT_CRISV32_U_JUMP
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5860 { CRISV32F_INSN_BCC_W
, model_crisv32_bcc_w
, { { (int) UNIT_CRISV32_U_CONST16
, 1, 1 }, { (int) UNIT_CRISV32_U_BRANCH
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5861 { CRISV32F_INSN_BA_W
, model_crisv32_ba_w
, { { (int) UNIT_CRISV32_U_CONST16
, 1, 1 }, { (int) UNIT_CRISV32_U_JUMP
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5862 { CRISV32F_INSN_JAS_R
, model_crisv32_jas_r
, { { (int) UNIT_CRISV32_U_JUMP_R
, 1, 1 }, { (int) UNIT_CRISV32_U_JUMP
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5863 { CRISV32F_INSN_JAS_C
, model_crisv32_jas_c
, { { (int) UNIT_CRISV32_U_CONST32
, 1, 1 }, { (int) UNIT_CRISV32_U_JUMP
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5864 { CRISV32F_INSN_JUMP_P
, model_crisv32_jump_p
, { { (int) UNIT_CRISV32_U_JUMP_SR
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5865 { CRISV32F_INSN_BAS_C
, model_crisv32_bas_c
, { { (int) UNIT_CRISV32_U_CONST32
, 1, 1 }, { (int) UNIT_CRISV32_U_JUMP
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5866 { CRISV32F_INSN_JASC_R
, model_crisv32_jasc_r
, { { (int) UNIT_CRISV32_U_JUMP_R
, 1, 1 }, { (int) UNIT_CRISV32_U_SKIP4
, 1, 1 }, { (int) UNIT_CRISV32_U_JUMP
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5867 { CRISV32F_INSN_JASC_C
, model_crisv32_jasc_c
, { { (int) UNIT_CRISV32_U_CONST32
, 1, 1 }, { (int) UNIT_CRISV32_U_SKIP4
, 1, 1 }, { (int) UNIT_CRISV32_U_JUMP
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5868 { CRISV32F_INSN_BASC_C
, model_crisv32_basc_c
, { { (int) UNIT_CRISV32_U_CONST32
, 1, 1 }, { (int) UNIT_CRISV32_U_SKIP4
, 1, 1 }, { (int) UNIT_CRISV32_U_JUMP
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5869 { CRISV32F_INSN_BREAK
, model_crisv32_break
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5870 { CRISV32F_INSN_BOUND_R_B_R
, model_crisv32_bound_r_b_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5871 { CRISV32F_INSN_BOUND_R_W_R
, model_crisv32_bound_r_w_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5872 { CRISV32F_INSN_BOUND_R_D_R
, model_crisv32_bound_r_d_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5873 { CRISV32F_INSN_BOUND_CB
, model_crisv32_bound_cb
, { { (int) UNIT_CRISV32_U_CONST16
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5874 { CRISV32F_INSN_BOUND_CW
, model_crisv32_bound_cw
, { { (int) UNIT_CRISV32_U_CONST16
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5875 { CRISV32F_INSN_BOUND_CD
, model_crisv32_bound_cd
, { { (int) UNIT_CRISV32_U_CONST32
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5876 { CRISV32F_INSN_SCC
, model_crisv32_scc
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5877 { CRISV32F_INSN_LZ
, model_crisv32_lz
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5878 { CRISV32F_INSN_ADDOQ
, model_crisv32_addoq
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5879 { CRISV32F_INSN_ADDO_M_B_M
, model_crisv32_addo_m_b_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5880 { CRISV32F_INSN_ADDO_M_W_M
, model_crisv32_addo_m_w_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5881 { CRISV32F_INSN_ADDO_M_D_M
, model_crisv32_addo_m_d_m
, { { (int) UNIT_CRISV32_U_MEM
, 1, 1 }, { (int) UNIT_CRISV32_U_MEM_R
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5882 { CRISV32F_INSN_ADDO_CB
, model_crisv32_addo_cb
, { { (int) UNIT_CRISV32_U_CONST16
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5883 { CRISV32F_INSN_ADDO_CW
, model_crisv32_addo_cw
, { { (int) UNIT_CRISV32_U_CONST16
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5884 { CRISV32F_INSN_ADDO_CD
, model_crisv32_addo_cd
, { { (int) UNIT_CRISV32_U_CONST32
, 1, 1 }, { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5885 { CRISV32F_INSN_ADDI_ACR_B_R
, model_crisv32_addi_acr_b_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5886 { CRISV32F_INSN_ADDI_ACR_W_R
, model_crisv32_addi_acr_w_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5887 { CRISV32F_INSN_ADDI_ACR_D_R
, model_crisv32_addi_acr_d_r
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5888 { CRISV32F_INSN_FIDXI
, model_crisv32_fidxi
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5889 { CRISV32F_INSN_FTAGI
, model_crisv32_ftagi
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5890 { CRISV32F_INSN_FIDXD
, model_crisv32_fidxd
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5891 { CRISV32F_INSN_FTAGD
, model_crisv32_ftagd
, { { (int) UNIT_CRISV32_U_EXEC
, 1, 1 } } },
5894 #endif /* WITH_PROFILE_MODEL_P */
5897 crisv32_model_init (SIM_CPU
*cpu
)
5899 CPU_MODEL_DATA (cpu
) = (void *) zalloc (sizeof (MODEL_CRISV32_DATA
));
5902 #if WITH_PROFILE_MODEL_P
5903 #define TIMING_DATA(td) td
5905 #define TIMING_DATA(td) 0
5908 static const MODEL crisv32_models
[] =
5910 { "crisv32", & crisv32_mach
, MODEL_CRISV32
, TIMING_DATA (& crisv32_timing
[0]), crisv32_model_init
},
5914 /* The properties of this cpu's implementation. */
5916 static const MACH_IMP_PROPERTIES crisv32f_imp_properties
=
5928 crisv32f_prepare_run (SIM_CPU
*cpu
)
5930 if (CPU_IDESC (cpu
) == NULL
)
5931 crisv32f_init_idesc_table (cpu
);
5934 static const CGEN_INSN
*
5935 crisv32f_get_idata (SIM_CPU
*cpu
, int inum
)
5937 return CPU_IDESC (cpu
) [inum
].idata
;
5941 crisv32_init_cpu (SIM_CPU
*cpu
)
5943 CPU_REG_FETCH (cpu
) = crisv32f_fetch_register
;
5944 CPU_REG_STORE (cpu
) = crisv32f_store_register
;
5945 CPU_PC_FETCH (cpu
) = crisv32f_h_pc_get
;
5946 CPU_PC_STORE (cpu
) = crisv32f_h_pc_set
;
5947 CPU_GET_IDATA (cpu
) = crisv32f_get_idata
;
5948 CPU_MAX_INSNS (cpu
) = CRISV32F_INSN__MAX
;
5949 CPU_INSN_NAME (cpu
) = cgen_insn_name
;
5950 CPU_FULL_ENGINE_FN (cpu
) = crisv32f_engine_run_full
;
5952 CPU_FAST_ENGINE_FN (cpu
) = crisv32f_engine_run_fast
;
5954 CPU_FAST_ENGINE_FN (cpu
) = crisv32f_engine_run_full
;
5958 const MACH crisv32_mach
=
5960 "crisv32", "crisv32", MACH_CRISV32
,
5961 32, 32, & crisv32_models
[0], & crisv32f_imp_properties
,
5963 crisv32f_prepare_run