From patchwork Thu Oct 1 20:51:35 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: "Geva, Erez" X-Patchwork-Id: 267757 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 0C296C4727F for ; Thu, 1 Oct 2020 21:03:04 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id D656720759 for ; Thu, 1 Oct 2020 21:03:03 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1733059AbgJAVDA (ORCPT ); Thu, 1 Oct 2020 17:03:00 -0400 Received: from goliath.siemens.de ([192.35.17.28]:55423 "EHLO goliath.siemens.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726606AbgJAVDA (ORCPT ); Thu, 1 Oct 2020 17:03:00 -0400 Received: from mail3.siemens.de (mail3.siemens.de [139.25.208.14]) by goliath.siemens.de (8.15.2/8.15.2) with ESMTPS id 091Kq7rb008970 (version=TLSv1.2 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Thu, 1 Oct 2020 22:52:07 +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 091KpxYU027868; Thu, 1 Oct 2020 22:52:06 +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 1/7] POSIX clock ID check function Date: Thu, 1 Oct 2020 22:51:35 +0200 Message-Id: <20201001205141.8885-2-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 function to check whether a clock ID refer to a file descriptor of a POSIX dynamic clock. Signed-off-by: Erez Geva --- include/linux/posix-timers.h | 5 +++++ kernel/time/posix-timers.c | 2 +- 2 files changed, 6 insertions(+), 1 deletion(-) diff --git a/include/linux/posix-timers.h b/include/linux/posix-timers.h index 896c16d2c5fb..7cb551bbb763 100644 --- a/include/linux/posix-timers.h +++ b/include/linux/posix-timers.h @@ -57,6 +57,11 @@ static inline int clockid_to_fd(const clockid_t clk) return ~(clk >> 3); } +static inline bool is_clockid_fd_clock(const clockid_t clk) +{ + return (clk < 0) && ((clk & CLOCKFD_MASK) == CLOCKFD); +} + #ifdef CONFIG_POSIX_TIMERS /** diff --git a/kernel/time/posix-timers.c b/kernel/time/posix-timers.c index bf540f5a4115..806465233303 100644 --- a/kernel/time/posix-timers.c +++ b/kernel/time/posix-timers.c @@ -1400,7 +1400,7 @@ static const struct k_clock *clockid_to_kclock(const clockid_t id) clockid_t idx = id; if (id < 0) { - return (id & CLOCKFD_MASK) == CLOCKFD ? + return is_clockid_fd_clock(id) ? &clock_posix_dynamic : &clock_posix_cpu; } From patchwork Thu Oct 1 20:51:36 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: "Geva, Erez" X-Patchwork-Id: 267152 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 D84E6C4727E for ; Thu, 1 Oct 2020 21:01:45 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 8A9B3207FB for ; Thu, 1 Oct 2020 21:01:45 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2387456AbgJAVBi (ORCPT ); Thu, 1 Oct 2020 17:01:38 -0400 Received: from david.siemens.de ([192.35.17.14]:54231 "EHLO david.siemens.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726515AbgJAVBh (ORCPT ); Thu, 1 Oct 2020 17:01:37 -0400 Received: from mail3.siemens.de (mail3.siemens.de [139.25.208.14]) by david.siemens.de (8.15.2/8.15.2) with ESMTPS id 091KqBeE029008 (version=TLSv1.2 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Thu, 1 Oct 2020 22:52:11 +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 091KpxYV027868; Thu, 1 Oct 2020 22:52:09 +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 2/7] Function to retrieve main clock state Date: Thu, 1 Oct 2020 22:51:36 +0200 Message-Id: <20201001205141.8885-3-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 function to retrieve main clock oscillator state. As calibration is done from user space daemon, the kernel access function permit read only. Signed-off-by: Erez Geva --- include/linux/timex.h | 1 + kernel/time/timekeeping.c | 9 +++++++++ 2 files changed, 10 insertions(+) diff --git a/include/linux/timex.h b/include/linux/timex.h index ce0859763670..03bc63bf3073 100644 --- a/include/linux/timex.h +++ b/include/linux/timex.h @@ -153,6 +153,7 @@ extern unsigned long tick_nsec; /* SHIFTED_HZ period (nsec) */ extern int do_adjtimex(struct __kernel_timex *); extern int do_clock_adjtime(const clockid_t which_clock, struct __kernel_timex * ktx); +extern int adjtimex(struct __kernel_timex *txc); extern void hardpps(const struct timespec64 *, const struct timespec64 *); diff --git a/kernel/time/timekeeping.c b/kernel/time/timekeeping.c index 4c47f388a83f..2248fa257ff8 100644 --- a/kernel/time/timekeeping.c +++ b/kernel/time/timekeeping.c @@ -2372,6 +2372,15 @@ int do_adjtimex(struct __kernel_timex *txc) return ret; } +int adjtimex(struct __kernel_timex *txc) +{ + if (txc->modes != 0) + return -EINVAL; + + return do_adjtimex(txc); +} +EXPORT_SYMBOL_GPL(adjtimex); + #ifdef CONFIG_NTP_PPS /** * hardpps() - Accessor function to NTP __hardpps function 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); From patchwork Thu Oct 1 20:51:38 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: "Geva, Erez" X-Patchwork-Id: 267153 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 BE94DC4741F for ; Thu, 1 Oct 2020 21:01:32 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 8469220759 for ; Thu, 1 Oct 2020 21:01:32 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1733104AbgJAVBa (ORCPT ); Thu, 1 Oct 2020 17:01:30 -0400 Received: from david.siemens.de ([192.35.17.14]:54201 "EHLO david.siemens.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726515AbgJAVBa (ORCPT ); Thu, 1 Oct 2020 17:01:30 -0400 X-Greylist: delayed 531 seconds by postgrey-1.27 at vger.kernel.org; Thu, 01 Oct 2020 17:01:28 EDT Received: from mail3.siemens.de (mail3.siemens.de [139.25.208.14]) by david.siemens.de (8.15.2/8.15.2) with ESMTPS id 091KqGnL029133 (version=TLSv1.2 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Thu, 1 Oct 2020 22:52:16 +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 091KpxYX027868; Thu, 1 Oct 2020 22:52:15 +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 4/7] Fix qdisc_watchdog_schedule_range_ns range check Date: Thu, 1 Oct 2020 22:51:38 +0200 Message-Id: <20201001205141.8885-5-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 - As all parameters are unsigned. - If 'expires' is bigger than 'last_expires' then the left expression overflows. - It is better to use addition and check both ends of the range. Signed-off-by: Erez Geva --- net/sched/sch_api.c | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/net/sched/sch_api.c b/net/sched/sch_api.c index 2a76a2f5ed88..ebf59ca1faab 100644 --- a/net/sched/sch_api.c +++ b/net/sched/sch_api.c @@ -632,7 +632,8 @@ void qdisc_watchdog_schedule_range_ns(struct qdisc_watchdog *wd, u64 expires, /* If timer is already set in [expires, expires + delta_ns], * do not reprogram it. */ - if (wd->last_expires - expires <= delta_ns) + if (wd->last_expires >= expires && + wd->last_expires <= expires + delta_ns) return; } From patchwork Thu Oct 1 20:51:39 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: "Geva, Erez" X-Patchwork-Id: 267151 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 E6836C4727F for ; Thu, 1 Oct 2020 21:03:18 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id B4713207FB for ; Thu, 1 Oct 2020 21:03:18 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2387479AbgJAVDP (ORCPT ); Thu, 1 Oct 2020 17:03:15 -0400 Received: from goliath.siemens.de ([192.35.17.28]:55485 "EHLO goliath.siemens.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2387429AbgJAVDP (ORCPT ); Thu, 1 Oct 2020 17:03:15 -0400 Received: from mail3.siemens.de (mail3.siemens.de [139.25.208.14]) by goliath.siemens.de (8.15.2/8.15.2) with ESMTPS id 091KqJ5M009276 (version=TLSv1.2 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Thu, 1 Oct 2020 22:52:19 +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 091KpxYY027868; Thu, 1 Oct 2020 22:52:18 +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 5/7] Traffic control using high-resolution timer issue Date: Thu, 1 Oct 2020 22:51:39 +0200 Message-Id: <20201001205141.8885-6-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 new schedule function for Qdisc watchdog. The function avoids reprogram if watchdog already expire before new expire. - Use new schedule function in ETF. - Add ETF range value to kernel configuration. as the value is characteristic to Hardware. Signed-off-by: Erez Geva --- include/net/pkt_sched.h | 2 ++ net/sched/Kconfig | 8 ++++++++ net/sched/sch_api.c | 33 +++++++++++++++++++++++++++++++++ net/sched/sch_etf.c | 10 ++++++++-- 4 files changed, 51 insertions(+), 2 deletions(-) diff --git a/include/net/pkt_sched.h b/include/net/pkt_sched.h index ac8c890a2657..4306c2773778 100644 --- a/include/net/pkt_sched.h +++ b/include/net/pkt_sched.h @@ -78,6 +78,8 @@ void qdisc_watchdog_init(struct qdisc_watchdog *wd, struct Qdisc *qdisc); void qdisc_watchdog_schedule_range_ns(struct qdisc_watchdog *wd, u64 expires, u64 delta_ns); +void qdisc_watchdog_schedule_soon_ns(struct qdisc_watchdog *wd, u64 expires, + u64 delta_ns); static inline void qdisc_watchdog_schedule_ns(struct qdisc_watchdog *wd, u64 expires) diff --git a/net/sched/Kconfig b/net/sched/Kconfig index a3b37d88800e..0f5261ee9e1b 100644 --- a/net/sched/Kconfig +++ b/net/sched/Kconfig @@ -195,6 +195,14 @@ config NET_SCH_ETF To compile this code as a module, choose M here: the module will be called sch_etf. +config NET_SCH_ETF_TIMER_RANGE + int "ETF Watchdog time range delta in nano seconds" + depends on NET_SCH_ETF + default 5000 + help + Specify the time range delta for ETF watchdog + Default is 5 microsecond + config NET_SCH_TAPRIO tristate "Time Aware Priority (taprio) Scheduler" help diff --git a/net/sched/sch_api.c b/net/sched/sch_api.c index ebf59ca1faab..80bd09555f5e 100644 --- a/net/sched/sch_api.c +++ b/net/sched/sch_api.c @@ -645,6 +645,39 @@ void qdisc_watchdog_schedule_range_ns(struct qdisc_watchdog *wd, u64 expires, } EXPORT_SYMBOL(qdisc_watchdog_schedule_range_ns); +void qdisc_watchdog_schedule_soon_ns(struct qdisc_watchdog *wd, u64 expires, + u64 delta_ns) +{ + if (test_bit(__QDISC_STATE_DEACTIVATED, + &qdisc_root_sleeping(wd->qdisc)->state)) + return; + + if (wd->last_expires == expires) + return; + + /** + * If expires is in [0, now + delta_ns], + * do not program it. + */ + if (expires <= ktime_to_ns(hrtimer_cb_get_time(&wd->timer)) + delta_ns) + return; + + /** + * If timer is already set in [0, expires + delta_ns], + * do not reprogram it. + */ + if (hrtimer_is_queued(&wd->timer) && + wd->last_expires <= expires + delta_ns) + return; + + wd->last_expires = expires; + hrtimer_start_range_ns(&wd->timer, + ns_to_ktime(expires), + delta_ns, + HRTIMER_MODE_ABS_PINNED); +} +EXPORT_SYMBOL(qdisc_watchdog_schedule_soon_ns); + void qdisc_watchdog_cancel(struct qdisc_watchdog *wd) { hrtimer_cancel(&wd->timer); diff --git a/net/sched/sch_etf.c b/net/sched/sch_etf.c index c48f91075b5c..48b2868c4672 100644 --- a/net/sched/sch_etf.c +++ b/net/sched/sch_etf.c @@ -20,6 +20,11 @@ #include #include +#ifdef CONFIG_NET_SCH_ETF_TIMER_RANGE +#define NET_SCH_ETF_TIMER_RANGE CONFIG_NET_SCH_ETF_TIMER_RANGE +#else +#define NET_SCH_ETF_TIMER_RANGE (5 * NSEC_PER_USEC) +#endif #define DEADLINE_MODE_IS_ON(x) ((x)->flags & TC_ETF_DEADLINE_MODE_ON) #define OFFLOAD_IS_ON(x) ((x)->flags & TC_ETF_OFFLOAD_ON) #define SKIP_SOCK_CHECK_IS_SET(x) ((x)->flags & TC_ETF_SKIP_SOCK_CHECK) @@ -128,8 +133,9 @@ static void reset_watchdog(struct Qdisc *sch) return; } - next = ktime_sub_ns(skb->tstamp, q->delta); - qdisc_watchdog_schedule_ns(&q->watchdog, ktime_to_ns(next)); + next = ktime_sub_ns(skb->tstamp, q->delta + NET_SCH_ETF_TIMER_RANGE); + qdisc_watchdog_schedule_soon_ns(&q->watchdog, ktime_to_ns(next), + NET_SCH_ETF_TIMER_RANGE); } static void report_sock_error(struct sk_buff *skb, u32 err, u8 code) From patchwork Thu Oct 1 20:51:40 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: "Geva, Erez" X-Patchwork-Id: 267149 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 B72C0C4741F for ; Thu, 1 Oct 2020 21:08:17 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 85EF0206FA for ; Thu, 1 Oct 2020 21:08:17 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1733218AbgJAVIP (ORCPT ); Thu, 1 Oct 2020 17:08:15 -0400 Received: from thoth.sbs.de ([192.35.17.2]:56967 "EHLO thoth.sbs.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726581AbgJAVIO (ORCPT ); Thu, 1 Oct 2020 17:08:14 -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 091KqMDn024403 (version=TLSv1.2 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Thu, 1 Oct 2020 22:52:22 +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 091KpxYZ027868; Thu, 1 Oct 2020 22:52:21 +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 6/7] TC-ETF code improvements Date: Thu, 1 Oct 2020 22:51:40 +0200 Message-Id: <20201001205141.8885-7-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 - Change clockid to use clockid_t type. - Pass pointer to ETF private structure to local function instead of retrieving it from Qdisc object again. - fix comment. Signed-off-by: Erez Geva --- net/sched/sch_etf.c | 38 +++++++++++++++++--------------------- 1 file changed, 17 insertions(+), 21 deletions(-) diff --git a/net/sched/sch_etf.c b/net/sched/sch_etf.c index 48b2868c4672..c0de4c6f9299 100644 --- a/net/sched/sch_etf.c +++ b/net/sched/sch_etf.c @@ -33,7 +33,7 @@ struct etf_sched_data { bool offload; bool deadline_mode; bool skip_sock_check; - int clockid; + clockid_t clockid; int queue; s32 delta; /* in ns */ ktime_t last; /* The txtime of the last skb sent to the netdevice. */ @@ -54,7 +54,7 @@ static inline int validate_input_params(struct tc_etf_qopt *qopt, * * * Dynamic clockids are not supported. * - * * Delta must be a positive integer. + * * Delta must be a positive or zero integer. * * Also note that for the HW offload case, we must * expect that system clocks have been synchronized to PHC. @@ -77,9 +77,9 @@ static inline int validate_input_params(struct tc_etf_qopt *qopt, return 0; } -static bool is_packet_valid(struct Qdisc *sch, struct sk_buff *nskb) +static bool is_packet_valid(struct Qdisc *sch, struct etf_sched_data *q, + struct sk_buff *nskb) { - struct etf_sched_data *q = qdisc_priv(sch); ktime_t txtime = nskb->tstamp; struct sock *sk = nskb->sk; ktime_t now; @@ -122,9 +122,8 @@ static struct sk_buff *etf_peek_timesortedlist(struct Qdisc *sch) return rb_to_skb(p); } -static void reset_watchdog(struct Qdisc *sch) +static void reset_watchdog(struct Qdisc *sch, struct etf_sched_data *q) { - struct etf_sched_data *q = qdisc_priv(sch); struct sk_buff *skb = etf_peek_timesortedlist(sch); ktime_t next; @@ -173,7 +172,7 @@ static int etf_enqueue_timesortedlist(struct sk_buff *nskb, struct Qdisc *sch, ktime_t txtime = nskb->tstamp; bool leftmost = true; - if (!is_packet_valid(sch, nskb)) { + if (!is_packet_valid(sch, q, nskb)) { report_sock_error(nskb, EINVAL, SO_EE_CODE_TXTIME_INVALID_PARAM); return qdisc_drop(nskb, sch, to_free); @@ -198,15 +197,14 @@ static int etf_enqueue_timesortedlist(struct sk_buff *nskb, struct Qdisc *sch, sch->q.qlen++; /* Now we may need to re-arm the qdisc watchdog for the next packet. */ - reset_watchdog(sch); + reset_watchdog(sch, q); return NET_XMIT_SUCCESS; } -static void timesortedlist_drop(struct Qdisc *sch, struct sk_buff *skb, - ktime_t now) +static void timesortedlist_drop(struct Qdisc *sch, struct etf_sched_data *q, + struct sk_buff *skb, ktime_t now) { - struct etf_sched_data *q = qdisc_priv(sch); struct sk_buff *to_free = NULL; struct sk_buff *tmp = NULL; @@ -234,10 +232,9 @@ static void timesortedlist_drop(struct Qdisc *sch, struct sk_buff *skb, kfree_skb_list(to_free); } -static void timesortedlist_remove(struct Qdisc *sch, struct sk_buff *skb) +static void timesortedlist_remove(struct Qdisc *sch, struct etf_sched_data *q, + struct sk_buff *skb) { - struct etf_sched_data *q = qdisc_priv(sch); - rb_erase_cached(&skb->rbnode, &q->head); /* The rbnode field in the skb re-uses these fields, now that @@ -270,7 +267,7 @@ static struct sk_buff *etf_dequeue_timesortedlist(struct Qdisc *sch) /* Drop if packet has expired while in queue. */ if (ktime_before(skb->tstamp, now)) { - timesortedlist_drop(sch, skb, now); + timesortedlist_drop(sch, q, skb, now); skb = NULL; goto out; } @@ -279,7 +276,7 @@ static struct sk_buff *etf_dequeue_timesortedlist(struct Qdisc *sch) * txtime from deadline to (now + delta). */ if (q->deadline_mode) { - timesortedlist_remove(sch, skb); + timesortedlist_remove(sch, q, skb); skb->tstamp = now; goto out; } @@ -288,13 +285,13 @@ static struct sk_buff *etf_dequeue_timesortedlist(struct Qdisc *sch) /* Dequeue only if now is within the [txtime - delta, txtime] range. */ if (ktime_after(now, next)) - timesortedlist_remove(sch, skb); + timesortedlist_remove(sch, q, skb); else skb = NULL; out: /* Now we may need to re-arm the qdisc watchdog for the next packet. */ - reset_watchdog(sch); + reset_watchdog(sch, q); return skb; } @@ -423,9 +420,8 @@ static int etf_init(struct Qdisc *sch, struct nlattr *opt, return 0; } -static void timesortedlist_clear(struct Qdisc *sch) +static void timesortedlist_clear(struct Qdisc *sch, struct etf_sched_data *q) { - struct etf_sched_data *q = qdisc_priv(sch); struct rb_node *p = rb_first_cached(&q->head); while (p) { @@ -448,7 +444,7 @@ static void etf_reset(struct Qdisc *sch) qdisc_watchdog_cancel(&q->watchdog); /* No matter which mode we are on, it's safe to clear both lists. */ - timesortedlist_clear(sch); + timesortedlist_clear(sch, q); __qdisc_reset_queue(&sch->q); sch->qstats.backlog = 0; From patchwork Thu Oct 1 20:51:41 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: "Geva, Erez" X-Patchwork-Id: 267753 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 552A2C4727F for ; Thu, 1 Oct 2020 21:08:28 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 2719E20754 for ; Thu, 1 Oct 2020 21:08:28 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2387407AbgJAVIX (ORCPT ); Thu, 1 Oct 2020 17:08:23 -0400 Received: from thoth.sbs.de ([192.35.17.2]:57031 "EHLO thoth.sbs.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726581AbgJAVIV (ORCPT ); Thu, 1 Oct 2020 17:08:21 -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 091KqPvE024446 (version=TLSv1.2 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Thu, 1 Oct 2020 22:52:25 +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 091KpxYa027868; Thu, 1 Oct 2020 22:52:24 +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 7/7] TC-ETF support PTP clocks Date: Thu, 1 Oct 2020 22:51:41 +0200 Message-Id: <20201001205141.8885-8-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 support for using a POSIX dynamic clock with Traffic control Earliest TxTime First (ETF) Qdisc. Signed-off-by: Erez Geva --- include/uapi/linux/net_tstamp.h | 5 ++ net/sched/sch_etf.c | 100 +++++++++++++++++++++++++++++--- 2 files changed, 97 insertions(+), 8 deletions(-) diff --git a/include/uapi/linux/net_tstamp.h b/include/uapi/linux/net_tstamp.h index 7ed0b3d1c00a..ecbaac6230d7 100644 --- a/include/uapi/linux/net_tstamp.h +++ b/include/uapi/linux/net_tstamp.h @@ -167,6 +167,11 @@ enum txtime_flags { SOF_TXTIME_FLAGS_MASK = (SOF_TXTIME_FLAGS_LAST - 1) | SOF_TXTIME_FLAGS_LAST }; +/* + * Clock ID to use with POSIX clocks + * The ID must be u8 to fit in (struct sock)->sk_clockid + */ +#define SOF_TXTIME_POSIX_CLOCK_ID (0x77) struct sock_txtime { __kernel_clockid_t clockid;/* reference clockid */ diff --git a/net/sched/sch_etf.c b/net/sched/sch_etf.c index c0de4c6f9299..8e3e0a61fa58 100644 --- a/net/sched/sch_etf.c +++ b/net/sched/sch_etf.c @@ -15,6 +15,7 @@ #include #include #include +#include #include #include #include @@ -40,19 +41,40 @@ struct etf_sched_data { struct rb_root_cached head; struct qdisc_watchdog watchdog; ktime_t (*get_time)(void); +#ifdef CONFIG_POSIX_TIMERS + struct posix_clock *pclock; /* pointer to a posix clock */ +#endif /* CONFIG_POSIX_TIMERS */ }; static const struct nla_policy etf_policy[TCA_ETF_MAX + 1] = { [TCA_ETF_PARMS] = { .len = sizeof(struct tc_etf_qopt) }, }; +static inline ktime_t get_now(struct Qdisc *sch, struct etf_sched_data *q) +{ +#ifdef CONFIG_POSIX_TIMERS + if (IS_ERR_OR_NULL(q->get_time)) { + struct timespec64 ts; + int err = posix_clock_gettime(q->pclock, &ts); + + if (err) { + pr_warn("Clock is disabled (%d) for queue %d\n", + err, q->queue); + return 0; + } + return timespec64_to_ktime(ts); + } +#endif /* CONFIG_POSIX_TIMERS */ + return q->get_time(); +} + static inline int validate_input_params(struct tc_etf_qopt *qopt, struct netlink_ext_ack *extack) { /* Check if params comply to the following rules: * * Clockid and delta must be valid. * - * * Dynamic clockids are not supported. + * * Dynamic CPU clockids are not supported. * * * Delta must be a positive or zero integer. * @@ -60,11 +82,22 @@ static inline int validate_input_params(struct tc_etf_qopt *qopt, * expect that system clocks have been synchronized to PHC. */ if (qopt->clockid < 0) { +#ifdef CONFIG_POSIX_TIMERS + /** + * Use of PTP clock through a posix clock. + * The TC application must open the posix clock device file + * and use the dynamic clockid from the file description. + */ + if (!is_clockid_fd_clock(qopt->clockid)) { + NL_SET_ERR_MSG(extack, + "Dynamic CPU clockids are not supported"); + return -EOPNOTSUPP; + } +#else /* CONFIG_POSIX_TIMERS */ NL_SET_ERR_MSG(extack, "Dynamic clockids are not supported"); return -ENOTSUPP; - } - - if (qopt->clockid != CLOCK_TAI) { +#endif /* CONFIG_POSIX_TIMERS */ + } else if (qopt->clockid != CLOCK_TAI) { NL_SET_ERR_MSG(extack, "Invalid clockid. CLOCK_TAI must be used"); return -EINVAL; } @@ -103,7 +136,7 @@ static bool is_packet_valid(struct Qdisc *sch, struct etf_sched_data *q, return false; skip: - now = q->get_time(); + now = get_now(sch, q); if (ktime_before(txtime, now) || ktime_before(txtime, q->last)) return false; @@ -133,6 +166,27 @@ static void reset_watchdog(struct Qdisc *sch, struct etf_sched_data *q) } next = ktime_sub_ns(skb->tstamp, q->delta + NET_SCH_ETF_TIMER_RANGE); +#ifdef CONFIG_POSIX_TIMERS + if (!IS_ERR_OR_NULL(q->pclock)) { + s64 now; + struct timespec64 ts; + int err = posix_clock_gettime(q->pclock, &ts); + + if (err) { + pr_warn("Clock is disabled (%d) for queue %d\n", + err, q->queue); + return; + } + now = timespec64_to_ns(&ts); + if (now == 0) { + pr_warn("Clock is not running for queue %d\n", + q->queue); + return; + } + /* Convert PHC to CLOCK_TAI as that is the timer clock */ + next = ktime_add(next, ktime_sub_ns(ktime_get_clocktai(), now)); + } +#endif /* CONFIG_POSIX_TIMERS */ qdisc_watchdog_schedule_soon_ns(&q->watchdog, ktime_to_ns(next), NET_SCH_ETF_TIMER_RANGE); } @@ -263,7 +317,7 @@ static struct sk_buff *etf_dequeue_timesortedlist(struct Qdisc *sch) if (!skb) return NULL; - now = q->get_time(); + now = get_now(sch, q); /* Drop if packet has expired while in queue. */ if (ktime_before(skb->tstamp, now)) { @@ -354,6 +408,7 @@ static int etf_init(struct Qdisc *sch, struct nlattr *opt, struct nlattr *tb[TCA_ETF_MAX + 1]; struct tc_etf_qopt *qopt; int err; + clockid_t clockid; if (!opt) { NL_SET_ERR_MSG(extack, @@ -391,13 +446,17 @@ static int etf_init(struct Qdisc *sch, struct nlattr *opt, } /* Everything went OK, save the parameters used. */ + clockid = qopt->clockid; q->delta = qopt->delta; q->clockid = qopt->clockid; q->offload = OFFLOAD_IS_ON(qopt); q->deadline_mode = DEADLINE_MODE_IS_ON(qopt); q->skip_sock_check = SKIP_SOCK_CHECK_IS_SET(qopt); +#ifdef CONFIG_POSIX_TIMERS + q->pclock = NULL; +#endif /* CONFIG_POSIX_TIMERS */ - switch (q->clockid) { + switch (clockid) { case CLOCK_REALTIME: q->get_time = ktime_get_real; break; @@ -411,11 +470,31 @@ static int etf_init(struct Qdisc *sch, struct nlattr *opt, q->get_time = ktime_get_clocktai; break; default: +#ifdef CONFIG_POSIX_TIMERS + q->pclock = posix_clock_get_clock(clockid); + if (IS_ERR_OR_NULL(q->pclock)) { + NL_SET_ERR_MSG(extack, "Clockid does not exist"); + return PTR_ERR(q->pclock); + } + q->clockid = SOF_TXTIME_POSIX_CLOCK_ID; + /** + * Posix clocks do not support high-resolution timers + * Using the TAI clock is close enough (for relative sleeps) + */ + clockid = CLOCK_TAI; + /** + * Posix clock do not provide direct ktime function + * We need to call posix_clock_gettime() + */ + q->get_time = NULL; + break; +#else /* CONFIG_POSIX_TIMERS */ NL_SET_ERR_MSG(extack, "Clockid is not supported"); return -ENOTSUPP; +#endif /* CONFIG_POSIX_TIMERS */ } - qdisc_watchdog_init_clockid(&q->watchdog, sch, q->clockid); + qdisc_watchdog_init_clockid(&q->watchdog, sch, clockid); return 0; } @@ -463,6 +542,11 @@ static void etf_destroy(struct Qdisc *sch) qdisc_watchdog_cancel(&q->watchdog); etf_disable_offload(dev, q); +#ifdef CONFIG_POSIX_TIMERS + /* Release posix clock */ + if (!IS_ERR_OR_NULL(q->pclock)) + posix_clock_put_clock(q->pclock); +#endif /* CONFIG_POSIX_TIMERS */ } static int etf_dump(struct Qdisc *sch, struct sk_buff *skb)