Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp3888900pxk; Tue, 29 Sep 2020 08:41:45 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyne4KDGwM0+nmH2rh0mzRkuEgaKlVLIhs/ikKysAFKhScJ2PNfz8c63jrI5jM4FPP8ihSH X-Received: by 2002:a17:906:85a:: with SMTP id f26mr4591736ejd.389.1601394105270; Tue, 29 Sep 2020 08:41:45 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1601394105; cv=none; d=google.com; s=arc-20160816; b=woMphjypN0SqGTnAWnmTHcKjdGet6pNMhLJxPyUfnWp1Py0KTNFyZ/wA6dRY1b+dWV cgD8OF47lcgRM668SVVPgc2s1m6qX1jcupxdj2W63ZZw+Y3WzKou4zN+2XjZB1O+hGM/ 77VWxiTbwMr41Ai7xRFLXKl2KfLIbCh9gYX5Ihzry38YdfNR2ovZMYIPUFiZm6gD5RuG C4KbdCXUFYqrpA345QHUs9/3lIhA7lGNdntsqq8dCKrYxgOcGiRO0vFAEl4K/+YOvRiE gE+8ojr6C6KN8cZdrfyIUTdHXxA6TcPyLpe1TNeFtAhIH0uk1yMoADOtHLTh96irZb6m 7oKg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date; bh=kwZ6KBMVWHYMeMcO/WF+xu1XAres80z6icT7H7u5FdE=; b=lpB6TJbemM6sMK0EMEWZ37haB8Fr51WOVn8n605pjTXdngWKDmZGyf9k3cvEQ/xNSK dzV/3HUeKOKmplF9WW8ENpMcFCBAP8MAfMhNqguHIGczphjmmlkZeg9MqVDObicpFeXj HO7LP+Lb2LXXNcyAgcnQbR+HPznHXqT0bedb80ZvyZLzPEOpB1we7TZV87sbpAs0AR1D 7y+Q9WejsLYD5eqeJ3nJpBAj7lXmMB4T889735X6oyOHwSzEtg4DvciXqnS2GHLkDNS6 JFj/6iimnXkPBlw7QHOllpMLWjVY6bsbaO6N5l9fvk19JXgOofbNR/wVMzWlv8WW3Y26 vmLg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id ot12si2858785ejb.692.2020.09.29.08.41.22; Tue, 29 Sep 2020 08:41:45 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729486AbgI2PkS (ORCPT + 99 others); Tue, 29 Sep 2020 11:40:18 -0400 Received: from foss.arm.com ([217.140.110.172]:47394 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728623AbgI2PkR (ORCPT ); Tue, 29 Sep 2020 11:40:17 -0400 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 36A941063; Tue, 29 Sep 2020 08:40:17 -0700 (PDT) Received: from C02TD0UTHF1T.local (unknown [10.57.51.69]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id A44C43F70D; Tue, 29 Sep 2020 08:40:15 -0700 (PDT) Date: Tue, 29 Sep 2020 16:40:12 +0100 From: Mark Rutland To: Roman Stratiienko Cc: linux-sunxi@googlegroups.com, megous@megous.com, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, maz@kernel.org Subject: Re: [PATCH] RFC: arm64: arch_timer: Fix timer inconsistency test for A64 Message-ID: <20200929154012.GF53442@C02TD0UTHF1T.local> References: <20200929111347.1967438-1-r.stratiienko@gmail.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20200929111347.1967438-1-r.stratiienko@gmail.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi, Please Cc maintainers for drivers -- Marc and I maintain the arch timer driver. On Tue, Sep 29, 2020 at 02:13:47PM +0300, Roman Stratiienko wrote: > Fixes linux_kselftest:timers_inconsistency-check_arm_64 > > Test logs without the fix: > ''' > binary returned non-zero. Exit code: 1, stderr: , stdout: > Consistent CLOCK_REALTIME > 1601335525:467086804 > 1601335525:467087554 > 1601335525:467088345 > 1601335525:467089095 > 1601335525:467089887 > 1601335525:467090637 > 1601335525:467091429 > 1601335525:467092179 > 1601335525:467092929 > 1601335525:467093720 > 1601335525:467094470 > 1601335525:467095262 > 1601335525:467096012 > 1601335525:467096804 > -------------------- > 1601335525:467097554 > 1601335525:467077012 That's 0x1BD757D2 followed by 0x1BD70794. The rollback is somewhere in bits 15:12 to go from 0x1BD75xxx to 0x1BD70xxx, which suggests the analysis in the existing comment is incomplete. > -------------------- > 1601335525:467099095 > 1601335525:467099845 > 1601335525:467100637 > 1601335525:467101387 > 1601335525:467102179 > 1601335525:467102929 > ''' It would be very helpful if the commit message could explain the rough idea behind the change, because the rationale is not clear to me. > Signed-off-by: Roman Stratiienko > CC: linux-arm-kernel@lists.infradead.org > CC: linux-kernel@vger.kernel.org > CC: linux-sunxi@googlegroups.com > CC: megous@megous.com > --- > drivers/clocksource/arm_arch_timer.c | 9 +++++---- > 1 file changed, 5 insertions(+), 4 deletions(-) > > diff --git a/drivers/clocksource/arm_arch_timer.c b/drivers/clocksource/arm_arch_timer.c > index 6c3e841801461..d50aa43cb654b 100644 > --- a/drivers/clocksource/arm_arch_timer.c > +++ b/drivers/clocksource/arm_arch_timer.c > @@ -346,16 +346,17 @@ static u64 notrace arm64_858921_read_cntvct_el0(void) > * number of CPU cycles in 3 consecutive 24 MHz counter periods. > */ > #define __sun50i_a64_read_reg(reg) ({ \ > - u64 _val; \ > + u64 _val1, _val2; \ > int _retries = 150; \ > \ > do { \ > - _val = read_sysreg(reg); \ > + _val1 = read_sysreg(reg); \ > + _val2 = read_sysreg(reg); \ > _retries--; \ > - } while (((_val + 1) & GENMASK(9, 0)) <= 1 && _retries); \ > + } while (((_val2 - _val1) > 0x10) && _retries); \ This is going to fail quite often at low CPU frequencies, and it's not clear to me that this solves the problem any more generally. DO we know what the underlying erratum is here? Thanks, Mark. > \ > WARN_ON_ONCE(!_retries); \ > - _val; \ > + _val2; \ > }) > > static u64 notrace sun50i_a64_read_cntpct_el0(void) > -- > 2.25.1 > > > _______________________________________________ > linux-arm-kernel mailing list > linux-arm-kernel@lists.infradead.org > http://lists.infradead.org/mailman/listinfo/linux-arm-kernel