Received: by 2002:a05:6358:53a8:b0:117:f937:c515 with SMTP id z40csp5516911rwe; Tue, 18 Apr 2023 07:54:51 -0700 (PDT) X-Google-Smtp-Source: AKy350Yf8zoslGRvvBkFc19V519JoUzcj4iyyZX/YDiecA/Ck9pk2wlIXUzJJWO8Wtni2/W6/REb X-Received: by 2002:a05:6a20:431b:b0:ee:7bf9:4c0d with SMTP id h27-20020a056a20431b00b000ee7bf94c0dmr18994402pzk.38.1681829691292; Tue, 18 Apr 2023 07:54:51 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1681829691; cv=none; d=google.com; s=arc-20160816; b=mVMGM+fl1JjjvfX9y2xVvpHV3qI5qkGYyia14yPWl4IFWXJXNF/IkU3lfvV5E1nW7p G0h2Im/yR8xJtEo7lvPe5iVMhPaNhzhCrZxp+q5tW1HQhO8GeTWC6prScntYhKuB95SC el3kTBsbjNwLMfxq1+4OdgqaLswxET70XznfwW+feeLBVGDKdurXLrhnIeO90I6NOu2I VGroeFl4YHfcemmwAStnT9Gl0KcQhl06hAxV87MdTpDPomy2DcskVO8VgxTphCxtbbir /eq9QLI/tmDuM93oGwVTc29DCNi+NDr6I6emhCrScoyMFfmQnslJllbU1prS0Eu9Kngx Q7Og== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:robot-unsubscribe :robot-id:message-id:mime-version:references:in-reply-to:cc:subject :to:reply-to:sender:from:dkim-signature:dkim-signature:date; bh=idUFnLwc9DEicaszUNU0vcf7I7imSGPqvv4DdMdr8TA=; b=vs7dnUl28tUbtE4d9pJd6IM44A9aF5zKOVkQbAvoNNTYfbZKYwM3s7+6Ke61xMt9Kg 0BmJ2ivxtb//GXZt1o6xHO1jt/uJekxL+VN6IVY/NxA6vo38uVc/+EyLdrLfPHoMI4Ko zRsMNfGryyQxh98TNmQcZLDJCA/579rf5ZpwBXzFsNDhuUgzHVJKhfT6ctPtxPFK1jTL 1XBVIquJIHttFTXred/GSc5DGYwZzpkHbq4ptr2QfHxUVwpGvAlUprUUm7Ytqn46B7aG BHYmQIOMA7nPBxcuWZlOltPL82Iqj4GmF0PCdkhYyoSvZFNLi5RWMizAZ5b+svQDWaYj RqBA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linutronix.de header.s=2020 header.b=mV2CO4dm; dkim=neutral (no key) header.i=@linutronix.de header.s=2020e; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=linutronix.de Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id 14-20020a63124e000000b00514156b3cbfsi11270624pgs.875.2023.04.18.07.54.34; Tue, 18 Apr 2023 07:54:51 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@linutronix.de header.s=2020 header.b=mV2CO4dm; dkim=neutral (no key) header.i=@linutronix.de header.s=2020e; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=linutronix.de Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229978AbjDROxs (ORCPT + 99 others); Tue, 18 Apr 2023 10:53:48 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:49912 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231194AbjDROxe (ORCPT ); Tue, 18 Apr 2023 10:53:34 -0400 Received: from galois.linutronix.de (Galois.linutronix.de [193.142.43.55]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 1FE2FAD2A; Tue, 18 Apr 2023 07:53:31 -0700 (PDT) Date: Tue, 18 Apr 2023 14:53:29 -0000 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linutronix.de; s=2020; t=1681829609; h=from:from:sender:sender:reply-to:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=idUFnLwc9DEicaszUNU0vcf7I7imSGPqvv4DdMdr8TA=; b=mV2CO4dmI6IEPEdsbfIHwEROgvvjDutm5oXeKCuSPCD9nBdriYVBIblnu8rharWNHnmYE3 Su6JU9JBwoVt7M/vgEvJ1eeifnzT4eVXJDPHsApMx2NsfbGPlpxY33spA9AEYWHQXAPII+ kNoM9ZI/JTYPT0xqR0x89TiqGEVWMY39pv3Ax+oZZr7E4Nw+xhgiyg70te8bzcKULMMtoo 2P0qKQvGs6Mx++zDWeIDYfMHMvX6BwdaGPU37rjZF22gwDK37JVhKnjceg9IICs+LLWp0T YnROErOEHr5TBIfFqYMgQhSi/UXJU+HgGV3/PXtL4EiqMwdLJIrOgGxJ+GSkyQ== DKIM-Signature: v=1; a=ed25519-sha256; c=relaxed/relaxed; d=linutronix.de; s=2020e; t=1681829609; h=from:from:sender:sender:reply-to:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=idUFnLwc9DEicaszUNU0vcf7I7imSGPqvv4DdMdr8TA=; b=hejqBdWfk07hDMeXqdHKjDzZ6XFbBu7X9RWV8G29DlTc6xy2gSs28kwXyMhmYtywx2g2cS oeRKITnDX1iPs7CA== From: "tip-bot2 for Frederic Weisbecker" Sender: tip-bot2@linutronix.de Reply-to: linux-kernel@vger.kernel.org To: linux-tip-commits@vger.kernel.org Subject: [tip: timers/core] timers/nohz: Add a comment about broken iowait counter update race Cc: Frederic Weisbecker , Thomas Gleixner , "Peter Zijlstra (Intel)" , x86@kernel.org, linux-kernel@vger.kernel.org In-Reply-To: <20230222144649.624380-5-frederic@kernel.org> References: <20230222144649.624380-5-frederic@kernel.org> MIME-Version: 1.0 Message-ID: <168182960920.404.6558173122716747219.tip-bot2@tip-bot2> Robot-ID: Robot-Unsubscribe: Contact to get blacklisted from these emails Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-4.4 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_MED,SPF_HELO_NONE, SPF_PASS,T_SCC_BODY_TEXT_LINE,URIBL_BLOCKED autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The following commit has been merged into the timers/core branch of tip: Commit-ID: ead70b75237371c735a481a9843b411cfbb18404 Gitweb: https://git.kernel.org/tip/ead70b75237371c735a481a9843b411cfbb18404 Author: Frederic Weisbecker AuthorDate: Wed, 22 Feb 2023 15:46:45 +01:00 Committer: Thomas Gleixner CommitterDate: Tue, 18 Apr 2023 16:35:12 +02:00 timers/nohz: Add a comment about broken iowait counter update race The per-cpu iowait task counter is incremented locally upon sleeping. But since the task can be woken to (and by) another CPU, the counter may then be decremented remotely. This is the source of a race involving readers VS writer of idle/iowait sleeptime. The following scenario shows an example where a /proc/stat reader observes a pending sleep time as IO whereas that pending sleep time later eventually gets accounted as non-IO. CPU 0 CPU 1 CPU 2 ----- ----- ------ //io_schedule() TASK A current->in_iowait = 1 rq(0)->nr_iowait++ //switch to idle // READ /proc/stat // See nr_iowait_cpu(0) == 1 return ts->iowait_sleeptime + ktime_sub(ktime_get(), ts->idle_entrytime) //try_to_wake_up(TASK A) rq(0)->nr_iowait-- //idle exit // See nr_iowait_cpu(0) == 0 ts->idle_sleeptime += ktime_sub(ktime_get(), ts->idle_entrytime) As a result subsequent reads on /proc/stat may expose backward progress. This is unfortunately hardly fixable. Just add a comment about that condition. Signed-off-by: Frederic Weisbecker Signed-off-by: Thomas Gleixner Acked-by: Peter Zijlstra (Intel) Link: https://lore.kernel.org/r/20230222144649.624380-5-frederic@kernel.org --- kernel/time/tick-sched.c | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/kernel/time/tick-sched.c b/kernel/time/tick-sched.c index 90d9b7b..edd6e9f 100644 --- a/kernel/time/tick-sched.c +++ b/kernel/time/tick-sched.c @@ -705,7 +705,10 @@ static u64 get_cpu_sleep_time_us(struct tick_sched *ts, ktime_t *sleeptime, * counters if NULL. * * Return the cumulative idle time (since boot) for a given - * CPU, in microseconds. + * CPU, in microseconds. Note this is partially broken due to + * the counter of iowait tasks that can be remotely updated without + * any synchronization. Therefore it is possible to observe backward + * values within two consecutive reads. * * This time is measured via accounting rather than sampling, * and is as accurate as ktime_get() is. @@ -728,7 +731,10 @@ EXPORT_SYMBOL_GPL(get_cpu_idle_time_us); * counters if NULL. * * Return the cumulative iowait time (since boot) for a given - * CPU, in microseconds. + * CPU, in microseconds. Note this is partially broken due to + * the counter of iowait tasks that can be remotely updated without + * any synchronization. Therefore it is possible to observe backward + * values within two consecutive reads. * * This time is measured via accounting rather than sampling, * and is as accurate as ktime_get() is.