linux-kernel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Christophe Leroy <christophe.leroy@c-s.fr>
To: Thomas Gleixner <tglx@linutronix.de>,
	LKML <linux-kernel@vger.kernel.org>
Cc: x86@kernel.org, John Stultz <john.stultz@linaro.org>,
	Vincenzo Frascino <vincenzo.frascino@arm.com>,
	Andy Lutomirski <luto@kernel.org>,
	Paolo Bonzini <pbonzini@redhat.com>,
	Boris Ostrovsky <boris.ostrovsky@oracle.com>,
	Juergen Gross <jgross@suse.com>,
	Haiyang Zhang <haiyangz@microsoft.com>,
	Sasha Levin <sashal@kernel.org>,
	Ralf Baechle <ralf@linux-mips.org>,
	Paul Burton <paulburton@kernel.org>,
	James Hogan <jhogan@kernel.org>,
	Russell King <linux@armlinux.org.uk>,
	Catalin Marinas <catalin.marinas@arm.com>,
	Will Deacon <will@kernel.org>,
	Mark Rutland <mark.rutland@arm.com>,
	Marc Zyngier <maz@kernel.org>
Subject: Re: [patch 15/15] lib/vdso: Move VCLOCK_TIMENS to vdso_clock_modes
Date: Wed, 15 Jan 2020 06:58:31 +0100	[thread overview]
Message-ID: <8673fa43-97f8-2ad2-d784-f22b54fd7a2e@c-s.fr> (raw)
In-Reply-To: <20200114185948.088821198@linutronix.de>



