On Mon, 16 Feb 2015, Peter Zijlstra wrote:

> From: Thomas Gleixner <t...@linutronix.de>
> 
> Replace the clockevents_notify() call with an explicit function call.
> 
> Signed-off-by: Thomas Gleixner <t...@linutronix.de>

This patch makes my test system hang solid after letting it sit idle for 
5 to 15 minutes.  Reverting it and this issue goes away.

The explicit function call is not an equivalent replacement. In 
clockevents_notify() the clockevents_lock is held across the call to 
tick_broadcast_enter() or tick_broadcast_exit(). This patch drops the 
locking.

> ---
>  kernel/sched/idle.c |    5 ++---
>  1 file changed, 2 insertions(+), 3 deletions(-)
> 
> Index: linux/kernel/sched/idle.c
> ===================================================================
> --- linux.orig/kernel/sched/idle.c
> +++ linux/kernel/sched/idle.c
> @@ -143,8 +143,7 @@ use_default:
>        * is used from another cpu as a broadcast timer, this call may
>        * fail if it is not available
>        */
> -     if (broadcast &&
> -         clockevents_notify(CLOCK_EVT_NOTIFY_BROADCAST_ENTER, &dev->cpu))
> +     if (broadcast && tick_broadcast_enter())
>               goto use_default;
>  
>       /* Take note of the planned idle state. */
> @@ -161,7 +160,7 @@ use_default:
>       idle_set_state(this_rq(), NULL);
>  
>       if (broadcast)
> -             clockevents_notify(CLOCK_EVT_NOTIFY_BROADCAST_EXIT, &dev->cpu);
> +             tick_broadcast_exit();
>  
>       /*
>        * Give the governor an opportunity to reflect on the outcome
> 
> 
> --
> To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
> the body of a message to majord...@vger.kernel.org
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
> Please read the FAQ at  http://www.tux.org/lkml/
> 
> 
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to