1 /* Misc. support for CPU family sh64.
3 THIS FILE IS MACHINE GENERATED WITH CGEN.
5 Copyright 1996-2018 Free Software Foundation, Inc.
7 This file is part of the GNU simulators.
9 This file is free software; you can redistribute it and/or modify
10 it under the terms of the GNU General Public License as published by
11 the Free Software Foundation; either version 3, or (at your option)
14 It is distributed in the hope that it will be useful, but WITHOUT
15 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
16 or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
17 License for more details.
19 You should have received a copy of the GNU General Public License along
20 with this program; if not, see <http://www.gnu.org/licenses/>.
30 /* Get the value of h-pc. */
33 sh64_h_pc_get (SIM_CPU
*current_cpu
)
38 /* Set a value for h-pc. */
41 sh64_h_pc_set (SIM_CPU
*current_cpu
, UDI newval
)
46 /* Get the value of h-gr. */
49 sh64_h_gr_get (SIM_CPU
*current_cpu
, UINT regno
)
51 return GET_H_GR (regno
);
54 /* Set a value for h-gr. */
57 sh64_h_gr_set (SIM_CPU
*current_cpu
, UINT regno
, DI newval
)
59 SET_H_GR (regno
, newval
);
62 /* Get the value of h-grc. */
65 sh64_h_grc_get (SIM_CPU
*current_cpu
, UINT regno
)
67 return GET_H_GRC (regno
);
70 /* Set a value for h-grc. */
73 sh64_h_grc_set (SIM_CPU
*current_cpu
, UINT regno
, SI newval
)
75 SET_H_GRC (regno
, newval
);
78 /* Get the value of h-cr. */
81 sh64_h_cr_get (SIM_CPU
*current_cpu
, UINT regno
)
83 return GET_H_CR (regno
);
86 /* Set a value for h-cr. */
89 sh64_h_cr_set (SIM_CPU
*current_cpu
, UINT regno
, DI newval
)
91 SET_H_CR (regno
, newval
);
94 /* Get the value of h-sr. */
97 sh64_h_sr_get (SIM_CPU
*current_cpu
)
102 /* Set a value for h-sr. */
105 sh64_h_sr_set (SIM_CPU
*current_cpu
, SI newval
)
110 /* Get the value of h-fpscr. */
113 sh64_h_fpscr_get (SIM_CPU
*current_cpu
)
115 return CPU (h_fpscr
);
118 /* Set a value for h-fpscr. */
121 sh64_h_fpscr_set (SIM_CPU
*current_cpu
, SI newval
)
123 CPU (h_fpscr
) = newval
;
126 /* Get the value of h-frbit. */
129 sh64_h_frbit_get (SIM_CPU
*current_cpu
)
131 return GET_H_FRBIT ();
134 /* Set a value for h-frbit. */
137 sh64_h_frbit_set (SIM_CPU
*current_cpu
, BI newval
)
139 SET_H_FRBIT (newval
);
142 /* Get the value of h-szbit. */
145 sh64_h_szbit_get (SIM_CPU
*current_cpu
)
147 return GET_H_SZBIT ();
150 /* Set a value for h-szbit. */
153 sh64_h_szbit_set (SIM_CPU
*current_cpu
, BI newval
)
155 SET_H_SZBIT (newval
);
158 /* Get the value of h-prbit. */
161 sh64_h_prbit_get (SIM_CPU
*current_cpu
)
163 return GET_H_PRBIT ();
166 /* Set a value for h-prbit. */
169 sh64_h_prbit_set (SIM_CPU
*current_cpu
, BI newval
)
171 SET_H_PRBIT (newval
);
174 /* Get the value of h-sbit. */
177 sh64_h_sbit_get (SIM_CPU
*current_cpu
)
179 return GET_H_SBIT ();
182 /* Set a value for h-sbit. */
185 sh64_h_sbit_set (SIM_CPU
*current_cpu
, BI newval
)
190 /* Get the value of h-mbit. */
193 sh64_h_mbit_get (SIM_CPU
*current_cpu
)
195 return GET_H_MBIT ();
198 /* Set a value for h-mbit. */
201 sh64_h_mbit_set (SIM_CPU
*current_cpu
, BI newval
)
206 /* Get the value of h-qbit. */
209 sh64_h_qbit_get (SIM_CPU
*current_cpu
)
211 return GET_H_QBIT ();
214 /* Set a value for h-qbit. */
217 sh64_h_qbit_set (SIM_CPU
*current_cpu
, BI newval
)
222 /* Get the value of h-fr. */
225 sh64_h_fr_get (SIM_CPU
*current_cpu
, UINT regno
)
227 return CPU (h_fr
[regno
]);
230 /* Set a value for h-fr. */
233 sh64_h_fr_set (SIM_CPU
*current_cpu
, UINT regno
, SF newval
)
235 CPU (h_fr
[regno
]) = newval
;
238 /* Get the value of h-fp. */
241 sh64_h_fp_get (SIM_CPU
*current_cpu
, UINT regno
)
243 return GET_H_FP (regno
);
246 /* Set a value for h-fp. */
249 sh64_h_fp_set (SIM_CPU
*current_cpu
, UINT regno
, SF newval
)
251 SET_H_FP (regno
, newval
);
254 /* Get the value of h-fv. */
257 sh64_h_fv_get (SIM_CPU
*current_cpu
, UINT regno
)
259 return GET_H_FV (regno
);
262 /* Set a value for h-fv. */
265 sh64_h_fv_set (SIM_CPU
*current_cpu
, UINT regno
, SF newval
)
267 SET_H_FV (regno
, newval
);
270 /* Get the value of h-fmtx. */
273 sh64_h_fmtx_get (SIM_CPU
*current_cpu
, UINT regno
)
275 return GET_H_FMTX (regno
);
278 /* Set a value for h-fmtx. */
281 sh64_h_fmtx_set (SIM_CPU
*current_cpu
, UINT regno
, SF newval
)
283 SET_H_FMTX (regno
, newval
);
286 /* Get the value of h-dr. */
289 sh64_h_dr_get (SIM_CPU
*current_cpu
, UINT regno
)
291 return GET_H_DR (regno
);
294 /* Set a value for h-dr. */
297 sh64_h_dr_set (SIM_CPU
*current_cpu
, UINT regno
, DF newval
)
299 SET_H_DR (regno
, newval
);
302 /* Get the value of h-fsd. */
305 sh64_h_fsd_get (SIM_CPU
*current_cpu
, UINT regno
)
307 return GET_H_FSD (regno
);
310 /* Set a value for h-fsd. */
313 sh64_h_fsd_set (SIM_CPU
*current_cpu
, UINT regno
, DF newval
)
315 SET_H_FSD (regno
, newval
);
318 /* Get the value of h-fmov. */
321 sh64_h_fmov_get (SIM_CPU
*current_cpu
, UINT regno
)
323 return GET_H_FMOV (regno
);
326 /* Set a value for h-fmov. */
329 sh64_h_fmov_set (SIM_CPU
*current_cpu
, UINT regno
, DF newval
)
331 SET_H_FMOV (regno
, newval
);
334 /* Get the value of h-tr. */
337 sh64_h_tr_get (SIM_CPU
*current_cpu
, UINT regno
)
339 return CPU (h_tr
[regno
]);
342 /* Set a value for h-tr. */
345 sh64_h_tr_set (SIM_CPU
*current_cpu
, UINT regno
, DI newval
)
347 CPU (h_tr
[regno
]) = newval
;
350 /* Get the value of h-endian. */
353 sh64_h_endian_get (SIM_CPU
*current_cpu
)
355 return GET_H_ENDIAN ();
358 /* Set a value for h-endian. */
361 sh64_h_endian_set (SIM_CPU
*current_cpu
, BI newval
)
363 SET_H_ENDIAN (newval
);
366 /* Get the value of h-ism. */
369 sh64_h_ism_get (SIM_CPU
*current_cpu
)
374 /* Set a value for h-ism. */
377 sh64_h_ism_set (SIM_CPU
*current_cpu
, BI newval
)
382 /* Get the value of h-frc. */
385 sh64_h_frc_get (SIM_CPU
*current_cpu
, UINT regno
)
387 return GET_H_FRC (regno
);
390 /* Set a value for h-frc. */
393 sh64_h_frc_set (SIM_CPU
*current_cpu
, UINT regno
, SF newval
)
395 SET_H_FRC (regno
, newval
);
398 /* Get the value of h-drc. */
401 sh64_h_drc_get (SIM_CPU
*current_cpu
, UINT regno
)
403 return GET_H_DRC (regno
);
406 /* Set a value for h-drc. */
409 sh64_h_drc_set (SIM_CPU
*current_cpu
, UINT regno
, DF newval
)
411 SET_H_DRC (regno
, newval
);
414 /* Get the value of h-xf. */
417 sh64_h_xf_get (SIM_CPU
*current_cpu
, UINT regno
)
419 return GET_H_XF (regno
);
422 /* Set a value for h-xf. */
425 sh64_h_xf_set (SIM_CPU
*current_cpu
, UINT regno
, SF newval
)
427 SET_H_XF (regno
, newval
);
430 /* Get the value of h-xd. */
433 sh64_h_xd_get (SIM_CPU
*current_cpu
, UINT regno
)
435 return GET_H_XD (regno
);
438 /* Set a value for h-xd. */
441 sh64_h_xd_set (SIM_CPU
*current_cpu
, UINT regno
, DF newval
)
443 SET_H_XD (regno
, newval
);
446 /* Get the value of h-fvc. */
449 sh64_h_fvc_get (SIM_CPU
*current_cpu
, UINT regno
)
451 return GET_H_FVC (regno
);
454 /* Set a value for h-fvc. */
457 sh64_h_fvc_set (SIM_CPU
*current_cpu
, UINT regno
, SF newval
)
459 SET_H_FVC (regno
, newval
);
462 /* Get the value of h-gbr. */
465 sh64_h_gbr_get (SIM_CPU
*current_cpu
)
470 /* Set a value for h-gbr. */
473 sh64_h_gbr_set (SIM_CPU
*current_cpu
, SI newval
)
478 /* Get the value of h-vbr. */
481 sh64_h_vbr_get (SIM_CPU
*current_cpu
)
486 /* Set a value for h-vbr. */
489 sh64_h_vbr_set (SIM_CPU
*current_cpu
, SI newval
)
494 /* Get the value of h-pr. */
497 sh64_h_pr_get (SIM_CPU
*current_cpu
)
502 /* Set a value for h-pr. */
505 sh64_h_pr_set (SIM_CPU
*current_cpu
, SI newval
)
510 /* Get the value of h-macl. */
513 sh64_h_macl_get (SIM_CPU
*current_cpu
)
515 return GET_H_MACL ();
518 /* Set a value for h-macl. */
521 sh64_h_macl_set (SIM_CPU
*current_cpu
, SI newval
)
526 /* Get the value of h-mach. */
529 sh64_h_mach_get (SIM_CPU
*current_cpu
)
531 return GET_H_MACH ();
534 /* Set a value for h-mach. */
537 sh64_h_mach_set (SIM_CPU
*current_cpu
, SI newval
)
542 /* Get the value of h-tbit. */
545 sh64_h_tbit_get (SIM_CPU
*current_cpu
)
547 return GET_H_TBIT ();
550 /* Set a value for h-tbit. */
553 sh64_h_tbit_set (SIM_CPU
*current_cpu
, BI newval
)
558 /* Record trace results for INSN. */
561 sh64_record_trace_results (SIM_CPU
*current_cpu
, CGEN_INSN
*insn
,
562 int *indices
, TRACE_RECORD
*tr
)