Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753495AbaA0IcW (ORCPT ); Mon, 27 Jan 2014 03:32:22 -0500 Received: from mail-we0-f173.google.com ([74.125.82.173]:61598 "EHLO mail-we0-f173.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753375AbaA0IcT (ORCPT ); Mon, 27 Jan 2014 03:32:19 -0500 Message-ID: <52E61993.2090705@linaro.org> Date: Mon, 27 Jan 2014 09:32:19 +0100 From: Daniel Lezcano User-Agent: Mozilla/5.0 (X11; Linux i686; rv:24.0) Gecko/20100101 Thunderbird/24.2.0 MIME-Version: 1.0 To: Nicolas Pitre , Russell King , Catalin Marinas , Benjamin Herrenschmidt , Paul Mundt , Thomas Gleixner , Ingo Molnar , Peter Zijlstra , "Rafael J. Wysocki" CC: linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linuxppc-dev@lists.ozlabs.org, linux-sh@vger.kernel.org, linux-pm@vger.kernel.org, linaro-kernel@lists.linaro.org Subject: Re: [PATCH 4/9] idle: move the cpuidle entry point to the generic idle loop References: <1390802904-28399-1-git-send-email-nicolas.pitre@linaro.org> <1390802904-28399-5-git-send-email-nicolas.pitre@linaro.org> In-Reply-To: <1390802904-28399-5-git-send-email-nicolas.pitre@linaro.org> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 01/27/2014 07:08 AM, Nicolas Pitre wrote: > In order to integrate cpuidle with the scheduler, we must have a better > proximity in the core code with what cpuidle is doing and not delegate > such interaction to arch code. > > Architectures implementing arch_cpu_idle() should simply enter > a cheap idle mode in the absence of a proper cpuidle driver. > > Signed-off-by: Nicolas Pitre This patch without the next ones will lead to an extra call to cpuidle_idle_call. cpuidle_idle_call arch_cpu_idle cpuidle_idle_call x86_idle But I guess it is acceptable as it is fixed with the next patches of the serie. Acked-by: Daniel Lezcano > --- > kernel/cpu/idle.c | 4 +++- > 1 file changed, 3 insertions(+), 1 deletion(-) > > diff --git a/kernel/cpu/idle.c b/kernel/cpu/idle.c > index 4e327e211b..a6f40ad9f8 100644 > --- a/kernel/cpu/idle.c > +++ b/kernel/cpu/idle.c > @@ -3,6 +3,7 @@ > */ > #include > #include > +#include > #include > #include > #include > @@ -94,7 +95,8 @@ static void cpu_idle_loop(void) > if (!current_clr_polling_and_test()) { > stop_critical_timings(); > rcu_idle_enter(); > - arch_cpu_idle(); > + if (cpuidle_idle_call()) > + arch_cpu_idle(); > WARN_ON_ONCE(irqs_disabled()); > rcu_idle_exit(); > start_critical_timings(); > -- Linaro.org │ Open source software for ARM SoCs Follow Linaro: Facebook | Twitter | Blog -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/