Statistics
| Branch: | Revision:

root / target-sparc / exec.h @ 157777ef

History | View | Annotate | Download (2.8 kB)

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