[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [4980] Handle wrapped registers correctly when saving
From: |
Blue Swirl |
Subject: |
[Qemu-devel] [4980] Handle wrapped registers correctly when saving |
Date: |
Fri, 01 Aug 2008 15:13:59 +0000 |
Revision: 4980
http://svn.sv.gnu.org/viewvc/?view=rev&root=qemu&revision=4980
Author: blueswir1
Date: 2008-08-01 15:13:58 +0000 (Fri, 01 Aug 2008)
Log Message:
-----------
Handle wrapped registers correctly when saving
Fix typo
Save and load interrupt_index and pil_in
Original patch by Luis Pureza
Modified Paths:
--------------
trunk/target-sparc/machine.c
Modified: trunk/target-sparc/machine.c
===================================================================
--- trunk/target-sparc/machine.c 2008-08-01 15:12:34 UTC (rev 4979)
+++ trunk/target-sparc/machine.c 2008-08-01 15:13:58 UTC (rev 4980)
@@ -31,6 +31,10 @@
int i;
uint32_t tmp;
+ // if env->cwp == env->nwindows - 1, this will set the ins of the last
+ // window as the outs of the first window
+ cpu_set_cwp(env, env->cwp);
+
for(i = 0; i < 8; i++)
qemu_put_betls(f, &env->gregs[i]);
qemu_put_be32s(f, &env->nwindows);
@@ -54,6 +58,9 @@
qemu_put_be32(f, tmp);
qemu_put_betls(f, &env->fsr);
qemu_put_betls(f, &env->tbr);
+ tmp = env->interrupt_index;
+ qemu_put_be32(f, tmp);
+ qemu_put_be32s(f, &env->pil_in);
#ifndef TARGET_SPARC64
qemu_put_be32s(f, &env->wim);
/* MMU */
@@ -110,7 +117,7 @@
qemu_put_be64s(f, &env->hver);
qemu_put_be64s(f, &env->hstick_cmpr);
qemu_put_be64s(f, &env->ssr);
- qemu_get_ptimer(f, env->hstick);
+ qemu_put_ptimer(f, env->hstick);
#endif
}
@@ -147,6 +154,9 @@
PUT_PSR(env, tmp);
qemu_get_betls(f, &env->fsr);
qemu_get_betls(f, &env->tbr);
+ tmp = qemu_get_be32(f);
+ env->interrupt_index = tmp;
+ qemu_get_be32s(f, &env->pil_in);
#ifndef TARGET_SPARC64
qemu_get_be32s(f, &env->wim);
/* MMU */
[Prev in Thread] |
Current Thread |
[Next in Thread] |
- [Qemu-devel] [4980] Handle wrapped registers correctly when saving,
Blue Swirl <=