Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp4708775imm; Mon, 30 Jul 2018 21:31:14 -0700 (PDT) X-Google-Smtp-Source: AAOMgpdqGI4QtVhaXE0D3Ha1eP3ksI5gmnXKM6yo8qvp+10rZx56hGI86q8nzF70DKon2Ppcqi7i X-Received: by 2002:a63:7a43:: with SMTP id j3-v6mr18699151pgn.363.1533011473971; Mon, 30 Jul 2018 21:31:13 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1533011473; cv=none; d=google.com; s=arc-20160816; b=sBW4Q/4Ptg6huaGt8D4s3KGGryoVVYk+2mpfCF4/zD6NfctBrFs8kupAgMuz+FrkmC zn3/KfAHAIxQBpq+TUaAc5zhJZAgm/t9nJXL/k2oWB7ubxp/msCWJHQh6zCc8OqAlxv6 V614dx/KTOOkwQ5QP6cfzPQz9QeO5/DRGf3uDuk7Fk/u1sYJUJMAfN5VG4mJsFId+aiB 22xhMrsVfB930DuacQXZdGDfInzqwuKorAqHc0XbZdrb5PMP5tMHVGFGs/0v782KzI1l xjyaP0hT9mJ35dxlsoWKokQo9bXIst60n+FNcnObXfaU/y18LraiuDzDAjedKsGSclW6 qIwg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dmarc-filter :dkim-signature:dkim-signature:arc-authentication-results; bh=w46PAzQlspMarJ9N8/a4m2KMFxWcJUVORJo+NNmwDM0=; b=dUu7il68gTDAen4pQKqewI/Cm2b+9k4Rlg/Kfq0fsh59e4ZceoTynJdSVWoIDSHXOM oSfqYUFtxirRrsvAxl10+Ixt++dNtm0thOG02VYvpG/7BD6ZSYIH/SLAGeze5nIdetPL 6FPPRdCXScvqsyKQkaVnLHi+LfvoVrApfZSIckjFAE7GnzOeZgm7ZwUsgbEnaTDcaUMk 1eAX7/6IDQYK49Di1emEo6du2e9g0Mh9GDpsMyfWxBHYmqh517RXxMcU/bQTgmF+H3YU 09JXcaG0PRwOoiG7R+HKgk2JRScqYGMv8ICm+yQR+hgLcG0VVPzZYae2F+p1vKzEiBlr FGgA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b=aKa8B5v0; dkim=pass header.i=@codeaurora.org header.s=default header.b="D/yU/rtd"; 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 k7-v6si13555027pfb.309.2018.07.30.21.30.59; Mon, 30 Jul 2018 21:31:13 -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=aKa8B5v0; dkim=pass header.i=@codeaurora.org header.s=default header.b="D/yU/rtd"; 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 S1727307AbeGaGHw (ORCPT + 99 others); Tue, 31 Jul 2018 02:07:52 -0400 Received: from smtp.codeaurora.org ([198.145.29.96]:42326 "EHLO smtp.codeaurora.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725853AbeGaGHv (ORCPT ); Tue, 31 Jul 2018 02:07:51 -0400 Received: by smtp.codeaurora.org (Postfix, from userid 1000) id 35B3C60264; Tue, 31 Jul 2018 04:29:33 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1533011373; bh=FBgx2iAY0kMwvdQrDxppPavTJQGfpZuyrykm3divWPo=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=aKa8B5v0tOUxk6jqOfq6lPTXJnI3uwcSkq+Byze8k6WGWfTrptz+08J8dp3it0WQc V8p/RKwuPsyB/TMK9pyyiRlPiO3C96d0tmf9RuVJKIPoHfiGpHEZVDTuR9DQfe9Q5Z Uxb5MZaR5jKQp+eQUJXqdWbCrt3BRH0KKK9rwScI= 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.8 required=2.0 tests=ALL_TRUSTED,BAYES_00, DKIM_SIGNED,T_DKIM_INVALID autolearn=no autolearn_force=no version=3.4.0 Received: from [10.204.78.76] (blr-c-bdr-fw-01_globalnat_allzones-outside.qualcomm.com [103.229.19.19]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: gkohli@smtp.codeaurora.org) by smtp.codeaurora.org (Postfix) with ESMTPSA id BCD5C6071C; Tue, 31 Jul 2018 04:29:30 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1533011372; bh=FBgx2iAY0kMwvdQrDxppPavTJQGfpZuyrykm3divWPo=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=D/yU/rtddOvrSzcKhAb0DStHGgAFTgrKd6Wx532VfvSYdlx/qMtW67DV+0yuwf57z oxxcTDcwKJgYlHJeBAMeieTWG+4yN8V4SpWa4ZbnVz10PoIgayUK5nDRYNjAvzNfUZ eKyUfMWoaW37qS2ZEmNrguHkGukX89fgO3KvSRqU= DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org BCD5C6071C 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=gkohli@codeaurora.org Subject: Re: [PATCH] timers: Clear must_forward_clk inside base lock To: john.stultz@linaro.org, tglx@linutronix.de, sboyd@kernel.org Cc: linux-kernel@vger.kernel.org, linux-arm-msm@vger.kernel.org References: <1532594522-28045-1-git-send-email-gkohli@codeaurora.org> From: "Kohli, Gaurav" Message-ID: <063840fb-3360-4208-2950-908ef76791c2@codeaurora.org> Date: Tue, 31 Jul 2018 09:59:28 +0530 User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:52.0) Gecko/20100101 Thunderbird/52.9.1 MIME-Version: 1.0 In-Reply-To: <1532594522-28045-1-git-send-email-gkohli@codeaurora.org> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi John, Thomas, Can you please review below patch and update your comments: Regards Gaurav On 7/26/2018 2:12 PM, Gaurav Kohli wrote: > While migrating timer to new base, there is a need > to update base clk by calling forward_timer_base to > avoid stale clock , but at the same time if run_timer > is exectuing in new core it may set must_forward_clk > to false and due to this forward base logic may fail as > per below check: > > if (likely(!base->must_forward_clk)) > return; > > So preventing the same by putting must_forward_clk inside > base lock. > > Signed-off-by: Gaurav Kohli > > diff --git a/kernel/time/timer.c b/kernel/time/timer.c > index cc2d23e..675241d 100644 > --- a/kernel/time/timer.c > +++ b/kernel/time/timer.c > @@ -1657,6 +1657,19 @@ static inline void __run_timers(struct timer_base *base) > > raw_spin_lock_irq(&base->lock); > > + /* > + * must_forward_clk must be cleared before running timers so that any > + * timer functions that call mod_timer will not try to forward the > + * base. idle trcking / clock forwarding logic is only used with > + * BASE_STD timers. > + * > + * The deferrable base does not do idle tracking at all, so we do > + * not forward it. This can result in very large variations in > + * granularity for deferrable timers, but they can be deferred for > + * long periods due to idle. > + */ > + base->must_forward_clk = false; > + > while (time_after_eq(jiffies, base->clk)) { > > levels = collect_expired_timers(base, heads); > @@ -1676,19 +1689,6 @@ static __latent_entropy void run_timer_softirq(struct softirq_action *h) > { > struct timer_base *base = this_cpu_ptr(&timer_bases[BASE_STD]); > > - /* > - * must_forward_clk must be cleared before running timers so that any > - * timer functions that call mod_timer will not try to forward the > - * base. idle trcking / clock forwarding logic is only used with > - * BASE_STD timers. > - * > - * The deferrable base does not do idle tracking at all, so we do > - * not forward it. This can result in very large variations in > - * granularity for deferrable timers, but they can be deferred for > - * long periods due to idle. > - */ > - base->must_forward_clk = false; > - > __run_timers(base); > if (IS_ENABLED(CONFIG_NO_HZ_COMMON)) > __run_timers(this_cpu_ptr(&timer_bases[BASE_DEF])); > -- Qualcomm India Private Limited, on behalf of Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum, a Linux Foundation Collaborative Project.