3 #include "qemu-timer.h"
7 void cpu_save(QEMUFile
*f
, void *opaque
)
9 CPUState
*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_FPREGS
; i
++) {
30 qemu_put_be32(f
, u
.i
);
33 qemu_put_betls(f
, &env
->pc
);
34 qemu_put_betls(f
, &env
->npc
);
35 qemu_put_betls(f
, &env
->y
);
36 tmp
= cpu_get_psr(env
);
37 qemu_put_be32(f
, tmp
);
38 qemu_put_betls(f
, &env
->fsr
);
39 qemu_put_betls(f
, &env
->tbr
);
40 tmp
= env
->interrupt_index
;
41 qemu_put_be32(f
, tmp
);
42 qemu_put_be32s(f
, &env
->pil_in
);
43 #ifndef TARGET_SPARC64
44 qemu_put_be32s(f
, &env
->wim
);
46 for (i
= 0; i
< 32; i
++)
47 qemu_put_be32s(f
, &env
->mmuregs
[i
]);
48 for (i
= 0; i
< 4; i
++) {
49 qemu_put_be64s(f
, &env
->mxccdata
[i
]);
51 for (i
= 0; i
< 8; i
++) {
52 qemu_put_be64s(f
, &env
->mxccregs
[i
]);
54 qemu_put_be32s(f
, &env
->mmubpctrv
);
55 qemu_put_be32s(f
, &env
->mmubpctrc
);
56 qemu_put_be32s(f
, &env
->mmubpctrs
);
57 qemu_put_be64s(f
, &env
->mmubpaction
);
58 for (i
= 0; i
< 4; i
++) {
59 qemu_put_be64s(f
, &env
->mmubpregs
[i
]);
62 qemu_put_be64s(f
, &env
->lsu
);
63 for (i
= 0; i
< 16; i
++) {
64 qemu_put_be64s(f
, &env
->immuregs
[i
]);
65 qemu_put_be64s(f
, &env
->dmmuregs
[i
]);
67 for (i
= 0; i
< 64; i
++) {
68 qemu_put_be64s(f
, &env
->itlb
[i
].tag
);
69 qemu_put_be64s(f
, &env
->itlb
[i
].tte
);
70 qemu_put_be64s(f
, &env
->dtlb
[i
].tag
);
71 qemu_put_be64s(f
, &env
->dtlb
[i
].tte
);
73 qemu_put_be32s(f
, &env
->mmu_version
);
74 for (i
= 0; i
< MAXTL_MAX
; i
++) {
75 qemu_put_be64s(f
, &env
->ts
[i
].tpc
);
76 qemu_put_be64s(f
, &env
->ts
[i
].tnpc
);
77 qemu_put_be64s(f
, &env
->ts
[i
].tstate
);
78 qemu_put_be32s(f
, &env
->ts
[i
].tt
);
80 qemu_put_be32s(f
, &env
->xcc
);
81 qemu_put_be32s(f
, &env
->asi
);
82 qemu_put_be32s(f
, &env
->pstate
);
83 qemu_put_be32s(f
, &env
->tl
);
84 qemu_put_be32s(f
, &env
->cansave
);
85 qemu_put_be32s(f
, &env
->canrestore
);
86 qemu_put_be32s(f
, &env
->otherwin
);
87 qemu_put_be32s(f
, &env
->wstate
);
88 qemu_put_be32s(f
, &env
->cleanwin
);
89 for (i
= 0; i
< 8; i
++)
90 qemu_put_be64s(f
, &env
->agregs
[i
]);
91 for (i
= 0; i
< 8; i
++)
92 qemu_put_be64s(f
, &env
->bgregs
[i
]);
93 for (i
= 0; i
< 8; i
++)
94 qemu_put_be64s(f
, &env
->igregs
[i
]);
95 for (i
= 0; i
< 8; i
++)
96 qemu_put_be64s(f
, &env
->mgregs
[i
]);
97 qemu_put_be64s(f
, &env
->fprs
);
98 qemu_put_be64s(f
, &env
->tick_cmpr
);
99 qemu_put_be64s(f
, &env
->stick_cmpr
);
100 cpu_put_timer(f
, env
->tick
);
101 cpu_put_timer(f
, env
->stick
);
102 qemu_put_be64s(f
, &env
->gsr
);
103 qemu_put_be32s(f
, &env
->gl
);
104 qemu_put_be64s(f
, &env
->hpstate
);
105 for (i
= 0; i
< MAXTL_MAX
; i
++)
106 qemu_put_be64s(f
, &env
->htstate
[i
]);
107 qemu_put_be64s(f
, &env
->hintp
);
108 qemu_put_be64s(f
, &env
->htba
);
109 qemu_put_be64s(f
, &env
->hver
);
110 qemu_put_be64s(f
, &env
->hstick_cmpr
);
111 qemu_put_be64s(f
, &env
->ssr
);
112 cpu_put_timer(f
, env
->hstick
);
116 int cpu_load(QEMUFile
*f
, void *opaque
, int version_id
)
118 CPUState
*env
= opaque
;
124 for(i
= 0; i
< 8; i
++)
125 qemu_get_betls(f
, &env
->gregs
[i
]);
126 qemu_get_be32s(f
, &env
->nwindows
);
127 for(i
= 0; i
< env
->nwindows
* 16; i
++)
128 qemu_get_betls(f
, &env
->regbase
[i
]);
131 for(i
= 0; i
< TARGET_FPREGS
; i
++) {
136 u
.i
= qemu_get_be32(f
);
140 qemu_get_betls(f
, &env
->pc
);
141 qemu_get_betls(f
, &env
->npc
);
142 qemu_get_betls(f
, &env
->y
);
143 tmp
= qemu_get_be32(f
);
144 env
->cwp
= 0; /* needed to ensure that the wrapping registers are
146 cpu_put_psr(env
, tmp
);
147 qemu_get_betls(f
, &env
->fsr
);
148 qemu_get_betls(f
, &env
->tbr
);
149 tmp
= qemu_get_be32(f
);
150 env
->interrupt_index
= tmp
;
151 qemu_get_be32s(f
, &env
->pil_in
);
152 #ifndef TARGET_SPARC64
153 qemu_get_be32s(f
, &env
->wim
);
155 for (i
= 0; i
< 32; i
++)
156 qemu_get_be32s(f
, &env
->mmuregs
[i
]);
157 for (i
= 0; i
< 4; i
++) {
158 qemu_get_be64s(f
, &env
->mxccdata
[i
]);
160 for (i
= 0; i
< 8; i
++) {
161 qemu_get_be64s(f
, &env
->mxccregs
[i
]);
163 qemu_get_be32s(f
, &env
->mmubpctrv
);
164 qemu_get_be32s(f
, &env
->mmubpctrc
);
165 qemu_get_be32s(f
, &env
->mmubpctrs
);
166 qemu_get_be64s(f
, &env
->mmubpaction
);
167 for (i
= 0; i
< 4; i
++) {
168 qemu_get_be64s(f
, &env
->mmubpregs
[i
]);
171 qemu_get_be64s(f
, &env
->lsu
);
172 for (i
= 0; i
< 16; i
++) {
173 qemu_get_be64s(f
, &env
->immuregs
[i
]);
174 qemu_get_be64s(f
, &env
->dmmuregs
[i
]);
176 for (i
= 0; i
< 64; i
++) {
177 qemu_get_be64s(f
, &env
->itlb
[i
].tag
);
178 qemu_get_be64s(f
, &env
->itlb
[i
].tte
);
179 qemu_get_be64s(f
, &env
->dtlb
[i
].tag
);
180 qemu_get_be64s(f
, &env
->dtlb
[i
].tte
);
182 qemu_get_be32s(f
, &env
->mmu_version
);
183 for (i
= 0; i
< MAXTL_MAX
; i
++) {
184 qemu_get_be64s(f
, &env
->ts
[i
].tpc
);
185 qemu_get_be64s(f
, &env
->ts
[i
].tnpc
);
186 qemu_get_be64s(f
, &env
->ts
[i
].tstate
);
187 qemu_get_be32s(f
, &env
->ts
[i
].tt
);
189 qemu_get_be32s(f
, &env
->xcc
);
190 qemu_get_be32s(f
, &env
->asi
);
191 qemu_get_be32s(f
, &env
->pstate
);
192 qemu_get_be32s(f
, &env
->tl
);
193 qemu_get_be32s(f
, &env
->cansave
);
194 qemu_get_be32s(f
, &env
->canrestore
);
195 qemu_get_be32s(f
, &env
->otherwin
);
196 qemu_get_be32s(f
, &env
->wstate
);
197 qemu_get_be32s(f
, &env
->cleanwin
);
198 for (i
= 0; i
< 8; i
++)
199 qemu_get_be64s(f
, &env
->agregs
[i
]);
200 for (i
= 0; i
< 8; i
++)
201 qemu_get_be64s(f
, &env
->bgregs
[i
]);
202 for (i
= 0; i
< 8; i
++)
203 qemu_get_be64s(f
, &env
->igregs
[i
]);
204 for (i
= 0; i
< 8; i
++)
205 qemu_get_be64s(f
, &env
->mgregs
[i
]);
206 qemu_get_be64s(f
, &env
->fprs
);
207 qemu_get_be64s(f
, &env
->tick_cmpr
);
208 qemu_get_be64s(f
, &env
->stick_cmpr
);
209 cpu_get_timer(f
, env
->tick
);
210 cpu_get_timer(f
, env
->stick
);
211 qemu_get_be64s(f
, &env
->gsr
);
212 qemu_get_be32s(f
, &env
->gl
);
213 qemu_get_be64s(f
, &env
->hpstate
);
214 for (i
= 0; i
< MAXTL_MAX
; i
++)
215 qemu_get_be64s(f
, &env
->htstate
[i
]);
216 qemu_get_be64s(f
, &env
->hintp
);
217 qemu_get_be64s(f
, &env
->htba
);
218 qemu_get_be64s(f
, &env
->hver
);
219 qemu_get_be64s(f
, &env
->hstick_cmpr
);
220 qemu_get_be64s(f
, &env
->ssr
);
221 cpu_get_timer(f
, env
->hstick
);