Le 14/01/2020 à 19:52, Thomas Gleixner a écrit :
> Move the time namespace indicator clock mode to the other ones for
> consistency sake.
> 
> Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
> ---
>   include/linux/clocksource.h |    3 +++
>   include/vdso/datapage.h     |    2 --
>   kernel/time/namespace.c     |    7 ++++---
>   lib/vdso/gettimeofday.c     |   18 ++++++++++--------
>   4 files changed, 17 insertions(+), 13 deletions(-)
> 
> --- a/include/linux/clocksource.h
> +++ b/include/linux/clocksource.h
> @@ -34,6 +34,9 @@ enum vdso_clock_mode {
>   	VDSO_ARCH_CLOCKMODES,
>   #endif
>   	VDSO_CLOCKMODE_MAX,
> +
> +	/* Indicator for time namespace VDSO */ > +	VDSO_CLOCKMODE_TIMENS = INT_MAX

Can we shorten the names a bit in order to avoid code line splits ? 
WOuldn't something like VDSO_CMODE_XXX be explicit enough ?

Christophe

>   };
>   
>   /**
> --- a/include/vdso/datapage.h
> +++ b/include/vdso/datapage.h
> @@ -21,8 +21,6 @@
>   #define CS_RAW		1
>   #define CS_BASES	(CS_RAW + 1)
>   
> -#define VCLOCK_TIMENS	UINT_MAX
> -
>   /**
>    * struct vdso_timestamp - basetime per clock_id
>    * @sec:	seconds
> --- a/kernel/time/namespace.c
> +++ b/kernel/time/namespace.c
> @@ -8,6 +8,7 @@
>   #include <linux/user_namespace.h>
>   #include <linux/sched/signal.h>
>   #include <linux/sched/task.h>
> +#include <linux/clocksource.h>
>   #include <linux/seq_file.h>
>   #include <linux/proc_ns.h>
>   #include <linux/export.h>
> @@ -172,8 +173,8 @@ static struct timens_offset offset_from_
>    * for vdso_data->clock_mode is a non-issue. The task is spin waiting for the
>    * update to finish and for 'seq' to become even anyway.
>    *
> - * Timens page has vdso_data->clock_mode set to VCLOCK_TIMENS which enforces
> - * the time namespace handling path.
> + * Timens page has vdso_data->clock_mode set to VDSO_CLOCKMODE_TIMENS which
> + * enforces the time namespace handling path.
>    */
>   static void timens_setup_vdso_data(struct vdso_data *vdata,
>   				   struct time_namespace *ns)
> @@ -183,7 +184,7 @@ static void timens_setup_vdso_data(struc
>   	struct timens_offset boottime = offset_from_ts(ns->offsets.boottime);
>   
>   	vdata->seq			= 1;
> -	vdata->clock_mode		= VCLOCK_TIMENS;
> +	vdata->clock_mode		= VDSO_CLOCKMODE_TIMENS;
>   	offset[CLOCK_MONOTONIC]		= monotonic;
>   	offset[CLOCK_MONOTONIC_RAW]	= monotonic;
>   	offset[CLOCK_MONOTONIC_COARSE]	= monotonic;
> --- a/lib/vdso/gettimeofday.c
> +++ b/lib/vdso/gettimeofday.c
> @@ -116,10 +116,10 @@ static __always_inline int do_hres(const
>   
>   	do {
>   		/*
> -		 * Open coded to handle VCLOCK_TIMENS. Time namespace
> +		 * Open coded to handle VDSO_CLOCKMODE_TIMENS. Time namespace
>   		 * enabled tasks have a special VVAR page installed which
>   		 * has vd->seq set to 1 and vd->clock_mode set to
> -		 * VCLOCK_TIMENS. For non time namespace affected tasks
> +		 * VDSO_CLOCKMODE_TIMENS. For non time namespace affected tasks
>   		 * this does not affect performance because if vd->seq is
>   		 * odd, i.e. a concurrent update is in progress the extra
>   		 * check for vd->clock_mode is just a few extra
> @@ -128,7 +128,7 @@ static __always_inline int do_hres(const
>   		 */
>   		while (unlikely((seq = READ_ONCE(vd->seq)) & 1)) {
>   			if (IS_ENABLED(CONFIG_TIME_NS) &&
> -			    vd->clock_mode == VCLOCK_TIMENS)
> +			    vd->clock_mode == VDSO_CLOCKMODE_TIMENS)
>   				return do_hres_timens(vd, clk, ts);
>   			cpu_relax();
>   		}
> @@ -200,12 +200,12 @@ static __always_inline int do_coarse(con
>   
>   	do {
>   		/*
> -		 * Open coded to handle VCLOCK_TIMENS. See comment in
> +		 * Open coded to handle VDSO_CLOCK_TIMENS. See comment in
>   		 * do_hres().
>   		 */
>   		while ((seq = READ_ONCE(vd->seq)) & 1) {
>   			if (IS_ENABLED(CONFIG_TIME_NS) &&
> -			    vd->clock_mode == VCLOCK_TIMENS)
> +			    vd->clock_mode == VDSO_CLOCKMODE_TIMENS)
>   				return do_coarse_timens(vd, clk, ts);
>   			cpu_relax();
>   		}
> @@ -292,7 +292,7 @@ static __maybe_unused int
>   
>   	if (unlikely(tz != NULL)) {
>   		if (IS_ENABLED(CONFIG_TIME_NS) &&
> -		    vd->clock_mode == VCLOCK_TIMENS)
> +		    vd->clock_mode == VDSO_CLOCKMODE_TIMENS)
>   			vd = __arch_get_timens_vdso_data();
>   
>   		tz->tz_minuteswest = vd[CS_HRES_COARSE].tz_minuteswest;
> @@ -308,7 +308,8 @@ static __maybe_unused __kernel_old_time_
>   	const struct vdso_data *vd = __arch_get_vdso_data();
>   	__kernel_old_time_t t;
>   
> -	if (IS_ENABLED(CONFIG_TIME_NS) && vd->clock_mode == VCLOCK_TIMENS)
> +	if (IS_ENABLED(CONFIG_TIME_NS) &&
> +	    vd->clock_mode == VDSO_CLOCKMODE_TIMENS)
>   		vd = __arch_get_timens_vdso_data();
>   
>   	t = READ_ONCE(vd[CS_HRES_COARSE].basetime[CLOCK_REALTIME].sec);
> @@ -333,7 +334,8 @@ int __cvdso_clock_getres_common(clockid_
>   	if (unlikely((u32) clock >= MAX_CLOCKS))
>   		return -1;
>   
> -	if (IS_ENABLED(CONFIG_TIME_NS) && vd->clock_mode == VCLOCK_TIMENS)
> +	if (IS_ENABLED(CONFIG_TIME_NS) &&
> +	    vd->clock_mode == VDSO_CLOCKMODE_TIMENS)
>   		vd = __arch_get_timens_vdso_data();
>   
>   	hrtimer_res = READ_ONCE(vd[CS_HRES_COARSE].hrtimer_res);
> 

      reply	other threads:[~2020-01-15  5:58 UTC|newest]

Thread overview: 25+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2020-01-14 18:52 [patch 00/15] lib/vdso: Bugfix and consolidation Thomas Gleixner
2020-01-14 18:52 ` [patch 01/15] lib/vdso: Make __arch_update_vdso_data() logic understandable Thomas Gleixner
2020-01-17 15:07   ` [tip: timers/urgent] " tip-bot2 for Thomas Gleixner
2020-01-14 18:52 ` [patch 02/15] lib/vdso: Update coarse timekeeper unconditionally Thomas Gleixner
2020-01-17 15:07   ` [tip: timers/urgent] " tip-bot2 for Thomas Gleixner
2020-01-14 18:52 ` [patch 03/15] ARM: vdso: Remove unused function Thomas Gleixner
2020-01-14 18:52 ` [patch 04/15] lib/vdso: Allow the high resolution parts to be compiled out Thomas Gleixner
2020-01-14 18:52 ` [patch 05/15] ARM: vdso: Compile high resolution parts conditionally Thomas Gleixner
2020-01-14 18:52 ` [patch 06/15] MIPS: " Thomas Gleixner
2020-01-14 18:52 ` [patch 07/15] clocksource: Cleanup struct clocksource and documentation Thomas Gleixner
2020-01-14 18:52 ` [patch 08/15] x86/vdso: Move VDSO clocksource state tracking to callback Thomas Gleixner
2020-01-15  5:56   ` Jürgen Groß
2020-01-20  1:42   ` Michael Kelley
2020-01-14 18:52 ` [patch 09/15] clocksource: Add common vdso clock mode storage Thomas Gleixner
2020-01-15  5:50   ` Christophe Leroy
2020-01-15  7:59     ` Thomas Gleixner
2020-01-14 18:52 ` [patch 10/15] x86/vdso: Use generic VDSO " Thomas Gleixner
2020-01-15  5:57   ` Jürgen Groß
2020-01-14 18:52 ` [patch 11/15] mips: vdso: " Thomas Gleixner
2020-01-14 18:52 ` [patch 12/15] ARM/arm64: vdso: Use common vdso " Thomas Gleixner
2020-01-14 18:52 ` [patch 13/15] lib/vdso: Cleanup clock mode storage leftovers Thomas Gleixner
2020-01-14 18:52 ` [patch 14/15] lib/vdso: Avoid highres update if clocksource is not VDSO capable Thomas Gleixner
2020-01-15  5:54   ` Christophe Leroy
2020-01-14 18:52 ` [patch 15/15] lib/vdso: Move VCLOCK_TIMENS to vdso_clock_modes Thomas Gleixner
2020-01-15  5:58   ` Christophe Leroy [this message]

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=8673fa43-97f8-2ad2-d784-f22b54fd7a2e@c-s.fr \
    --to=christophe.leroy@c-s.fr \
    --cc=boris.ostrovsky@oracle.com \
    --cc=catalin.marinas@arm.com \
    --cc=haiyangz@microsoft.com \
    --cc=jgross@suse.com \
    --cc=jhogan@kernel.org \
    --cc=john.stultz@linaro.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux@armlinux.org.uk \
    --cc=luto@kernel.org \
    --cc=mark.rutland@arm.com \
    --cc=maz@kernel.org \
    --cc=paulburton@kernel.org \
    --cc=pbonzini@redhat.com \
    --cc=ralf@linux-mips.org \
    --cc=sashal@kernel.org \
    --cc=tglx@linutronix.de \
    --cc=vincenzo.frascino@arm.com \
    --cc=will@kernel.org \
    --cc=x86@kernel.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).