]> git.proxmox.com Git - qemu.git/blame - target-sparc/exec.h
full system SPARC emulation (Blue Swirl)
[qemu.git] / target-sparc / exec.h
CommitLineData
7a3f1944
FB
1#ifndef EXEC_SPARC_H
2#define EXEC_SPARC_H 1
3#include "dyngen-exec.h"
4
5register struct CPUSPARCState *env asm(AREG0);
6register uint32_t T0 asm(AREG1);
7register uint32_t T1 asm(AREG2);
8register uint32_t T2 asm(AREG3);
e8af50a3
FB
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)
7a3f1944
FB
15
16#include "cpu.h"
17#include "exec-all.h"
18
19void cpu_lock(void);
20void cpu_unlock(void);
21void cpu_loop_exit(void);
658138bc 22void helper_flush(target_ulong addr);
e8af50a3
FB
23void helper_ld_asi(int asi, int size, int sign);
24void helper_st_asi(int asi, int size, int sign);
25void helper_rett(void);
26void helper_stfsr(void);
27void set_cwp(int new_cwp);
28void do_fabss(void);
29void do_fsqrts(void);
30void do_fsqrtd(void);
31void do_fcmps(void);
32void do_fcmpd(void);
33void do_interrupt(int intno, int is_int, int error_code,
34 unsigned int next_eip, int is_hw);
35void raise_exception_err(int exception_index, int error_code);
36void raise_exception(int tt);
37void memcpy32(uint32_t *dst, const uint32_t *src);
38
39/* XXX: move that to a generic header */
40#if !defined(CONFIG_USER_ONLY)
41
42#define ldul_user ldl_user
43#define ldul_kernel ldl_kernel
44
45#define ACCESS_TYPE 0
46#define MEMSUFFIX _kernel
47#define DATA_SIZE 1
48#include "softmmu_header.h"
49
50#define DATA_SIZE 2
51#include "softmmu_header.h"
52
53#define DATA_SIZE 4
54#include "softmmu_header.h"
55
56#define DATA_SIZE 8
57#include "softmmu_header.h"
58#undef ACCESS_TYPE
59#undef MEMSUFFIX
60
61#define ACCESS_TYPE 1
62#define MEMSUFFIX _user
63#define DATA_SIZE 1
64#include "softmmu_header.h"
65
66#define DATA_SIZE 2
67#include "softmmu_header.h"
68
69#define DATA_SIZE 4
70#include "softmmu_header.h"
71
72#define DATA_SIZE 8
73#include "softmmu_header.h"
74#undef ACCESS_TYPE
75#undef MEMSUFFIX
76
77/* these access are slower, they must be as rare as possible */
78#define ACCESS_TYPE 2
79#define MEMSUFFIX _data
80#define DATA_SIZE 1
81#include "softmmu_header.h"
82
83#define DATA_SIZE 2
84#include "softmmu_header.h"
85
86#define DATA_SIZE 4
87#include "softmmu_header.h"
88
89#define DATA_SIZE 8
90#include "softmmu_header.h"
91#undef ACCESS_TYPE
92#undef MEMSUFFIX
93
94#define ldub(p) ldub_data(p)
95#define ldsb(p) ldsb_data(p)
96#define lduw(p) lduw_data(p)
97#define ldsw(p) ldsw_data(p)
98#define ldl(p) ldl_data(p)
99#define ldq(p) ldq_data(p)
100
101#define stb(p, v) stb_data(p, v)
102#define stw(p, v) stw_data(p, v)
103#define stl(p, v) stl_data(p, v)
104#define stq(p, v) stq_data(p, v)
105
106#endif /* !defined(CONFIG_USER_ONLY) */
7a3f1944 107#endif