Received: by 2002:a25:7ec1:0:0:0:0:0 with SMTP id z184csp3113964ybc; Thu, 14 Nov 2019 04:16:25 -0800 (PST) X-Google-Smtp-Source: APXvYqwNQidfPRLjqtIJUrART6VKgiV6uAx7PJECCxvBn20TiINzA/+P6Y8nMXtq2EKclUk6c+YB X-Received: by 2002:a50:cc07:: with SMTP id m7mr884266edi.146.1573733785534; Thu, 14 Nov 2019 04:16:25 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1573733785; cv=none; d=google.com; s=arc-20160816; b=yBtjcX5DiPt9v/NwTXkV0KowDU0mDhIan6dnhI02Ae4iY7eqNWosoDYWY/iVImnL8h swg9/ppc6upD8zzIKoQMbVahJcvhHDmoBdz2E0JtkBCRnpv7SN3eISBT8yUKNMtoSzwC 02qGrTrr9tuTcLKUHj8bZ6JCyeHD9p0Y/oo5vftF6jKV1aqciOJavo5RpcjFGsGBWGWh +57ocorrv26efi6MfXaju/LAu/sHGPCa3tpZyU9xJWz/Eoi8cUiqmOXWZruKjILSlmAb xVYTpulTIWxzKRsLg01zHx685psbl5WRqg4khC3X4um7OQ8WBmzFg+ykP+5fAJ21jNf2 /8/w== 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=81iq2CtYih7JFnXujksNMkvSAmWOutS4jkftFb9rQDg=; b=RWlMzqdTOmot+tv4mJ4QbA5ZRx/IxGGWfEqWCh8T+I+yLFdh3jCXL1G188LunXf2LJ 8JDjZN/W6zUN/yNkySALnQXM/ylE255YyRe/kJVTtzl2P9X4Db1zS9zDK4ftEoHr2owq hfl/f0fYmoozp0upQzhEo9DRIANBkg+mGVNCFgKTEMOi+y5mpPDd7AAsV0byMkKsRAMZ 21hRaIXLf63D5Ez+lqr55YtHY9OUncI/BlsXV6BZxC7pkrdOQy1HGVpmu5vf7K5sd8U2 DSYm5kzU4cbkb95EcjWY+bCSSnis5Tugoy241wlaP0MfmZ1Dqb2qbe0dIZ3EBhujgnDa FxeQ== 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 t18si3461931eji.130.2019.11.14.04.16.01; Thu, 14 Nov 2019 04:16:25 -0800 (PST) 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 S1727178AbfKNMOq (ORCPT + 99 others); Thu, 14 Nov 2019 07:14:46 -0500 Received: from foss.arm.com ([217.140.110.172]:41946 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727136AbfKNMOo (ORCPT ); Thu, 14 Nov 2019 07:14:44 -0500 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 76CE631B; Thu, 14 Nov 2019 04:14:43 -0800 (PST) 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 D036F3F6C4; Thu, 14 Nov 2019 04:14:37 -0800 (PST) From: Jianyong Wu To: netdev@vger.kernel.org, yangbo.lu@nxp.com, john.stultz@linaro.org, tglx@linutronix.de, pbonzini@redhat.com, sean.j.christopherson@intel.com, maz@kernel.org, richardcochran@gmail.com, Mark.Rutland@arm.com, will@kernel.org, suzuki.poulose@arm.com Cc: linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, kvmarm@lists.cs.columbia.edu, kvm@vger.kernel.org, Steve.Capper@arm.com, Kaly.Xin@arm.com, justin.he@arm.com, jianyong.wu@arm.com, nd@arm.com Subject: [RFC PATCH v7 4/7] time: Add mechanism to recognize clocksource in time_get_snapshot Date: Thu, 14 Nov 2019 20:13:55 +0800 Message-Id: <20191114121358.6684-5-jianyong.wu@arm.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20191114121358.6684-1-jianyong.wu@arm.com> References: <20191114121358.6684-1-jianyong.wu@arm.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Thomas Gleixner In some scenario like return device time to ptp_kvm guest, we need identify the current clocksource outside core time code. A mechanism added to recognize the current clocksource by export clocksource id in time_get_snapshot. Signed-off-by: Thomas Gleixner Signed-off-by: Jianyong Wu --- include/linux/clocksource.h | 6 ++++++ include/linux/clocksource_ids.h | 13 +++++++++++++ include/linux/timekeeping.h | 12 +++++++----- kernel/time/clocksource.c | 3 +++ kernel/time/timekeeping.c | 1 + 5 files changed, 30 insertions(+), 5 deletions(-) create mode 100644 include/linux/clocksource_ids.h diff --git a/include/linux/clocksource.h b/include/linux/clocksource.h index b21db536fd52..96e85b6f9ca0 100644 --- a/include/linux/clocksource.h +++ b/include/linux/clocksource.h @@ -17,6 +17,7 @@ #include #include #include +#include #include #include @@ -49,6 +50,10 @@ struct module; * 400-499: Perfect * The ideal clocksource. A must-use where * available. + * @id: Defaults to CSID_GENERIC. The id value is captured + * in certain snapshot functions to allow callers to + * validate the clocksource from which the snapshot was + * taken. * @read: returns a cycle value, passes clocksource as argument * @enable: optional function to enable the clocksource * @disable: optional function to disable the clocksource @@ -91,6 +96,7 @@ struct clocksource { const char *name; struct list_head list; int rating; + enum clocksource_ids id; int (*enable)(struct clocksource *cs); void (*disable)(struct clocksource *cs); unsigned long flags; diff --git a/include/linux/clocksource_ids.h b/include/linux/clocksource_ids.h new file mode 100644 index 000000000000..93bec8426c44 --- /dev/null +++ b/include/linux/clocksource_ids.h @@ -0,0 +1,13 @@ +/* SPDX-License-Identifier: GPL-2.0 */ +#ifndef _LINUX_CLOCKSOURCE_IDS_H +#define _LINUX_CLOCKSOURCE_IDS_H + +/* Enum to give clocksources a unique identifier */ +enum clocksource_ids { + CSID_GENERIC = 0, + CSID_ARM_ARCH_COUNTER, + CSID_MAX, +}; + +#endif + diff --git a/include/linux/timekeeping.h b/include/linux/timekeeping.h index a8ab0f143ac4..ecce56269a7e 100644 --- a/include/linux/timekeeping.h +++ b/include/linux/timekeeping.h @@ -2,6 +2,7 @@ #ifndef _LINUX_TIMEKEEPING_H #define _LINUX_TIMEKEEPING_H +#include #include /* Included from linux/ktime.h */ @@ -204,11 +205,12 @@ extern void timekeeping_inject_sleeptime64(const struct timespec64 *delta); * @cs_was_changed_seq: The sequence number of clocksource change events */ struct system_time_snapshot { - u64 cycles; - ktime_t real; - ktime_t raw; - unsigned int clock_was_set_seq; - u8 cs_was_changed_seq; + u64 cycles; + ktime_t real; + ktime_t raw; + enum clocksource_ids cs_id; + unsigned int clock_was_set_seq; + u8 cs_was_changed_seq; }; /* diff --git a/kernel/time/clocksource.c b/kernel/time/clocksource.c index 3bcc19ceb073..26a3add61771 100644 --- a/kernel/time/clocksource.c +++ b/kernel/time/clocksource.c @@ -921,6 +921,9 @@ int __clocksource_register_scale(struct clocksource *cs, u32 scale, u32 freq) clocksource_arch_init(cs); + if (WARN_ON_ONCE((unsigned int)cs->id >= CSID_MAX)) + cs->id = CSID_GENERIC; + /* Initialize mult/shift and max_idle_ns */ __clocksource_update_freq_scale(cs, scale, freq); diff --git a/kernel/time/timekeeping.c b/kernel/time/timekeeping.c index 44b726bab4bd..88078cff7fe2 100644 --- a/kernel/time/timekeeping.c +++ b/kernel/time/timekeeping.c @@ -974,6 +974,7 @@ void ktime_get_snapshot(struct system_time_snapshot *systime_snapshot) do { seq = read_seqcount_begin(&tk_core.seq); now = tk_clock_read(&tk->tkr_mono); + systime_snapshot->cs_id = tk->tkr_mono.clock->id; systime_snapshot->cs_was_changed_seq = tk->cs_was_changed_seq; systime_snapshot->clock_was_set_seq = tk->clock_was_set_seq; base_real = ktime_add(tk->tkr_mono.base, -- 2.17.1