Let's stop the timer and delete any pending CKC IRQ before doing anything else.
Signed-off-by: David Hildenbrand <da...@redhat.com> --- target/s390x/misc_helper.c | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/target/s390x/misc_helper.c b/target/s390x/misc_helper.c index 6ccbe1fe9a..d5f9f5e1d3 100644 --- a/target/s390x/misc_helper.c +++ b/target/s390x/misc_helper.c @@ -158,6 +158,12 @@ void HELPER(sckc)(CPUS390XState *env, uint64_t time) Error *err = NULL; S390TOD tod_base; + /* stop the timer and remove pending CKC IRQs */ + timer_del(env->tod_timer); + qemu_mutex_lock_iothread(); + env->pending_int &= ~INTERRUPT_EXT_CLOCK_COMPARATOR; + qemu_mutex_unlock_iothread(); + if (time == -1ULL) { return; } -- 2.17.1