Received: by 2002:a25:d7c1:0:0:0:0:0 with SMTP id o184csp3346409ybg; Fri, 25 Oct 2019 02:47:38 -0700 (PDT) X-Google-Smtp-Source: APXvYqzZUG3xSSRS//PrFFUJ6B2dRulaA8VcdEf9SZAS+Xb1vDqPNRoqfB8C6TptPNwS0s0HMxje X-Received: by 2002:aa7:c498:: with SMTP id m24mr2858305edq.113.1571996858551; Fri, 25 Oct 2019 02:47:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1571996858; cv=none; d=google.com; s=arc-20160816; b=TzhVe+1MCXAGDGj1eeeNFTJD3Sdd4qln5Mmimmw9Mo/opHFakndTjThuw8X1hCb9gp HUf0d+pLnvDHjXGST1kRTrnhu98NWegrGkm/yB4krEalI+mOb9X24mKJAAOQI0irrKum mxO1P6IPXNPJB15gkFPQV/PeEWxDbdhE8zSXtmDQb+mckZUAzSSViGAYP8sKoOHGrYnK +cxNOaY4p9/oPB1cg2cUsQg3mc2SYx1W+iCeuil0jnKWFbEgcKmJ1WJMODofHt+Ak4Le aNYwlo2j14kjf8WTz/47fFUxHdjVhEgzGGUDpICI6Fva6aWVO7g+CA/Xi5YjUF4GGVsw 22HQ== 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=TmfuuPt6OycG0B/gHL0Li1OI5kNRA84gMTstDEJCcTo=; b=oazRUQH7SANmMytIyFUFG8yRRhF/7l/gfUimiUbgcSH5bkiBdZPBaYX9AgS6lrKM1l N9HtfKl8LxzSP7WQFL2ZNsW5ORFf5lVU3yFeBGd0Wxo/36cBonP3AfT3QYbnrSppMLxV 2klRLbtbEnagiWa01N1OByk3uavlV6EVriZcUM6qMe6xHgHPl2NrBBkV/8hVg563heUS 0yEMuUyyv32+V0ri6mG1FJoZ5frYHL4+oKmDFyjEZ6+JYNdv1H+7VtsjWaSVgLNjFET7 5wIWSrWvL2L497k9Gjm+rjx+NzzHpWRM0tTRiFTz5GWtvrFv+H/ynYimLIXlxuKbtt3/ DkJA== 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 f51si880119edb.421.2019.10.25.02.47.14; Fri, 25 Oct 2019 02:47:38 -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 S2393445AbfJXLDA (ORCPT + 99 others); Thu, 24 Oct 2019 07:03:00 -0400 Received: from foss.arm.com ([217.140.110.172]:47502 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2390265AbfJXLC7 (ORCPT ); Thu, 24 Oct 2019 07:02:59 -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 59DDF7A7; Thu, 24 Oct 2019 04:02:45 -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 644D13F71A; Thu, 24 Oct 2019 04:02:40 -0700 (PDT) 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 v6 4/7] time: Add mechanism to recognize clocksource in time_get_snapshot Date: Thu, 24 Oct 2019 19:02:06 +0800 Message-Id: <20191024110209.21328-5-jianyong.wu@arm.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20191024110209.21328-1-jianyong.wu@arm.com> References: <20191024110209.21328-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. This patch add a mechanism 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/timekeeping.h | 12 +++++++----- kernel/time/clocksource.c | 3 +++ kernel/time/timekeeping.c | 1 + 4 files changed, 17 insertions(+), 5 deletions(-) diff --git a/include/linux/clocksource.h b/include/linux/clocksource.h index b21db536fd52..ac8016b22734 100644 --- a/include/linux/clocksource.h +++ b/include/linux/clocksource.h @@ -19,6 +19,7 @@ #include #include #include +#include struct clocksource; struct module; @@ -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/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