> +++ b/kernel/time/tick-broadcast-hrtimer.c
> +/*
> + * This is called from the guts of the broadcast code when the cpu
> + * which is about to enter idle has the earliest broadcast timer event.
> + */
> +static int bc_set_next(ktime_t expires, struct clock_event_device *bc)
> +{
> +     ktime_t now, interval;
> +     /*
> +      * We try to cancel the timer first. If the callback is on
> +      * flight on some other cpu then we let it handle it. If we
> +      * were able to cancel the timer nothing can rearm it as we
> +      * own broadcast_lock.
> +      *
> +      * However if we are called from the hrtimer interrupt handler
> +      * itself, reprogram it.
> +      */
> +     if (hrtimer_try_to_cancel(&bctimer) >= 0) {
> +             hrtimer_start(&bctimer, expires, HRTIMER_MODE_ABS_PINNED);
> +             /* Bind the "device" to the cpu */
> +             bc->bound_on = smp_processor_id();
> +     } else if (bc->bound_on == smp_processor_id()) {

This part really wants a proper comment. It took me a while to figure
out why this is correct and what the call chain is.


> +             now = ktime_get();
> +             interval = ktime_sub(expires, now);
> +             hrtimer_forward_now(&bctimer, interval);

We are in the event handler called from bc_handler() and expires is
absolute time. So what's wrong with calling
hrtimer_set_expires(&bctimer, expires)?

> +static enum hrtimer_restart bc_handler(struct hrtimer *t)
> +{
> +     ce_broadcast_hrtimer.event_handler(&ce_broadcast_hrtimer);
> +     return HRTIMER_RESTART;

We probably want to check whether the timer needs to be restarted at
all.

        if (ce_broadcast_timer.next_event.tv64 == KTIME_MAX)
           return HRTIMER_NORESTART;

        return HRTIMER_RESTART;

Hmm?

Thanks,

        tglx
_______________________________________________
Linuxppc-dev mailing list
Linuxppc-dev@lists.ozlabs.org
https://lists.ozlabs.org/listinfo/linuxppc-dev

Reply via email to