Received: by 2002:ac0:a582:0:0:0:0:0 with SMTP id m2-v6csp1419100imm; Wed, 10 Oct 2018 14:22:50 -0700 (PDT) X-Google-Smtp-Source: ACcGV622oSqi+o6oM4/WRCjJYP1z4TT29e16fe/t3mEAh/JJDlTPcXYgukRrrrZz4t1b/n2qKFFW X-Received: by 2002:a62:454d:: with SMTP id s74-v6mr37489058pfa.136.1539206570815; Wed, 10 Oct 2018 14:22:50 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1539206570; cv=none; d=google.com; s=arc-20160816; b=EZswelPqMDS5etkHGeEqgsc694aPXAIZp5OYb8rw14MIj+FlJJCuWTmgiRQD8sXXIF 46m5bfzJ3e6Rm7+1JZifhbv8p///aJZsT0r5A7QETOLprudsKQPrCKWfkinxGQlp1bew ck+4AwZ0EmCC5xhZwBpvQZNRiTiFqp1M7N1XJ0ivE8XTCJFzl/3ynsY1x95JuHz8Mpu1 nBDhBseJdm59ym5gycasflHwOunDhi2890mY3g0N9rGX7cIZMT1M6pNr7czfekXKsH0V DWpWVgbN0WgtWp/fG2BlXgZEP39ifJwJ58jrkFacLa2zW5nKwX0jfwB5fxqyTZThPIg7 WyVQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dmarc-filter:dkim-signature:dkim-signature; bh=YZDhD01VxzXcehZSf8zIzgMV9+OeTRftFJdCx3rfibc=; b=0Y9fMYowRsoKiqbWqrgzMHQ6U6WZ/DNCJDmvnntwSumk3yJkQgalgUb1+wI1s8liNh NU45W+kY84rg9EsVVt3MCvj84wx/0avnG2zcNX0XWgsIdGCNJ9F0tHhacGdd3Z93u46Q hK/ntL6LaxQwekv/EssT9H6rLV2GgAwb2jgX+TgLblfsFUra9Z95LHeU/cSlwWATIIEy my0eIKmyfSpp2UVqHimsbdPtYWpc55AfoT7KvPRyuZVWDhJ7RDVY9PWni9NTxBzFloUM E2THP+73OXQ9SOWK2HC/etJLKcjw7j+VX+8p9z8wIzFj2Wu02TVgUI+C6dlc41VGfBrZ 1xwg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b=TmIudI9P; dkim=pass header.i=@codeaurora.org header.s=default header.b=hyBpp4W1; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id b127-v6si25071547pga.153.2018.10.10.14.22.20; Wed, 10 Oct 2018 14:22:50 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b=TmIudI9P; dkim=pass header.i=@codeaurora.org header.s=default header.b=hyBpp4W1; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726302AbeJKEpn (ORCPT + 99 others); Thu, 11 Oct 2018 00:45:43 -0400 Received: from smtp.codeaurora.org ([198.145.29.96]:38184 "EHLO smtp.codeaurora.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725899AbeJKEpn (ORCPT ); Thu, 11 Oct 2018 00:45:43 -0400 Received: by smtp.codeaurora.org (Postfix, from userid 1000) id 67ACF60C60; Wed, 10 Oct 2018 21:21:41 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1539206502; bh=S111ydwN3Rpmcs3kPsAcfRoMDUH6nJcnZx4HI+bxqfs=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=TmIudI9PMtoFEw+unqFA7ehIQ0DQdQCGdgy0fJLLTc+oEpHKv5Fmnp2qQgJjQ1bOO 636jRrg45dSfR3EjzCaOZk8yvFVv9UH8365TpC6XJDssTvne16EsQgkxcgoVsHM/9X FgF+TPADdCFl0ODhp5G+9j5RJ12UqjnAEvqL1M7M= X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on pdx-caf-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-2.2 required=2.0 tests=ALL_TRUSTED,BAYES_00, DKIM_INVALID,DKIM_SIGNED,FROM_LOCAL_NOVOWEL autolearn=no autolearn_force=no version=3.4.0 Received: from rplsssn-linux.qualcomm.com (blr-c-bdr-fw-01_globalnat_allzones-outside.qualcomm.com [103.229.19.19]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: rplsssn@smtp.codeaurora.org) by smtp.codeaurora.org (Postfix) with ESMTPSA id AEF9860B73; Wed, 10 Oct 2018 21:21:32 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1539206500; bh=S111ydwN3Rpmcs3kPsAcfRoMDUH6nJcnZx4HI+bxqfs=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=hyBpp4W1fLiyRB3p59reuSEBkaO7ixGKwl8pLoUOUI8RHYE1rtOt9FWC9XML0gbhf U/d6rDESuoaPVvDjAq076q7wzyzRgheqlIoTP2c4yWsXFek/O0EeHlGTZ/PpaPWdHQ kOzd0MTLAjamuxZLr6StaqYyybkO/l85/TH4zalE= DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org AEF9860B73 Authentication-Results: pdx-caf-mail.web.codeaurora.org; dmarc=none (p=none dis=none) header.from=codeaurora.org Authentication-Results: pdx-caf-mail.web.codeaurora.org; spf=none smtp.mailfrom=rplsssn@codeaurora.org From: "Raju P.L.S.S.S.N" To: andy.gross@linaro.org, david.brown@linaro.org, rjw@rjwysocki.net, ulf.hansson@linaro.org, khilman@kernel.org, linux-arm-msm@vger.kernel.org, linux-soc@vger.kernel.org Cc: rnayak@codeaurora.org, bjorn.andersson@linaro.org, linux-kernel@vger.kernel.org, linux-pm@vger.kernel.org, devicetree@vger.kernel.org, sboyd@kernel.org, evgreen@chromium.org, dianders@chromium.org, mka@chromium.org, ilina@codeaurora.org, Lina Iyer , Thomas Gleixner , Daniel Lezcano , Frederic Weisbecker , Ingo Molnar , "Raju P.L.S.S.S.N" Subject: [PATCH RFC v1 3/8] timer: Export next wakeup time of a CPU Date: Thu, 11 Oct 2018 02:50:50 +0530 Message-Id: <1539206455-29342-4-git-send-email-rplsssn@codeaurora.org> X-Mailer: git-send-email 1.9.1 In-Reply-To: <1539206455-29342-1-git-send-email-rplsssn@codeaurora.org> References: <1539206455-29342-1-git-send-email-rplsssn@codeaurora.org> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Lina Iyer Knowing the sleep duration of CPUs, is known to be needed while selecting the most energy efficient idle state for a CPU or a group of CPUs. However, to be able to compute the sleep duration, we need to know at what time the next expected wakeup is for the CPU. Therefore, let's export this information via a new function, tick_nohz_get_next_wakeup(). Following changes make use of it. Cc: Thomas Gleixner Cc: Daniel Lezcano Cc: Lina Iyer Cc: Frederic Weisbecker Cc: Ingo Molnar Signed-off-by: Lina Iyer Co-developed-by: Ulf Hansson Signed-off-by: Ulf Hansson Signed-off-by: Raju P.L.S.S.S.N (am from https://patchwork.kernel.org/patch/10478021/) --- include/linux/tick.h | 8 ++++++++ kernel/time/tick-sched.c | 10 ++++++++++ 2 files changed, 18 insertions(+) diff --git a/include/linux/tick.h b/include/linux/tick.h index 55388ab..e48f6b2 100644 --- a/include/linux/tick.h +++ b/include/linux/tick.h @@ -125,6 +125,7 @@ enum tick_dep_bits { extern ktime_t tick_nohz_get_sleep_length(ktime_t *delta_next); extern unsigned long tick_nohz_get_idle_calls(void); extern unsigned long tick_nohz_get_idle_calls_cpu(int cpu); +extern ktime_t tick_nohz_get_next_wakeup(int cpu); extern u64 get_cpu_idle_time_us(int cpu, u64 *last_update_time); extern u64 get_cpu_iowait_time_us(int cpu, u64 *last_update_time); @@ -151,6 +152,13 @@ static inline ktime_t tick_nohz_get_sleep_length(ktime_t *delta_next) *delta_next = TICK_NSEC; return *delta_next; } + +static inline ktime_t tick_nohz_get_next_wakeup(int cpu) +{ + /* Next wake up is the tick period, assume it starts now */ + return ktime_add(ktime_get(), TICK_NSEC); +} + static inline u64 get_cpu_idle_time_us(int cpu, u64 *unused) { return -1; } static inline u64 get_cpu_iowait_time_us(int cpu, u64 *unused) { return -1; } diff --git a/kernel/time/tick-sched.c b/kernel/time/tick-sched.c index 5b33e2f..bca95f9 100644 --- a/kernel/time/tick-sched.c +++ b/kernel/time/tick-sched.c @@ -1089,6 +1089,16 @@ unsigned long tick_nohz_get_idle_calls(void) return ts->idle_calls; } +/** + * tick_nohz_get_next_wakeup - return the next wake up of the CPU + */ +ktime_t tick_nohz_get_next_wakeup(int cpu) +{ + struct clock_event_device *dev = per_cpu(tick_cpu_device.evtdev, cpu); + + return dev->next_event; +} + static void tick_nohz_account_idle_ticks(struct tick_sched *ts) { #ifndef CONFIG_VIRT_CPU_ACCOUNTING_NATIVE -- QUALCOMM INDIA, on behalf of Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum, hosted by The Linux Foundation.