3 #include "qemu/timer.h"
7 void cpu_save(QEMUFile
*f
, void *opaque
)
9 CPUSPARCState
*env
= opaque
;
13 // if env->cwp == env->nwindows - 1, this will set the ins of the last
14 // window as the outs of the first window
15 cpu_set_cwp(env
, env
->cwp
);
17 for(i
= 0; i
< 8; i
++)
18 qemu_put_betls(f
, &env
->gregs
[i
]);
19 qemu_put_be32s(f
, &env
->nwindows
);
20 for(i
= 0; i
< env
->nwindows
* 16; i
++)
21 qemu_put_betls(f
, &env
->regbase
[i
]);
24 for (i
= 0; i
< TARGET_DPREGS
; i
++) {
25 qemu_put_be32(f
, env
->fpr
[i
].l
.upper
);
26 qemu_put_be32(f
, env
->fpr
[i
].l
.lower
);
29 qemu_put_betls(f
, &env
->pc
);
30 qemu_put_betls(f
, &env
->npc
);
31 qemu_put_betls(f
, &env
->y
);
32 tmp
= cpu_get_psr(env
);
33 qemu_put_be32(f
, tmp
);
34 qemu_put_betls(f
, &env
->fsr
);
35 qemu_put_betls(f
, &env
->tbr
);
36 tmp
= env
->interrupt_index
;
37 qemu_put_be32(f
, tmp
);
38 qemu_put_be32s(f
, &env
->pil_in
);
39 #ifndef TARGET_SPARC64
40 qemu_put_be32s(f
, &env
->wim
);
42 for (i
= 0; i
< 32; i
++)
43 qemu_put_be32s(f
, &env
->mmuregs
[i
]);
44 for (i
= 0; i
< 4; i
++) {
45 qemu_put_be64s(f
, &env
->mxccdata
[i
]);
47 for (i
= 0; i
< 8; i
++) {
48 qemu_put_be64s(f
, &env
->mxccregs
[i
]);
50 qemu_put_be32s(f
, &env
->mmubpctrv
);
51 qemu_put_be32s(f
, &env
->mmubpctrc
);
52 qemu_put_be32s(f
, &env
->mmubpctrs
);
53 qemu_put_be64s(f
, &env
->mmubpaction
);
54 for (i
= 0; i
< 4; i
++) {
55 qemu_put_be64s(f
, &env
->mmubpregs
[i
]);
58 qemu_put_be64s(f
, &env
->lsu
);
59 for (i
= 0; i
< 16; i
++) {
60 qemu_put_be64s(f
, &env
->immuregs
[i
]);
61 qemu_put_be64s(f
, &env
->dmmuregs
[i
]);
63 for (i
= 0; i
< 64; i
++) {
64 qemu_put_be64s(f
, &env
->itlb
[i
].tag
);
65 qemu_put_be64s(f
, &env
->itlb
[i
].tte
);
66 qemu_put_be64s(f
, &env
->dtlb
[i
].tag
);
67 qemu_put_be64s(f
, &env
->dtlb
[i
].tte
);
69 qemu_put_be32s(f
, &env
->mmu_version
);
70 for (i
= 0; i
< MAXTL_MAX
; i
++) {
71 qemu_put_be64s(f
, &env
->ts
[i
].tpc
);
72 qemu_put_be64s(f
, &env
->ts
[i
].tnpc
);
73 qemu_put_be64s(f
, &env
->ts
[i
].tstate
);
74 qemu_put_be32s(f
, &env
->ts
[i
].tt
);
76 qemu_put_be32s(f
, &env
->xcc
);
77 qemu_put_be32s(f
, &env
->asi
);
78 qemu_put_be32s(f
, &env
->pstate
);
79 qemu_put_be32s(f
, &env
->tl
);
80 qemu_put_be32s(f
, &env
->cansave
);
81 qemu_put_be32s(f
, &env
->canrestore
);
82 qemu_put_be32s(f
, &env
->otherwin
);
83 qemu_put_be32s(f
, &env
->wstate
);
84 qemu_put_be32s(f
, &env
->cleanwin
);
85 for (i
= 0; i
< 8; i
++)
86 qemu_put_be64s(f
, &env
->agregs
[i
]);
87 for (i
= 0; i
< 8; i
++)
88 qemu_put_be64s(f
, &env
->bgregs
[i
]);
89 for (i
= 0; i
< 8; i
++)
90 qemu_put_be64s(f
, &env
->igregs
[i
]);
91 for (i
= 0; i
< 8; i
++)
92 qemu_put_be64s(f
, &env
->mgregs
[i
]);
93 qemu_put_be64s(f
, &env
->fprs
);
94 qemu_put_be64s(f
, &env
->tick_cmpr
);
95 qemu_put_be64s(f
, &env
->stick_cmpr
);
96 cpu_put_timer(f
, env
->tick
);
97 cpu_put_timer(f
, env
->stick
);
98 qemu_put_be64s(f
, &env
->gsr
);
99 qemu_put_be32s(f
, &env
->gl
);
100 qemu_put_be64s(f
, &env
->hpstate
);
101 for (i
= 0; i
< MAXTL_MAX
; i
++)
102 qemu_put_be64s(f
, &env
->htstate
[i
]);
103 qemu_put_be64s(f
, &env
->hintp
);
104 qemu_put_be64s(f
, &env
->htba
);
105 qemu_put_be64s(f
, &env
->hver
);
106 qemu_put_be64s(f
, &env
->hstick_cmpr
);
107 qemu_put_be64s(f
, &env
->ssr
);
108 cpu_put_timer(f
, env
->hstick
);
112 int cpu_load(QEMUFile
*f
, void *opaque
, int version_id
)
114 CPUSPARCState
*env
= opaque
;
115 SPARCCPU
*cpu
= sparc_env_get_cpu(env
);
121 for(i
= 0; i
< 8; i
++)
122 qemu_get_betls(f
, &env
->gregs
[i
]);
123 qemu_get_be32s(f
, &env
->nwindows
);
124 for(i
= 0; i
< env
->nwindows
* 16; i
++)
125 qemu_get_betls(f
, &env
->regbase
[i
]);
128 for (i
= 0; i
< TARGET_DPREGS
; i
++) {
129 env
->fpr
[i
].l
.upper
= qemu_get_be32(f
);
130 env
->fpr
[i
].l
.lower
= qemu_get_be32(f
);
133 qemu_get_betls(f
, &env
->pc
);
134 qemu_get_betls(f
, &env
->npc
);
135 qemu_get_betls(f
, &env
->y
);
136 tmp
= qemu_get_be32(f
);
137 env
->cwp
= 0; /* needed to ensure that the wrapping registers are
139 cpu_put_psr(env
, tmp
);
140 qemu_get_betls(f
, &env
->fsr
);
141 qemu_get_betls(f
, &env
->tbr
);
142 tmp
= qemu_get_be32(f
);
143 env
->interrupt_index
= tmp
;
144 qemu_get_be32s(f
, &env
->pil_in
);
145 #ifndef TARGET_SPARC64
146 qemu_get_be32s(f
, &env
->wim
);
148 for (i
= 0; i
< 32; i
++)
149 qemu_get_be32s(f
, &env
->mmuregs
[i
]);
150 for (i
= 0; i
< 4; i
++) {
151 qemu_get_be64s(f
, &env
->mxccdata
[i
]);
153 for (i
= 0; i
< 8; i
++) {
154 qemu_get_be64s(f
, &env
->mxccregs
[i
]);
156 qemu_get_be32s(f
, &env
->mmubpctrv
);
157 qemu_get_be32s(f
, &env
->mmubpctrc
);
158 qemu_get_be32s(f
, &env
->mmubpctrs
);
159 qemu_get_be64s(f
, &env
->mmubpaction
);
160 for (i
= 0; i
< 4; i
++) {
161 qemu_get_be64s(f
, &env
->mmubpregs
[i
]);
164 qemu_get_be64s(f
, &env
->lsu
);
165 for (i
= 0; i
< 16; i
++) {
166 qemu_get_be64s(f
, &env
->immuregs
[i
]);
167 qemu_get_be64s(f
, &env
->dmmuregs
[i
]);
169 for (i
= 0; i
< 64; i
++) {
170 qemu_get_be64s(f
, &env
->itlb
[i
].tag
);
171 qemu_get_be64s(f
, &env
->itlb
[i
].tte
);
172 qemu_get_be64s(f
, &env
->dtlb
[i
].tag
);
173 qemu_get_be64s(f
, &env
->dtlb
[i
].tte
);
175 qemu_get_be32s(f
, &env
->mmu_version
);
176 for (i
= 0; i
< MAXTL_MAX
; i
++) {
177 qemu_get_be64s(f
, &env
->ts
[i
].tpc
);
178 qemu_get_be64s(f
, &env
->ts
[i
].tnpc
);
179 qemu_get_be64s(f
, &env
->ts
[i
].tstate
);
180 qemu_get_be32s(f
, &env
->ts
[i
].tt
);
182 qemu_get_be32s(f
, &env
->xcc
);
183 qemu_get_be32s(f
, &env
->asi
);
184 qemu_get_be32s(f
, &env
->pstate
);
185 qemu_get_be32s(f
, &env
->tl
);
186 qemu_get_be32s(f
, &env
->cansave
);
187 qemu_get_be32s(f
, &env
->canrestore
);
188 qemu_get_be32s(f
, &env
->otherwin
);
189 qemu_get_be32s(f
, &env
->wstate
);
190 qemu_get_be32s(f
, &env
->cleanwin
);
191 for (i
= 0; i
< 8; i
++)
192 qemu_get_be64s(f
, &env
->agregs
[i
]);
193 for (i
= 0; i
< 8; i
++)
194 qemu_get_be64s(f
, &env
->bgregs
[i
]);
195 for (i
= 0; i
< 8; i
++)
196 qemu_get_be64s(f
, &env
->igregs
[i
]);
197 for (i
= 0; i
< 8; i
++)
198 qemu_get_be64s(f
, &env
->mgregs
[i
]);
199 qemu_get_be64s(f
, &env
->fprs
);
200 qemu_get_be64s(f
, &env
->tick_cmpr
);
201 qemu_get_be64s(f
, &env
->stick_cmpr
);
202 cpu_get_timer(f
, env
->tick
);
203 cpu_get_timer(f
, env
->stick
);
204 qemu_get_be64s(f
, &env
->gsr
);
205 qemu_get_be32s(f
, &env
->gl
);
206 qemu_get_be64s(f
, &env
->hpstate
);
207 for (i
= 0; i
< MAXTL_MAX
; i
++)
208 qemu_get_be64s(f
, &env
->htstate
[i
]);
209 qemu_get_be64s(f
, &env
->hintp
);
210 qemu_get_be64s(f
, &env
->htba
);
211 qemu_get_be64s(f
, &env
->hver
);
212 qemu_get_be64s(f
, &env
->hstick_cmpr
);
213 qemu_get_be64s(f
, &env
->ssr
);
214 cpu_get_timer(f
, env
->hstick
);
216 tlb_flush(CPU(cpu
), 1);