Received: by 2002:a05:7412:b130:b0:e2:908c:2ebd with SMTP id az48csp1318032rdb; Sat, 18 Nov 2023 11:07:47 -0800 (PST) X-Google-Smtp-Source: AGHT+IFl9TV8y5ocRrFpr+WlpF0JbfHrsnwhdbtOZwtkacbtbjjbzoMkVHTElVWrzBRZtGQM9pEj X-Received: by 2002:a17:902:cec1:b0:1cc:52b5:8df8 with SMTP id d1-20020a170902cec100b001cc52b58df8mr13194453plg.26.1700334467060; Sat, 18 Nov 2023 11:07:47 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1700334467; cv=none; d=google.com; s=arc-20160816; b=HfPfvcm+/yGIdJzo9oeLItkuwjy9q9iAk7rOcRIYRm5G7Qn0iW7cHVfn/Q45QlQD7O q490wgyjScNieBaI8C80iBIJd5f+9QAmXJIqq7osjmQ14s3wDFH12mX1RWLnYO0Hnkrs ojUzhe5TKAmXlBvqjCk14QjJV98Ag6Lfow+FmtiaoH/OO1gLrRAMWr1yQQbLkuvKCfcZ MGFrDgqsQeeJII4l5LAnRMBYh6nK6AZlxsy5A9BXulLc3anA9CRtUjGdynrr6cL3brFf TiGz0SC8eHKh0yVGjBrRbysGJjaX2F/PWLfU34cbw67Rztzm/5sXlZSH6ZYRVPoqjjF+ cF6w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:autocrypt :from:references:cc:to:content-language:subject:user-agent :mime-version:date:message-id:dkim-signature; bh=ah97aCbN24GtUBFT8VSBvxF84jY96VzFBfOL/rbwUPw=; fh=MDmX2ZWMK+/I+ezXlE2Q8L+L4B1FGlBd/EGKSD7HKYM=; b=bWj7h6k4wJiCKrosMcjo8J5xb0Ge9dkruQmKAhP0Hj+H4tVH2zvin7+fX7SczysfVN pQAiyzisvSTG96dgB1em0osmcFTqu+lCpiZ37kKahdq9D9B631ztmJ9tHyDvRFBkZVZy IzIxZtwEBatNKUYFMmwhoQqhgNnh/ApWiwSL5sUgaXtC3mesOMKMpMBLnc6yye3HLVVU XYsfka74yDCGDPYHy/fD2gyPUq4zlTHzVhq8TZTl8klPco8J2f/LTsMRpxo4NXQQSxio /kbDIqeDJB1A6C+WW9uH3FHQfhWy/jdzQoIQRpEcAT5vrEto536vxMbfMIA7vCiOvhOQ ZPiw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass (test mode) header.i=@o2.pl header.s=1024a header.b=QIMdCusO; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:5 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=o2.pl Return-Path: Received: from groat.vger.email (groat.vger.email. [2620:137:e000::3:5]) by mx.google.com with ESMTPS id m187-20020a6326c4000000b005adba954597si4640099pgm.504.2023.11.18.11.07.46 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 18 Nov 2023 11:07:47 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:5 as permitted sender) client-ip=2620:137:e000::3:5; Authentication-Results: mx.google.com; dkim=pass (test mode) header.i=@o2.pl header.s=1024a header.b=QIMdCusO; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:5 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=o2.pl Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by groat.vger.email (Postfix) with ESMTP id 637148088A40; Sat, 18 Nov 2023 11:07:30 -0800 (PST) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.11 at groat.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230013AbjKRTHP (ORCPT + 99 others); Sat, 18 Nov 2023 14:07:15 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:56930 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230268AbjKRTHM (ORCPT ); Sat, 18 Nov 2023 14:07:12 -0500 Received: from mx-out.tlen.pl (mx-out.tlen.pl [193.222.135.140]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 87AEAD66 for ; Sat, 18 Nov 2023 11:07:05 -0800 (PST) Received: (wp-smtpd smtp.tlen.pl 29537 invoked from network); 18 Nov 2023 20:07:02 +0100 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=o2.pl; s=1024a; t=1700334422; bh=ah97aCbN24GtUBFT8VSBvxF84jY96VzFBfOL/rbwUPw=; h=Subject:To:Cc:From; b=QIMdCusO1tTtUrw7L3tTLKOgB5VfiROd/ZmFSaxCo+kSCGyovbm8+BVYYg5ae7cyz zttG8pedzbbaQlkKNPJCW3+N/cWFo98RfdkHCJTc1rkZj0LOjh6UGdmpSfUgRUcIdd YFB+/oLZEHpi/kb4IAA4uMjOmXTw8UThtDtrX+3A= Received: from aafl106.neoplus.adsl.tpnet.pl (HELO [192.168.1.22]) (mat.jonczyk@o2.pl@[83.4.141.106]) (envelope-sender ) by smtp.tlen.pl (WP-SMTPD) with ECDHE-RSA-AES256-GCM-SHA384 encrypted SMTP for ; 18 Nov 2023 20:07:02 +0100 Message-ID: <9a34ad89-6263-4cda-b938-348bdf62e155@o2.pl> Date: Sat, 18 Nov 2023 20:06:59 +0100 MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH 3/4] rtc: Add support for configuring the UIP timeout for RTC reads Content-Language: en-GB To: Mario Limonciello , Alessandro Zummo , Alexandre Belloni Cc: "open list:REAL TIME CLOCK (RTC) SUBSYSTEM" , open list , linux-pm@vger.kernel.org, tobrohl@gmail.com, aalsing@gmail.com, Dhaval.Giani@amd.com, xmb8dsv4@gmail.com, x86@kernel.org References: <20231117063220.65093-1-mario.limonciello@amd.com> <20231117063220.65093-4-mario.limonciello@amd.com> From: =?UTF-8?Q?Mateusz_Jo=C5=84czyk?= Autocrypt: addr=mat.jonczyk@o2.pl; keydata= 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 TANkZ3QqXNX2 In-Reply-To: <20231117063220.65093-4-mario.limonciello@amd.com> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-WP-MailID: 7ac0a0c6de035ddcdf3814c62d506835 X-WP-AV: skaner antywirusowy Poczty o2 X-WP-SPAM: NO 0000000 [waP0] X-Spam-Status: No, score=-0.6 required=5.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,FREEMAIL_FORGED_FROMDOMAIN,FREEMAIL_FROM, HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI,SPF_HELO_NONE, SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on groat.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (groat.vger.email [0.0.0.0]); Sat, 18 Nov 2023 11:07:30 -0800 (PST) Hello, W dniu 17.11.2023 o 07:32, Mario Limonciello pisze: > The UIP timeout is hardcoded to 10ms for all RTC reads, but in some > contexts this might not be enough time. Add a timeout parameter to > mc146818_get_time() and mc146818_get_time_callback(). > Make all callers use 10ms to ensure no functional changes. > > Signed-off-by: Mario Limonciello Fixes: ec5895c0f2d8 ("rtc: mc146818-lib: extract mc146818_avoid_UIP") If you would like to Cc: stable this patch, commit d2a632a8a117 ("rtc: mc146818-lib: reduce RTC_UIP polling period") is a prerequisite. > --- > arch/alpha/kernel/rtc.c | 2 +- > arch/x86/kernel/hpet.c | 2 +- > arch/x86/kernel/rtc.c | 2 +- > drivers/base/power/trace.c | 2 +- > drivers/rtc/rtc-cmos.c | 6 +++--- > drivers/rtc/rtc-mc146818-lib.c | 31 +++++++++++++++++++++++-------- > include/linux/mc146818rtc.h | 3 ++- > 7 files changed, 32 insertions(+), 16 deletions(-) > [snip] > --- a/drivers/rtc/rtc-mc146818-lib.c > +++ b/drivers/rtc/rtc-mc146818-lib.c > @@ -8,26 +8,29 @@ > #include > #endif > > +#define UIP_RECHECK_DELAY 100 /* usec */ > + > /* > * Execute a function while the UIP (Update-in-progress) bit of the RTC is > - * unset. > + * unset. The timeout is configurable by the caller in ms. > * > * Warning: callback may be executed more then once. > */ > bool mc146818_avoid_UIP(void (*callback)(unsigned char seconds, void *param), > + int timeout, > void *param) > { > int i; > unsigned long flags; > unsigned char seconds; > > - for (i = 0; i < 100; i++) { > + for (i = 0; i < USEC_PER_MSEC / UIP_RECHECK_DELAY * timeout; i++) { > spin_lock_irqsave(&rtc_lock, flags); > > /* > * Check whether there is an update in progress during which the > * readout is unspecified. The maximum update time is ~2ms. Poll > - * every 100 usec for completion. > + * for completion. > * > * Store the second value before checking UIP so a long lasting > * NMI which happens to hit after the UIP check cannot make > @@ -37,7 +40,7 @@ bool mc146818_avoid_UIP(void (*callback)(unsigned char seconds, void *param), > > if (CMOS_READ(RTC_FREQ_SELECT) & RTC_UIP) { > spin_unlock_irqrestore(&rtc_lock, flags); > - udelay(100); > + udelay(UIP_RECHECK_DELAY); > continue; > } > > @@ -56,7 +59,7 @@ bool mc146818_avoid_UIP(void (*callback)(unsigned char seconds, void *param), > */ > if (CMOS_READ(RTC_FREQ_SELECT) & RTC_UIP) { > spin_unlock_irqrestore(&rtc_lock, flags); > - udelay(100); > + udelay(UIP_RECHECK_DELAY); > continue; > } > I think that when reading the RTC is not finished in 100ms or so (irrespective of the timeout parameter), the code should log a warning / an error message. Greetings, Mateusz