3 #include "dyngen-exec.h"
5 register struct CPUSPARCState *env asm(AREG0);
11 register uint32_t T0 asm(AREG1);
12 register uint32_t T1 asm(AREG2);
13 register uint32_t T2 asm(AREG3);
15 #define FT0 (env->ft0)
16 #define FT1 (env->ft1)
17 #define FT2 (env->ft2)
18 #define DT0 (env->dt0)
19 #define DT1 (env->dt1)
20 #define DT2 (env->dt2)
26 void cpu_unlock(void);
27 void cpu_loop_exit(void);
28 void helper_flush(target_ulong addr);
29 void helper_ld_asi(int asi, int size, int sign);
30 void helper_st_asi(int asi, int size, int sign);
31 void helper_rett(void);
32 void helper_ldfsr(void);
33 void set_cwp(int new_cwp);
41 void do_ldd_kernel(target_ulong addr);
42 void do_ldd_user(target_ulong addr);
43 void do_ldd_raw(target_ulong addr);
44 void do_interrupt(int intno);
45 void raise_exception(int tt);
46 void memcpy32(target_ulong *dst, const target_ulong *src);
47 target_ulong mmu_probe(target_ulong address, int mmulev);
53 /* XXX: move that to a generic header */
54 #if !defined(CONFIG_USER_ONLY)
56 #define ldul_user ldl_user
57 #define ldul_kernel ldl_kernel
60 #define MEMSUFFIX _kernel
62 #include "softmmu_header.h"
65 #include "softmmu_header.h"
68 #include "softmmu_header.h"
71 #include "softmmu_header.h"
76 #define MEMSUFFIX _user
78 #include "softmmu_header.h"
81 #include "softmmu_header.h"
84 #include "softmmu_header.h"
87 #include "softmmu_header.h"
91 /* these access are slower, they must be as rare as possible */
93 #define MEMSUFFIX _data
95 #include "softmmu_header.h"
98 #include "softmmu_header.h"
101 #include "softmmu_header.h"
104 #include "softmmu_header.h"
108 #define ldub(p) ldub_data(p)
109 #define ldsb(p) ldsb_data(p)
110 #define lduw(p) lduw_data(p)
111 #define ldsw(p) ldsw_data(p)
112 #define ldl(p) ldl_data(p)
113 #define ldq(p) ldq_data(p)
115 #define stb(p, v) stb_data(p, v)
116 #define stw(p, v) stw_data(p, v)
117 #define stl(p, v) stl_data(p, v)
118 #define stq(p, v) stq_data(p, v)
120 #endif /* !defined(CONFIG_USER_ONLY) */
122 static inline void env_to_regs(void)
126 static inline void regs_to_env(void)
130 int cpu_sparc_handle_mmu_fault(CPUState *env, target_ulong address, int rw,
131 int is_user, int is_softmmu);