Hi Thomas,

On 02/04/2014 03:48 PM, Thomas Gleixner wrote:
>> +++ 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.

How about:

"However we can also be called from the event handler of
ce_broadcast_hrtimer when bctimer expires. We cannot therefore restart
the timer since it is on flight on the same CPU. But due to the same
reason we can reset it."
?

> 
> 
>> +            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)?

You are right. There are so many interfaces doing nearly the same thing
:( I overlooked that hrtimer_forward() and its variants were being used
when the interval was pre-calculated and stored away. And
hrtimer_set_expires() would be used when we knew the absolute expiry.
And it looks safe to call it here too.

> 
>> +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;

True this additional check would be useful.

Do you want me to send out the next version with the above corrections
including the patch added to this thread where we handle archs setting
the CPUIDLE_FLAG_TIMER_STOP flag?

> 
> Hmm?
> 
> Thanks,
> 
>       tglx

Thanks

Regards
Preeti U Murthy
> _______________________________________________
> Linuxppc-dev mailing list
> Linuxppc-dev@lists.ozlabs.org
> https://lists.ozlabs.org/listinfo/linuxppc-dev
> 

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

Reply via email to