SPARC merge
[qemu] / target-sparc / exec.h
1 #ifndef EXEC_SPARC_H
2 #define EXEC_SPARC_H 1
3 #include "dyngen-exec.h"
4
5 register struct CPUSPARCState *env asm(AREG0);
6 register uint32_t T0 asm(AREG1);
7 register uint32_t T1 asm(AREG2);
8 register uint32_t T2 asm(AREG3);
9 #define FT0 (env->ft0)
10 #define FT1 (env->ft1)
11 #define FT2 (env->ft2)
12 #define DT0 (env->dt0)
13 #define DT1 (env->dt1)
14 #define DT2 (env->dt2)
15
16 #include "cpu.h"
17 #include "exec-all.h"
18
19 void cpu_lock(void);
20 void cpu_unlock(void);
21 void cpu_loop_exit(void);
22 void helper_flush(target_ulong addr);
23 void helper_ld_asi(int asi, int size, int sign);
24 void helper_st_asi(int asi, int size, int sign);
25 void helper_rett(void);
26 void helper_ldfsr(void);
27 void set_cwp(int new_cwp);
28 void do_fitos(void);
29 void do_fitod(void);
30 void do_fabss(void);
31 void do_fsqrts(void);
32 void do_fsqrtd(void);
33 void do_fcmps(void);
34 void do_fcmpd(void);
35 void do_ldd_kernel(uint32_t addr);
36 void do_ldd_user(uint32_t addr);
37 void do_ldd_raw(uint32_t addr);
38 void do_interrupt(int intno, int is_int, int error_code, 
39                   unsigned int next_eip, int is_hw);
40 void raise_exception_err(int exception_index, int error_code);
41 void raise_exception(int tt);
42 void memcpy32(uint32_t *dst, const uint32_t *src);
43 uint32_t mmu_probe(uint32_t address, int mmulev);
44 void dump_mmu(void);
45 void helper_debug();
46
47 /* XXX: move that to a generic header */
48 #if !defined(CONFIG_USER_ONLY)
49
50 #define ldul_user ldl_user
51 #define ldul_kernel ldl_kernel
52
53 #define ACCESS_TYPE 0
54 #define MEMSUFFIX _kernel
55 #define DATA_SIZE 1
56 #include "softmmu_header.h"
57
58 #define DATA_SIZE 2
59 #include "softmmu_header.h"
60
61 #define DATA_SIZE 4
62 #include "softmmu_header.h"
63
64 #define DATA_SIZE 8
65 #include "softmmu_header.h"
66 #undef ACCESS_TYPE
67 #undef MEMSUFFIX
68
69 #define ACCESS_TYPE 1
70 #define MEMSUFFIX _user
71 #define DATA_SIZE 1
72 #include "softmmu_header.h"
73
74 #define DATA_SIZE 2
75 #include "softmmu_header.h"
76
77 #define DATA_SIZE 4
78 #include "softmmu_header.h"
79
80 #define DATA_SIZE 8
81 #include "softmmu_header.h"
82 #undef ACCESS_TYPE
83 #undef MEMSUFFIX
84
85 /* these access are slower, they must be as rare as possible */
86 #define ACCESS_TYPE 2
87 #define MEMSUFFIX _data
88 #define DATA_SIZE 1
89 #include "softmmu_header.h"
90
91 #define DATA_SIZE 2
92 #include "softmmu_header.h"
93
94 #define DATA_SIZE 4
95 #include "softmmu_header.h"
96
97 #define DATA_SIZE 8
98 #include "softmmu_header.h"
99 #undef ACCESS_TYPE
100 #undef MEMSUFFIX
101
102 #define ldub(p) ldub_data(p)
103 #define ldsb(p) ldsb_data(p)
104 #define lduw(p) lduw_data(p)
105 #define ldsw(p) ldsw_data(p)
106 #define ldl(p) ldl_data(p)
107 #define ldq(p) ldq_data(p)
108
109 #define stb(p, v) stb_data(p, v)
110 #define stw(p, v) stw_data(p, v)
111 #define stl(p, v) stl_data(p, v)
112 #define stq(p, v) stq_data(p, v)
113
114 #endif /* !defined(CONFIG_USER_ONLY) */
115
116 static inline void env_to_regs(void)
117 {
118 }
119
120 static inline void regs_to_env(void)
121 {
122 }
123
124 #endif