提交 7107e5a7 编写于 作者: A Aurelien Jarno 提交者: Alexander Graf

target-s390x: correctly initialize ext interrupt queue

env->ext_index should be initialized to -1 to mark the external
interrupt queue as emtpy. This should not be done in s390_cpu_initfn
as all the interrupt fields are later reset to 0 by the memset in
s390_cpu_initial_reset or s390_cpu_full_reset. Move the initialization
there.
Signed-off-by: NAurelien Jarno <aurelien@aurel32.net>
Signed-off-by: NAlexander Graf <agraf@suse.de>
上级 06e3c077
...@@ -117,6 +117,7 @@ static void s390_cpu_initial_reset(CPUState *s) ...@@ -117,6 +117,7 @@ static void s390_cpu_initial_reset(CPUState *s)
env->cregs[14] = CR14_RESET; env->cregs[14] = CR14_RESET;
env->pfault_token = -1UL; env->pfault_token = -1UL;
env->ext_index = -1;
/* tininess for underflow is detected before rounding */ /* tininess for underflow is detected before rounding */
set_float_detect_tininess(float_tininess_before_rounding, set_float_detect_tininess(float_tininess_before_rounding,
...@@ -146,6 +147,7 @@ static void s390_cpu_full_reset(CPUState *s) ...@@ -146,6 +147,7 @@ static void s390_cpu_full_reset(CPUState *s)
env->cregs[14] = CR14_RESET; env->cregs[14] = CR14_RESET;
env->pfault_token = -1UL; env->pfault_token = -1UL;
env->ext_index = -1;
/* tininess for underflow is detected before rounding */ /* tininess for underflow is detected before rounding */
set_float_detect_tininess(float_tininess_before_rounding, set_float_detect_tininess(float_tininess_before_rounding,
...@@ -207,7 +209,6 @@ static void s390_cpu_initfn(Object *obj) ...@@ -207,7 +209,6 @@ static void s390_cpu_initfn(Object *obj)
s390_cpu_set_state(CPU_STATE_STOPPED, cpu); s390_cpu_set_state(CPU_STATE_STOPPED, cpu);
#endif #endif
env->cpu_num = cpu_num++; env->cpu_num = cpu_num++;
env->ext_index = -1;
if (tcg_enabled() && !inited) { if (tcg_enabled() && !inited) {
inited = true; inited = true;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册