1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21#ifndef CPU_CRIS_H
22#define CPU_CRIS_H
23
24#define TARGET_LONG_BITS 32
25
26#include "cpu-defs.h"
27
28#define TARGET_HAS_ICE 1
29
30#define ELF_MACHINE EM_CRIS
31
32#define EXCP_NMI 1
33#define EXCP_GURU 2
34#define EXCP_BUSFAULT 3
35#define EXCP_IRQ 4
36#define EXCP_BREAK 5
37
38
39#define R_FP 8
40#define R_SP 14
41#define R_ACR 15
42
43
44#define PR_BZ 0
45#define PR_VR 1
46#define PR_PID 2
47#define PR_SRS 3
48#define PR_WZ 4
49#define PR_EXS 5
50#define PR_EDA 6
51#define PR_MOF 7
52#define PR_DZ 8
53#define PR_EBP 9
54#define PR_ERP 10
55#define PR_SRP 11
56#define PR_NRP 12
57#define PR_CCS 13
58#define PR_USP 14
59#define PR_SPC 15
60
61
62#define Q_FLAG 0x80000000
63#define M_FLAG 0x40000000
64#define S_FLAG 0x200
65#define R_FLAG 0x100
66#define P_FLAG 0x80
67#define U_FLAG 0x40
68#define P_FLAG 0x80
69#define U_FLAG 0x40
70#define I_FLAG 0x20
71#define X_FLAG 0x10
72#define N_FLAG 0x08
73#define Z_FLAG 0x04
74#define V_FLAG 0x02
75#define C_FLAG 0x01
76#define ALU_FLAGS 0x1F
77
78
79#define CC_CC 0
80#define CC_CS 1
81#define CC_NE 2
82#define CC_EQ 3
83#define CC_VC 4
84#define CC_VS 5
85#define CC_PL 6
86#define CC_MI 7
87#define CC_LS 8
88#define CC_HI 9
89#define CC_GE 10
90#define CC_LT 11
91#define CC_GT 12
92#define CC_LE 13
93#define CC_A 14
94#define CC_P 15
95
96
97#define F_DELAYSLOT 1
98
99#define NB_MMU_MODES 2
100
101typedef struct CPUCRISState {
102 uint32_t regs[16];
103
104 uint32_t pregs[16];
105
106
107 uint32_t pc;
108
109
110 uint32_t ksp;
111
112
113 int dslot;
114 int btaken;
115 uint32_t btarget;
116
117
118 uint32_t cc_op;
119 uint32_t cc_mask;
120 uint32_t cc_dest;
121 uint32_t cc_src;
122 uint32_t cc_result;
123
124 int cc_size;
125
126 int cc_x;
127
128 int interrupt_vector;
129 int fault_vector;
130 int trap_vector;
131
132
133
134
135
136
137
138
139 uint32_t sregs[4][16];
140
141
142
143
144 uint32_t mmu_rand_lfsr;
145
146
147
148
149
150
151
152 struct
153 {
154 uint32_t hi;
155 uint32_t lo;
156 } tlbsets[2][4][16];
157
158 CPU_COMMON
159} CPUCRISState;
160
161CPUCRISState *cpu_cris_init(const char *cpu_model);
162int cpu_cris_exec(CPUCRISState *s);
163void cpu_cris_close(CPUCRISState *s);
164void do_interrupt(CPUCRISState *env);
165
166
167
168int cpu_cris_signal_handler(int host_signum, void *pinfo,
169 void *puc);
170
171enum {
172 CC_OP_DYNAMIC,
173 CC_OP_FLAGS,
174 CC_OP_CMP,
175 CC_OP_MOVE,
176 CC_OP_ADD,
177 CC_OP_ADDC,
178 CC_OP_MCP,
179 CC_OP_ADDU,
180 CC_OP_SUB,
181 CC_OP_SUBU,
182 CC_OP_NEG,
183 CC_OP_BTST,
184 CC_OP_MULS,
185 CC_OP_MULU,
186 CC_OP_DSTEP,
187 CC_OP_BOUND,
188
189 CC_OP_OR,
190 CC_OP_AND,
191 CC_OP_XOR,
192 CC_OP_LSL,
193 CC_OP_LSR,
194 CC_OP_ASR,
195 CC_OP_LZ
196};
197
198
199#define TARGET_PAGE_BITS 13
200#define MMAP_SHIFT TARGET_PAGE_BITS
201
202#define CPUState CPUCRISState
203#define cpu_init cpu_cris_init
204#define cpu_exec cpu_cris_exec
205#define cpu_gen_code cpu_cris_gen_code
206#define cpu_signal_handler cpu_cris_signal_handler
207
208#define CPU_SAVE_VERSION 1
209
210
211#define MMU_MODE0_SUFFIX _kernel
212#define MMU_MODE1_SUFFIX _user
213#define MMU_USER_IDX 1
214static inline int cpu_mmu_index (CPUState *env)
215{
216 return !!(env->pregs[PR_CCS] & U_FLAG);
217}
218
219int cpu_cris_handle_mmu_fault(CPUState *env, target_ulong address, int rw,
220 int mmu_idx, int is_softmmu);
221
222#if defined(CONFIG_USER_ONLY)
223static inline void cpu_clone_regs(CPUState *env, target_ulong newsp)
224{
225 if (newsp)
226 env->regs[14] = newsp;
227 env->regs[10] = 0;
228}
229#endif
230
231static inline void cpu_set_tls(CPUCRISState *env, target_ulong newtls)
232{
233 env->pregs[PR_PID] = (env->pregs[PR_PID] & 0xff) | newtls;
234}
235
236
237#define SFR_RW_GC_CFG 0][0
238#define SFR_RW_MM_CFG env->pregs[PR_SRS]][0
239#define SFR_RW_MM_KBASE_LO env->pregs[PR_SRS]][1
240#define SFR_RW_MM_KBASE_HI env->pregs[PR_SRS]][2
241#define SFR_R_MM_CAUSE env->pregs[PR_SRS]][3
242#define SFR_RW_MM_TLB_SEL env->pregs[PR_SRS]][4
243#define SFR_RW_MM_TLB_LO env->pregs[PR_SRS]][5
244#define SFR_RW_MM_TLB_HI env->pregs[PR_SRS]][6
245
246#include "cpu-all.h"
247#include "exec-all.h"
248
249static inline void cpu_pc_from_tb(CPUState *env, TranslationBlock *tb)
250{
251 env->pc = tb->pc;
252}
253
254static inline void cpu_get_tb_cpu_state(CPUState *env, target_ulong *pc,
255 target_ulong *cs_base, int *flags)
256{
257 *pc = env->pc;
258 *cs_base = 0;
259 *flags = env->dslot |
260 (env->pregs[PR_CCS] & (S_FLAG | P_FLAG | U_FLAG | X_FLAG));
261}
262
263#endif
264