From patchwork Thu Oct 1 20:51:37 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: "Geva, Erez" X-Patchwork-Id: 267754 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-12.7 required=3.0 tests=BAYES_00, HEADER_FROM_DIFFERENT_DOMAINS, INCLUDES_PATCH, MAILING_LIST_MULTI, SIGNED_OFF_BY, SPF_HELO_NONE, SPF_PASS, URIBL_BLOCKED, USER_AGENT_GIT autolearn=unavailable autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 96776C4727E for ; Thu, 1 Oct 2020 21:08:12 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 694CA206FA for ; Thu, 1 Oct 2020 21:08:12 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1733189AbgJAVIH (ORCPT ); Thu, 1 Oct 2020 17:08:07 -0400 Received: from thoth.sbs.de ([192.35.17.2]:56913 "EHLO thoth.sbs.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726581AbgJAVIG (ORCPT ); Thu, 1 Oct 2020 17:08:06 -0400 Received: from mail3.siemens.de (mail3.siemens.de [139.25.208.14]) by thoth.sbs.de (8.15.2/8.15.2) with ESMTPS id 091KqE4a024200 (version=TLSv1.2 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Thu, 1 Oct 2020 22:52:14 +0200 Received: from tsnlaptop.atstm41.nbgm.siemens.de ([144.145.220.50]) by mail3.siemens.de (8.15.2/8.15.2) with ESMTP id 091KpxYW027868; Thu, 1 Oct 2020 22:52:12 +0200 From: Erez Geva To: linux-kernel@vger.kernel.org, netdev@vger.kernel.org, Cong Wang , "David S . Miller" , Jakub Kicinski , Jamal Hadi Salim , Jiri Pirko , Andrei Vagin , Dmitry Safonov <0x7f454c46@gmail.com>, "Eric W . Biederman" , Ingo Molnar , John Stultz , Michal Kubecek , Oleg Nesterov , Peter Zijlstra , Richard Cochran , Stephen Boyd , Thomas Gleixner , Vladis Dronov , Sebastian Andrzej Siewior , Frederic Weisbecker , Eric Dumazet Cc: Jesus Sanchez-Palencia , Vinicius Costa Gomes , Vedang Patel , Simon Sudler , Andreas Meisinger , Andreas Bucher , Henning Schild , Jan Kiszka , Andreas Zirkler , Ermin Sakic , An Ninh Nguyen , Michael Saenger , Bernd Maehringer , Gisela Greinert , Erez Geva , Erez Geva Subject: [PATCH 3/7] Functions to fetch POSIX dynamic clock object Date: Thu, 1 Oct 2020 22:51:37 +0200 Message-Id: <20201001205141.8885-4-erez.geva.ext@siemens.com> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20201001205141.8885-1-erez.geva.ext@siemens.com> References: <20201001205141.8885-1-erez.geva.ext@siemens.com> MIME-Version: 1.0 Precedence: bulk List-ID: X-Mailing-List: netdev@vger.kernel.org Add kernel functions to fetch a pointer to a POSIX dynamic clock using a user file description dynamic clock ID. Signed-off-by: Erez Geva --- include/linux/posix-clock.h | 39 +++++++++++++++++++ kernel/time/posix-clock.c | 76 +++++++++++++++++++++++++++++++++++++ 2 files changed, 115 insertions(+) diff --git a/include/linux/posix-clock.h b/include/linux/posix-clock.h index 468328b1e1dd..e90bd90d3a01 100644 --- a/include/linux/posix-clock.h +++ b/include/linux/posix-clock.h @@ -116,4 +116,43 @@ int posix_clock_register(struct posix_clock *clk, struct device *dev); */ void posix_clock_unregister(struct posix_clock *clk); +/** + * posix_clock_get_clock() - get reference to a posix clock + * @id: A user clockid that uses a posix clock + * + * Used by kernel code to get a reference to a posix clock. + * Increase the reference count, ensure the referece is not removed. + */ +struct posix_clock *posix_clock_get_clock(clockid_t id); + +/** + * posix_clock_put_clock() - release a reference to a posix clock + * @clk: The reference to a posix clock to release + * + * Release a reference to a posix clock. + * Reduce the reference count. + */ +int posix_clock_put_clock(struct posix_clock *clk); + +/** + * posix_clock_gettime() - get time from posix clock + * @clk: A reference to a posix clock + * @ts: pointer to a time structure used to store the time from the posix clock + * + * Retrieve the time from a posix clock. + * In case the clock device was removed, the function return error. + */ +int posix_clock_gettime(struct posix_clock *clk, struct timespec64 *ts); + +/** + * posix_clock_adjtime() - get tune parameters from posix clock + * @clk: A reference to a posix clock + * @tx: pointer to a kernel timex structure used to store + * the tune parameters from the posix clock + * + * Retrieve the tune parameters from a posix clock. + * In case the clock device was removed, the function return error. + */ +int posix_clock_adjtime(struct posix_clock *clk, struct __kernel_timex *tx); + #endif diff --git a/kernel/time/posix-clock.c b/kernel/time/posix-clock.c index 77c0c2370b6d..1e205eea6ebd 100644 --- a/kernel/time/posix-clock.c +++ b/kernel/time/posix-clock.c @@ -315,3 +315,79 @@ const struct k_clock clock_posix_dynamic = { .clock_get_timespec = pc_clock_gettime, .clock_adj = pc_clock_adjtime, }; + +struct posix_clock *posix_clock_get_clock(clockid_t id) +{ + int err; + struct posix_clock_desc cd; + + /* Verify we use posix clock ID */ + if (!is_clockid_fd_clock(id)) + return ERR_PTR(-EINVAL); + + err = get_clock_desc(id, &cd); + if (err) + return ERR_PTR(err); + + get_device(cd.clk->dev); + + put_clock_desc(&cd); + + return cd.clk; +} +EXPORT_SYMBOL_GPL(posix_clock_get_clock); + +int posix_clock_put_clock(struct posix_clock *clk) +{ + if (IS_ERR_OR_NULL(clk)) + return -EINVAL; + put_device(clk->dev); + return 0; +} +EXPORT_SYMBOL_GPL(posix_clock_put_clock); + +int posix_clock_gettime(struct posix_clock *clk, struct timespec64 *ts) +{ + int err; + + if (IS_ERR_OR_NULL(clk)) + return -EINVAL; + + down_read(&clk->rwsem); + + if (clk->zombie) + err = -ENODEV; + else if (clk->ops.clock_gettime) + err = clk->ops.clock_gettime(clk, ts); + else + err = -EOPNOTSUPP; + + up_read(&clk->rwsem); + return err; +} +EXPORT_SYMBOL_GPL(posix_clock_gettime); + +int posix_clock_adjtime(struct posix_clock *clk, struct __kernel_timex *tx) +{ + int err; + + /* Allow read only */ + if (tx->modes != 0) + return -EINVAL; + + if (IS_ERR_OR_NULL(clk)) + return -EINVAL; + + down_read(&clk->rwsem); + + if (clk->zombie) + err = -ENODEV; + else if (clk->ops.clock_adjtime) + err = clk->ops.clock_adjtime(clk, tx); + else + err = -EOPNOTSUPP; + + up_read(&clk->rwsem); + return err; +} +EXPORT_SYMBOL_GPL(posix_clock_adjtime);