Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp784965ybz; Fri, 1 May 2020 08:30:07 -0700 (PDT) X-Google-Smtp-Source: APiQypIylbXEgUeQVTqZNe0btJZLVjReir4RSfySRUDsiJvnK1QaXLXBH7+OJGzwg4UGakjGowkm X-Received: by 2002:a17:906:f251:: with SMTP id gy17mr3444302ejb.369.1588347007226; Fri, 01 May 2020 08:30:07 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1588347007; cv=none; d=google.com; s=arc-20160816; b=HTyXmotP+LrxV8D0R7yJq5vvqk+HWkIrrfUZ0Bw6BmjdB0XhVJxrhFKcpjEAKe5T3t OL3UxjbpTJLVth+H9q4CIRg+7pY1qYPBbjExVAzoFfctt9ZD8CYFIgi25Xx30tY+lAdN y+NEpwuKkbdC7y6DyR4JPeG0uLR3tSsc76HIjj0+S2UvEuwBKe0TNRvGe2nNz/sPp8vU q2W+foAUyRBUsVw8XwqbbopYmXrU9YpfqInm9cETIvDj9RwhHRRTIJFFdB0vTTGCKdE9 bWBN6OMjG7p1AM/zUSglUdkB7cCgBESaVaS4ZbBpnG5VuuL/TrG19Jw+yQwbhs4RotSQ JLQA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature; bh=6sZqo1tkWIHR/bJjtJ1I3zPxyLvTKT+7HpCs/zy5GP0=; b=IxyzIWhEAB0uB/Aqj6OicLOa2a/ij1WLdadj8vweaZoGJXwydYkLeSptPWvynW5TJ7 eP7iFCN46DBjj0/JKj3YJ7We1PwRk+W2d+s9wO3Stde4o1fPMWOvwscoJel8yCSvHDnD 8HFTwMN4fYdxmrD7sxHb7MNum1rhYP+ZEEMVuRpNUC/uouqwrqjMQoeAWxMrVHZdNwAl +c9N0bKRcPiHCTZM61JlQVYTsdfhxkSPlS9Itzd3rdtkXxC7wQ0N749NBP5svszUBY8m mZLmV+bnaTkn+L4v9669oRY58NyZFEdKBAwf+9I4pkiOnuUFv29m8TVuRA0P3rR+MThy iMFw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=L0SfJ+al; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id n21si2012374ejc.113.2020.05.01.08.29.44; Fri, 01 May 2020 08:30:07 -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; dkim=pass header.i=@kernel.org header.s=default header.b=L0SfJ+al; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729784AbgEAP0Q (ORCPT + 99 others); Fri, 1 May 2020 11:26:16 -0400 Received: from mail.kernel.org ([198.145.29.99]:46580 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728443AbgEAP0P (ORCPT ); Fri, 1 May 2020 11:26:15 -0400 Received: from willie-the-truck (236.31.169.217.in-addr.arpa [217.169.31.236]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id BB1A2206D9; Fri, 1 May 2020 15:26:12 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1588346775; bh=MjFoLfW1BtT4NUArrsrbntaI0HBfUeoxnqplpyIMRUo=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=L0SfJ+alaXKR7XR5Dihir9MiOm2Hi4aU+G0JXpiTBiaO9Ew7PVCEagmNYyU6Hu6qg HJj5JDXmw+/gw2RoEeBL0eosOv7znVbanO7VUo2KKIQ4SJ84fkrT5UUmPGBlH5i8Bb 34UZKOAUJA0SICP6gdqhKOMoThIaC4tZM+OUXxt0= Date: Fri, 1 May 2020 16:26:09 +0100 From: Will Deacon To: Leo Yan Cc: Peter Zijlstra , Marc Zyngier , Mark Rutland , Ingo Molnar , Arnaldo Carvalho de Melo , Alexander Shishkin , Jiri Olsa , Namhyung Kim , Catalin Marinas , linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, Mathieu Poirier , Mike Leach , Al Grant , James Clark , tglx@linutronix.de Subject: Re: [PATCH] arm64: perf_event: Fix time_offset for arch timer Message-ID: <20200501152609.GA17646@willie-the-truck> References: <20200320093545.28227-1-leo.yan@linaro.org> <20200430145823.GA25258@willie-the-truck> <4d924f705245c797a19d3a73eb0c1ba0@kernel.org> <20200430160436.GC13575@hirez.programming.kicks-ass.net> <20200430161815.GE25258@willie-the-truck> <20200501151448.GA9650@leoy-ThinkPad-X240s> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20200501151448.GA9650@leoy-ThinkPad-X240s> User-Agent: Mutt/1.10.1 (2018-07-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, May 01, 2020 at 11:14:48PM +0800, Leo Yan wrote: > On Thu, Apr 30, 2020 at 05:18:15PM +0100, Will Deacon wrote: > > On Thu, Apr 30, 2020 at 06:04:36PM +0200, Peter Zijlstra wrote: > > > On Thu, Apr 30, 2020 at 04:29:23PM +0100, Marc Zyngier wrote: > > > > > > > I wonder if we could/should make __sched_clock_offset available even when > > > > CONFIG_HAVE_UNSTABLE_SCHED_CLOCK isn't defined. It feels like it would > > > > help with this particular can or worm... > > > > > > Errrgh. __sched_clock_offset is only needed on x86 because we transition > > > from one clock device to another on boot. It really shouldn't exist on > > > anything sane. > > > > I think we still transition from jiffies on arm64, because we don't register > > with sched_clock until the timer driver probes. Marc, is that right? > > > > > Let me try and understand your particular problem better. > > > > I think the long and short of it is that userspace needs a way to convert > > the raw counter cycles into a ns value that can be compared against values > > coming out of sched_clock. To do this accurately, I think it needs the > > cycles value at the point when sched_clock was initialised. > > Will's understanding is exactly what I want to resolve in this patch. > > The background info is for the ARM SPE [1] decoding with perf tool, if > the timestamp is enabled, it uses the generic timer's counter as > timestamp source. SPE trace data only contains the raw counter cycles, > as Will mentioned, the perf tool needs to convert it to a coordinate > value with sched_clock. This is why this patch tries to calculate the > offset between the raw counter's ns value and sched_clock, eventually > this offset value will be used by SPE's decoding code in Perf tool to > calibrate a 'correct' timestamp. > > Based on your suggestions, I will use __sched_clock_offset to resolve > the accuracy issue in patch v2. (I noticed Peter suggested to use a > new API for wrapping clock_data structure, IIUC, __sched_clock_offset > is more straightforward for this case). > > Please correct if I miss anything. Thank you for reviewing and > suggestions! I don't think you can use __sched_clock_offset without selecting HAVE_UNSTABLE_SCHED_CLOCK, and we really don't want to do that just for this. So Peter's idea about exposing what we need is better, although you'll probably need to take care with the switch-over from jiffies. It needs some thought, but one possibility would be to introduce a new variant of sthe ched_clock_register() function that returns the cycle offset, and then we could fish that out of the timer driver. If we're crossing all the 'i's and dotting all the 't's then we'd want to disable the perf userpage if sched_clock changes clocksource too (a bit like we do for the vDSO). Will