1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20#ifndef CPU_ARM_H
21#define CPU_ARM_H
22
23#define TARGET_LONG_BITS 32
24
25#define ELF_MACHINE EM_ARM
26
27#include "cpu-defs.h"
28
29#include "softfloat.h"
30
31#define TARGET_HAS_ICE 1
32
33#define EXCP_UDEF 1
34#define EXCP_SWI 2
35#define EXCP_PREFETCH_ABORT 3
36#define EXCP_DATA_ABORT 4
37#define EXCP_IRQ 5
38#define EXCP_FIQ 6
39#define EXCP_BKPT 7
40#define EXCP_EXCEPTION_EXIT 8
41#define EXCP_KERNEL_TRAP 9
42
43#define ARMV7M_EXCP_RESET 1
44#define ARMV7M_EXCP_NMI 2
45#define ARMV7M_EXCP_HARD 3
46#define ARMV7M_EXCP_MEM 4
47#define ARMV7M_EXCP_BUS 5
48#define ARMV7M_EXCP_USAGE 6
49#define ARMV7M_EXCP_SVC 11
50#define ARMV7M_EXCP_DEBUG 12
51#define ARMV7M_EXCP_PENDSV 14
52#define ARMV7M_EXCP_SYSTICK 15
53
54typedef void ARMWriteCPFunc(void *opaque, int cp_info,
55 int srcreg, int operand, uint32_t value);
56typedef uint32_t ARMReadCPFunc(void *opaque, int cp_info,
57 int dstreg, int operand);
58
59struct arm_boot_info;
60
61#define NB_MMU_MODES 2
62
63
64
65
66
67
68
69
70
71typedef struct CPUARMState {
72
73 uint32_t regs[16];
74
75
76
77 uint32_t uncached_cpsr;
78 uint32_t spsr;
79
80
81 uint32_t banked_spsr[6];
82 uint32_t banked_r13[6];
83 uint32_t banked_r14[6];
84
85
86 uint32_t usr_regs[5];
87 uint32_t fiq_regs[5];
88
89
90 uint32_t CF;
91 uint32_t VF;
92 uint32_t NF;
93 uint32_t ZF;
94 uint32_t QF;
95 uint32_t GE;
96 uint32_t thumb;
97 uint32_t condexec_bits;
98
99
100 struct {
101 uint32_t c0_cpuid;
102 uint32_t c0_cachetype;
103 uint32_t c0_ccsid[16];
104 uint32_t c0_clid;
105 uint32_t c0_cssel;
106 uint32_t c0_c1[8];
107 uint32_t c0_c2[8];
108 uint32_t c1_sys;
109 uint32_t c1_coproc;
110 uint32_t c1_xscaleauxcr;
111 uint32_t c2_base0;
112 uint32_t c2_base1;
113 uint32_t c2_control;
114 uint32_t c2_mask;
115 uint32_t c2_base_mask;
116 uint32_t c2_data;
117 uint32_t c2_insn;
118 uint32_t c3;
119
120 uint32_t c5_insn;
121 uint32_t c5_data;
122 uint32_t c6_region[8];
123 uint32_t c6_insn;
124 uint32_t c6_data;
125 uint32_t c9_insn;
126 uint32_t c9_data;
127 uint32_t c13_fcse;
128 uint32_t c13_context;
129 uint32_t c13_tls1;
130 uint32_t c13_tls2;
131 uint32_t c13_tls3;
132 uint32_t c15_cpar;
133 uint32_t c15_ticonfig;
134 uint32_t c15_i_max;
135 uint32_t c15_i_min;
136 uint32_t c15_threadid;
137 } cp15;
138
139 struct {
140 uint32_t other_sp;
141 uint32_t vecbase;
142 uint32_t basepri;
143 uint32_t control;
144 int current_sp;
145 int exception;
146 int pending_exception;
147 void *nvic;
148 } v7m;
149
150
151 struct {
152 ARMReadCPFunc *cp_read;
153 ARMWriteCPFunc *cp_write;
154 void *opaque;
155 } cp[15];
156
157
158 uint32_t teecr;
159 uint32_t teehbr;
160
161
162 uint32_t features;
163
164
165 int (*get_irq_vector)(struct CPUARMState *);
166 void *irq_opaque;
167
168
169 struct {
170 float64 regs[32];
171
172 uint32_t xregs[16];
173
174 int vec_len;
175 int vec_stride;
176
177
178 uint32_t scratch[8];
179
180 float_status fp_status;
181 } vfp;
182#if defined(CONFIG_USER_ONLY)
183 struct mmon_state *mmon_entry;
184#else
185 uint32_t mmon_addr;
186#endif
187
188
189 struct {
190 uint64_t regs[16];
191 uint64_t val;
192
193 uint32_t cregs[16];
194 } iwmmxt;
195
196#if defined(CONFIG_USER_ONLY)
197
198 int eabi;
199#endif
200
201 CPU_COMMON
202
203
204 struct arm_boot_info *boot_info;
205} CPUARMState;
206
207CPUARMState *cpu_arm_init(const char *cpu_model);
208void arm_translate_init(void);
209int cpu_arm_exec(CPUARMState *s);
210void cpu_arm_close(CPUARMState *s);
211void do_interrupt(CPUARMState *);
212void switch_mode(CPUARMState *, int);
213uint32_t do_arm_semihosting(CPUARMState *env);
214
215
216
217
218int cpu_arm_signal_handler(int host_signum, void *pinfo,
219 void *puc);
220int cpu_arm_handle_mmu_fault (CPUARMState *env, target_ulong address, int rw,
221 int mmu_idx, int is_softmuu);
222
223void cpu_lock(void);
224void cpu_unlock(void);
225static inline void cpu_set_tls(CPUARMState *env, target_ulong newtls)
226{
227 env->cp15.c13_tls2 = newtls;
228}
229
230#define CPSR_M (0x1f)
231#define CPSR_T (1 << 5)
232#define CPSR_F (1 << 6)
233#define CPSR_I (1 << 7)
234#define CPSR_A (1 << 8)
235#define CPSR_E (1 << 9)
236#define CPSR_IT_2_7 (0xfc00)
237#define CPSR_GE (0xf << 16)
238#define CPSR_RESERVED (0xf << 20)
239#define CPSR_J (1 << 24)
240#define CPSR_IT_0_1 (3 << 25)
241#define CPSR_Q (1 << 27)
242#define CPSR_V (1 << 28)
243#define CPSR_C (1 << 29)
244#define CPSR_Z (1 << 30)
245#define CPSR_N (1 << 31)
246#define CPSR_NZCV (CPSR_N | CPSR_Z | CPSR_C | CPSR_V)
247
248#define CPSR_IT (CPSR_IT_0_1 | CPSR_IT_2_7)
249#define CACHED_CPSR_BITS (CPSR_T | CPSR_GE | CPSR_IT | CPSR_Q | CPSR_NZCV)
250
251#define CPSR_USER (CPSR_NZCV | CPSR_Q | CPSR_GE)
252
253#define CPSR_EXEC (CPSR_T | CPSR_IT | CPSR_J)
254
255
256uint32_t cpsr_read(CPUARMState *env);
257
258void cpsr_write(CPUARMState *env, uint32_t val, uint32_t mask);
259
260
261static inline uint32_t xpsr_read(CPUARMState *env)
262{
263 int ZF;
264 ZF = (env->ZF == 0);
265 return (env->NF & 0x80000000) | (ZF << 30)
266 | (env->CF << 29) | ((env->VF & 0x80000000) >> 3) | (env->QF << 27)
267 | (env->thumb << 24) | ((env->condexec_bits & 3) << 25)
268 | ((env->condexec_bits & 0xfc) << 8)
269 | env->v7m.exception;
270}
271
272
273static inline void xpsr_write(CPUARMState *env, uint32_t val, uint32_t mask)
274{
275 if (mask & CPSR_NZCV) {
276 env->ZF = (~val) & CPSR_Z;
277 env->NF = val;
278 env->CF = (val >> 29) & 1;
279 env->VF = (val << 3) & 0x80000000;
280 }
281 if (mask & CPSR_Q)
282 env->QF = ((val & CPSR_Q) != 0);
283 if (mask & (1 << 24))
284 env->thumb = ((val & (1 << 24)) != 0);
285 if (mask & CPSR_IT_0_1) {
286 env->condexec_bits &= ~3;
287 env->condexec_bits |= (val >> 25) & 3;
288 }
289 if (mask & CPSR_IT_2_7) {
290 env->condexec_bits &= 3;
291 env->condexec_bits |= (val >> 8) & 0xfc;
292 }
293 if (mask & 0x1ff) {
294 env->v7m.exception = val & 0x1ff;
295 }
296}
297
298enum arm_cpu_mode {
299 ARM_CPU_MODE_USR = 0x10,
300 ARM_CPU_MODE_FIQ = 0x11,
301 ARM_CPU_MODE_IRQ = 0x12,
302 ARM_CPU_MODE_SVC = 0x13,
303 ARM_CPU_MODE_ABT = 0x17,
304 ARM_CPU_MODE_UND = 0x1b,
305 ARM_CPU_MODE_SYS = 0x1f
306};
307
308
309#define ARM_VFP_FPSID 0
310#define ARM_VFP_FPSCR 1
311#define ARM_VFP_MVFR1 6
312#define ARM_VFP_MVFR0 7
313#define ARM_VFP_FPEXC 8
314#define ARM_VFP_FPINST 9
315#define ARM_VFP_FPINST2 10
316
317
318#define ARM_IWMMXT_wCID 0
319#define ARM_IWMMXT_wCon 1
320#define ARM_IWMMXT_wCSSF 2
321#define ARM_IWMMXT_wCASF 3
322#define ARM_IWMMXT_wCGR0 8
323#define ARM_IWMMXT_wCGR1 9
324#define ARM_IWMMXT_wCGR2 10
325#define ARM_IWMMXT_wCGR3 11
326
327enum arm_features {
328 ARM_FEATURE_VFP,
329 ARM_FEATURE_AUXCR,
330 ARM_FEATURE_XSCALE,
331 ARM_FEATURE_IWMMXT,
332 ARM_FEATURE_V6,
333 ARM_FEATURE_V6K,
334 ARM_FEATURE_V7,
335 ARM_FEATURE_THUMB2,
336 ARM_FEATURE_MPU,
337 ARM_FEATURE_VFP3,
338 ARM_FEATURE_NEON,
339 ARM_FEATURE_DIV,
340 ARM_FEATURE_M,
341 ARM_FEATURE_OMAPCP,
342 ARM_FEATURE_THUMB2EE
343};
344
345static inline int arm_feature(CPUARMState *env, int feature)
346{
347 return (env->features & (1u << feature)) != 0;
348}
349
350void arm_cpu_list(FILE *f, int (*cpu_fprintf)(FILE *f, const char *fmt, ...));
351
352
353void armv7m_nvic_set_pending(void *opaque, int irq);
354int armv7m_nvic_acknowledge_irq(void *opaque);
355void armv7m_nvic_complete_irq(void *opaque, int irq);
356
357void cpu_arm_set_cp_io(CPUARMState *env, int cpnum,
358 ARMReadCPFunc *cp_read, ARMWriteCPFunc *cp_write,
359 void *opaque);
360
361
362
363
364
365#define IS_M(env) arm_feature(env, ARM_FEATURE_M)
366#define ARM_CPUID(env) (env->cp15.c0_cpuid)
367
368#define ARM_CPUID_ARM1026 0x4106a262
369#define ARM_CPUID_ARM926 0x41069265
370#define ARM_CPUID_ARM946 0x41059461
371#define ARM_CPUID_TI915T 0x54029152
372#define ARM_CPUID_TI925T 0x54029252
373#define ARM_CPUID_PXA250 0x69052100
374#define ARM_CPUID_PXA255 0x69052d00
375#define ARM_CPUID_PXA260 0x69052903
376#define ARM_CPUID_PXA261 0x69052d05
377#define ARM_CPUID_PXA262 0x69052d06
378#define ARM_CPUID_PXA270 0x69054110
379#define ARM_CPUID_PXA270_A0 0x69054110
380#define ARM_CPUID_PXA270_A1 0x69054111
381#define ARM_CPUID_PXA270_B0 0x69054112
382#define ARM_CPUID_PXA270_B1 0x69054113
383#define ARM_CPUID_PXA270_C0 0x69054114
384#define ARM_CPUID_PXA270_C5 0x69054117
385#define ARM_CPUID_ARM1136 0x4117b363
386#define ARM_CPUID_ARM1136_R2 0x4107b362
387#define ARM_CPUID_ARM11MPCORE 0x410fb022
388#define ARM_CPUID_CORTEXA8 0x410fc080
389#define ARM_CPUID_CORTEXM3 0x410fc231
390#define ARM_CPUID_ANY 0xffffffff
391
392#if defined(CONFIG_USER_ONLY)
393#define TARGET_PAGE_BITS 12
394#else
395
396
397
398#define TARGET_PAGE_BITS 10
399#endif
400
401#define CPUState CPUARMState
402#define cpu_init cpu_arm_init
403#define cpu_exec cpu_arm_exec
404#define cpu_gen_code cpu_arm_gen_code
405#define cpu_signal_handler cpu_arm_signal_handler
406#define cpu_list arm_cpu_list
407
408#define CPU_SAVE_VERSION 1
409
410
411#define MMU_MODE0_SUFFIX _kernel
412#define MMU_MODE1_SUFFIX _user
413#define MMU_USER_IDX 1
414static inline int cpu_mmu_index (CPUState *env)
415{
416 return (env->uncached_cpsr & CPSR_M) == ARM_CPU_MODE_USR ? 1 : 0;
417}
418
419#if defined(CONFIG_USER_ONLY)
420static inline void cpu_clone_regs(CPUState *env, target_ulong newsp)
421{
422 if (newsp)
423 env->regs[13] = newsp;
424 env->regs[0] = 0;
425}
426#endif
427
428#include "cpu-all.h"
429#include "exec-all.h"
430
431static inline void cpu_pc_from_tb(CPUState *env, TranslationBlock *tb)
432{
433 env->regs[15] = tb->pc;
434}
435
436static inline void cpu_get_tb_cpu_state(CPUState *env, target_ulong *pc,
437 target_ulong *cs_base, int *flags)
438{
439 *pc = env->regs[15];
440 *cs_base = 0;
441 *flags = env->thumb | (env->vfp.vec_len << 1)
442 | (env->vfp.vec_stride << 4) | (env->condexec_bits << 8);
443 if ((env->uncached_cpsr & CPSR_M) != ARM_CPU_MODE_USR)
444 *flags |= (1 << 6);
445 if (env->vfp.xregs[ARM_VFP_FPEXC] & (1 << 30))
446 *flags |= (1 << 7);
447}
448
449#endif
450