Received: by 2002:a25:c593:0:0:0:0:0 with SMTP id v141csp5201198ybe; Tue, 17 Sep 2019 04:27:36 -0700 (PDT) X-Google-Smtp-Source: APXvYqzUpVW77S5pBDex+hicfctsB+I8rFmbeQIMBShh4wVgn8uOXaatm0Dy5+OV1TTVgcF/IAk4 X-Received: by 2002:a50:f009:: with SMTP id r9mr4131131edl.195.1568719656705; Tue, 17 Sep 2019 04:27:36 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1568719656; cv=none; d=google.com; s=arc-20160816; b=U2IyepEI4YxqtqjycKkMMjLIKI/VElCUm+INLPQc94zV8HIaApuhA6oXgzdgx4o4sl G+AVqs7F9/3yAmLvqxnShKTQoQco93f67qMzitjYGboc68cMXdH8kwhHnqFsQTuBthPD VViNwvm2EBAk5rNgeM0T9OGPX99OOm9M/Mec4dAVmu/hkZpjxukhO/znqAf+1bjkhg79 7t9Lyv7C1QRs+Yy8KqeklwALAtLQTaAsCjOK2JMgqDwnXA3S9cV6Xvk+P3m3QcboUS8c Jhnx4/V1JUfN+Rj6XFMOEPF2qxgX0GPOl+Z4Hm+mF2b95Yh0MOkVmfWyRIpfLqFIr4Ln lJ8Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from; bh=k6m2hvLb5kvFO9Yxopg4Ow+/oKH5YML0Gnv8S7ZAi38=; b=dEyzNatpBg9L8bfeIbEpWnbIeY6tFjeErRktKw1Jab53PVCLSPh8i8eT5491LZTDIj fI6cP9mk8MnphSR9lop2vaA6h6MJlQoO3AaZzOVf9qRlAZ7L2u93QW+q5IRgxwP1Hc8G kL+URi7rVe15vEVpAyYLrDGp0HYIzQfaeDZFV4Xwv9EzX9KptdHc2wbuu+7OS2UjTPll k8Fz9t5+QJ052u2+4VQ4uq+BzJqKlpzSnNIgrvPBnm7ubl5xD9J1oKlYOhauI2RD87wF j5hsQQiJd6SZmoyTeqLb6ELMe0Zr4BMZzHO+GK5AggQI7CefzKoUAkGPR6V7IJDzsvnA uVCQ== ARC-Authentication-Results: i=1; mx.google.com; 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 g20si909909eje.364.2019.09.17.04.27.10; Tue, 17 Sep 2019 04:27:36 -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; 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 S1727309AbfIQLZM (ORCPT + 99 others); Tue, 17 Sep 2019 07:25:12 -0400 Received: from foss.arm.com ([217.140.110.172]:54654 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727262AbfIQLZK (ORCPT ); Tue, 17 Sep 2019 07:25:10 -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 331E81570; Tue, 17 Sep 2019 04:25:10 -0700 (PDT) Received: from entos-d05.shanghai.arm.com (entos-d05.shanghai.arm.com [10.169.40.35]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPA id 5CFDB3F59C; Tue, 17 Sep 2019 04:25:07 -0700 (PDT) From: Jianyong Wu To: netdev@vger.kernel.org, pbonzini@redhat.com, sean.j.christopherson@intel.com, maz@kernel.org, richardcochran@gmail.com, Mark.Rutland@arm.com, Will.Deacon@arm.com, suzuki.poulose@arm.com Cc: linux-kernel@vger.kernel.org, Steve.Capper@arm.com, Kaly.Xin@arm.com, justin.he@arm.com, jianyong.wu@arm.com, nd@arm.com, linux-arm-kernel@lists.infradead.org Subject: [PATCH 3/6] Timer: expose monotonic clock and counter value Date: Tue, 17 Sep 2019 07:24:27 -0400 Message-Id: <20190917112430.45680-4-jianyong.wu@arm.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20190917112430.45680-1-jianyong.wu@arm.com> References: <20190917112430.45680-1-jianyong.wu@arm.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org A number of PTP drivers (such as ptp-kvm) are assuming what the current clock source is, which could lead to interesting effects on systems where the clocksource can change depending on external events. For this purpose, add a new API that retrives both the current monotonic clock as well as its counter value. Signed-off-by: Marc Zyngier Signed-off-by: Jianyong Wu --- include/linux/timekeeping.h | 3 +++ kernel/time/timekeeping.c | 13 +++++++++++++ 2 files changed, 16 insertions(+) diff --git a/include/linux/timekeeping.h b/include/linux/timekeeping.h index a8ab0f143ac4..a5389adaa8bc 100644 --- a/include/linux/timekeeping.h +++ b/include/linux/timekeeping.h @@ -247,6 +247,9 @@ extern int get_device_system_crosststamp( struct system_time_snapshot *history, struct system_device_crosststamp *xtstamp); +/* Obtain current monotonic clock and its counter value */ +extern void get_current_counterval(struct system_counterval_t *sc); + /* * Simultaneously snapshot realtime and monotonic raw clocks */ diff --git a/kernel/time/timekeeping.c b/kernel/time/timekeeping.c index 44b726bab4bd..07a0969625b1 100644 --- a/kernel/time/timekeeping.c +++ b/kernel/time/timekeeping.c @@ -1098,6 +1098,19 @@ static bool cycle_between(u64 before, u64 test, u64 after) return false; } +/** + * get_current_counterval - Snapshot the current clocksource and counter value + * @sc: Pointer to a struct containing the current clocksource and its value + */ +void get_current_counterval(struct system_counterval_t *sc) +{ + struct timekeeper *tk = &tk_core.timekeeper; + + sc->cs = READ_ONCE(tk->tkr_mono.clock); + sc->cycles = sc->cs->read(sc->cs); +} +EXPORT_SYMBOL_GPL(get_current_counterval); + /** * get_device_system_crosststamp - Synchronously capture system/device timestamp * @get_time_fn: Callback to get simultaneous device time and -- 2.17.1