On 21.06.2018 15:58, Cornelia Huck wrote: > On Thu, 21 Jun 2018 14:09:28 +0200 > Thomas Huth <th...@redhat.com> wrote: > >> On 20.06.2018 12:08, David Hildenbrand wrote: >>> 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(); >> >> Reviewed-by: Thomas Huth <th...@redhat.com> >> >>> if (time == -1ULL) { >> >> I wonder whether that check is still adequate? Is there really a way to >> disable the clock comparator like this? At least I haven't seen it in >> the PoP. > > Me neither. It seems to have been in the code since the beginning...
I agree that this is somewhat buried deep down in the PoP and not obvious when only looking at SET CLOCK COMPARATOR documentation. I'll add a comment like "we can never exceed -1 and therefore never trigger an IRQ" -- Thanks, David / dhildenb