|
@@ -413,7 +413,11 @@ static void save_window(CPUSPARCState *env)
|
|
save_window_offset(env, cpu_cwp_dec(env, env->cwp - 2));
|
|
save_window_offset(env, cpu_cwp_dec(env, env->cwp - 2));
|
|
env->wim = new_wim;
|
|
env->wim = new_wim;
|
|
#else
|
|
#else
|
|
- save_window_offset(env, cpu_cwp_dec(env, env->cwp - 2));
|
|
|
|
|
|
+ /*
|
|
|
|
+ * cansave is zero if the spill trap handler is triggered by `save` and
|
|
|
|
+ * nonzero if triggered by a `flushw`
|
|
|
|
+ */
|
|
|
|
+ save_window_offset(env, cpu_cwp_dec(env, env->cwp - env->cansave - 2));
|
|
env->cansave++;
|
|
env->cansave++;
|
|
env->canrestore--;
|
|
env->canrestore--;
|
|
#endif
|
|
#endif
|