]> git.proxmox.com Git - qemu.git/blob - target-sparc/cpu.h
monitor fixes
[qemu.git] / target-sparc / cpu.h
1 #ifndef CPU_SPARC_H
2 #define CPU_SPARC_H
3
4 #define TARGET_LONG_BITS 32
5
6 #include "cpu-defs.h"
7
8 /*#define EXCP_INTERRUPT 0x100*/
9
10 /* trap definitions */
11 #define TT_ILL_INSN 0x02
12 #define TT_PRIV_INSN 0x03
13 #define TT_WIN_OVF 0x05
14 #define TT_WIN_UNF 0x06
15 #define TT_FP_EXCP 0x08
16 #define TT_DIV_ZERO 0x2a
17 #define TT_TRAP 0x80
18
19 #define PSR_NEG (1<<23)
20 #define PSR_ZERO (1<<22)
21 #define PSR_OVF (1<<21)
22 #define PSR_CARRY (1<<20)
23 #define PSR_ICC (PSR_NEG|PSR_ZERO|PSR_OVF|PSR_CARRY)
24 #define PSR_S (1<<7)
25 #define PSR_PS (1<<6)
26 #define PSR_ET (1<<5)
27 #define PSR_CWP 0x1f
28 /* Fake impl 0, version 4 */
29 #define GET_PSR(env) ((0<<28) | (4<<24) | env->psr | (env->psrs? PSR_S : 0) | (env->psrs? PSR_PS : 0) |(env->psret? PSR_ET : 0) | env->cwp)
30
31 /* Trap base register */
32 #define TBR_BASE_MASK 0xfffff000
33
34 /* Fcc */
35 #define FSR_RD1 (1<<31)
36 #define FSR_RD0 (1<<30)
37 #define FSR_RD_MASK (FSR_RD1 | FSR_RD0)
38 #define FSR_RD_NEAREST 0
39 #define FSR_RD_ZERO FSR_RD0
40 #define FSR_RD_POS FSR_RD1
41 #define FSR_RD_NEG (FSR_RD1 | FSR_RD0)
42
43 #define FSR_NVM (1<<27)
44 #define FSR_OFM (1<<26)
45 #define FSR_UFM (1<<25)
46 #define FSR_DZM (1<<24)
47 #define FSR_NXM (1<<23)
48 #define FSR_TEM_MASK (FSR_NVM | FSR_OFM | FSR_UFM | FSR_DZM | FSR_NXM)
49
50 #define FSR_NVA (1<<9)
51 #define FSR_OFA (1<<8)
52 #define FSR_UFA (1<<7)
53 #define FSR_DZA (1<<6)
54 #define FSR_NXA (1<<5)
55 #define FSR_AEXC_MASK (FSR_NVA | FSR_OFA | FSR_UFA | FSR_DZA | FSR_NXA)
56
57 #define FSR_NVC (1<<4)
58 #define FSR_OFC (1<<3)
59 #define FSR_UFC (1<<2)
60 #define FSR_DZC (1<<1)
61 #define FSR_NXC (1<<0)
62 #define FSR_CEXC_MASK (FSR_NVC | FSR_OFC | FSR_UFC | FSR_DZC | FSR_NXC)
63
64 #define FSR_FTT2 (1<<16)
65 #define FSR_FTT1 (1<<15)
66 #define FSR_FTT0 (1<<14)
67 #define FSR_FTT_MASK (FSR_FTT2 | FSR_FTT1 | FSR_FTT0)
68
69 #define FSR_FCC1 (1<<11)
70 #define FSR_FCC0 (1<<10)
71
72 /* MMU */
73 #define MMU_E (1<<0)
74 #define MMU_NF (1<<1)
75
76 #define PTE_ENTRYTYPE_MASK 3
77 #define PTE_ACCESS_MASK 0x1c
78 #define PTE_ACCESS_SHIFT 2
79 #define PTE_PPN_SHIFT 7
80 #define PTE_ADDR_MASK 0xffffff00
81
82 #define PG_ACCESSED_BIT 5
83 #define PG_MODIFIED_BIT 6
84 #define PG_CACHE_BIT 7
85
86 #define PG_ACCESSED_MASK (1 << PG_ACCESSED_BIT)
87 #define PG_MODIFIED_MASK (1 << PG_MODIFIED_BIT)
88 #define PG_CACHE_MASK (1 << PG_CACHE_BIT)
89
90 #define NWINDOWS 32
91
92 typedef struct CPUSPARCState {
93 uint32_t gregs[8]; /* general registers */
94 uint32_t *regwptr; /* pointer to current register window */
95 float fpr[32]; /* floating point registers */
96 uint32_t pc; /* program counter */
97 uint32_t npc; /* next program counter */
98 uint32_t y; /* multiply/divide register */
99 uint32_t psr; /* processor state register */
100 uint32_t fsr; /* FPU state register */
101 uint32_t T2;
102 uint32_t cwp; /* index of current register window (extracted
103 from PSR) */
104 uint32_t wim; /* window invalid mask */
105 uint32_t tbr; /* trap base register */
106 int psrs; /* supervisor mode (extracted from PSR) */
107 int psrps; /* previous supervisor mode */
108 int psret; /* enable traps */
109 jmp_buf jmp_env;
110 int user_mode_only;
111 int exception_index;
112 int interrupt_index;
113 int interrupt_request;
114 uint32_t exception_next_pc;
115 struct TranslationBlock *current_tb;
116 void *opaque;
117 /* NOTE: we allow 8 more registers to handle wrapping */
118 uint32_t regbase[NWINDOWS * 16 + 8];
119
120 /* in order to avoid passing too many arguments to the memory
121 write helpers, we store some rarely used information in the CPU
122 context) */
123 unsigned long mem_write_pc; /* host pc at which the memory was
124 written */
125 unsigned long mem_write_vaddr; /* target virtual addr at which the
126 memory was written */
127 /* 0 = kernel, 1 = user (may have 2 = kernel code, 3 = user code ?) */
128 CPUTLBEntry tlb_read[2][CPU_TLB_SIZE];
129 CPUTLBEntry tlb_write[2][CPU_TLB_SIZE];
130 int error_code;
131 /* MMU regs */
132 uint32_t mmuregs[16];
133 /* temporary float registers */
134 float ft0, ft1, ft2;
135 double dt0, dt1, dt2;
136
137 /* ice debug support */
138 uint32_t breakpoints[MAX_BREAKPOINTS];
139 int nb_breakpoints;
140 int singlestep_enabled; /* XXX: should use CPU single step mode instead */
141
142 } CPUSPARCState;
143
144 CPUSPARCState *cpu_sparc_init(void);
145 int cpu_sparc_exec(CPUSPARCState *s);
146 int cpu_sparc_close(CPUSPARCState *s);
147
148 struct siginfo;
149 int cpu_sparc_signal_handler(int hostsignum, struct siginfo *info, void *puc);
150
151 #define TARGET_PAGE_BITS 12 /* 4k */
152 #include "cpu-all.h"
153
154 #endif