linux-kernel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Peter Zijlstra <peterz@infradead.org>
To: Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
Cc: Andrew Morton <akpm@linux-foundation.org>,
	Russell King <linux@arm.linux.org.uk>,
	Thomas Gleixner <tglx@linutronix.de>,
	Ingo Molnar <mingo@redhat.com>, "H. Peter Anvin" <hpa@zytor.com>,
	linux-kernel@vger.kernel.org,
	linux-api <linux-api@vger.kernel.org>,
	Paul Turner <pjt@google.com>, Andrew Hunter <ahh@google.com>,
	Andy Lutomirski <luto@amacapital.net>,
	Andi Kleen <andi@firstfloor.org>,
	Dave Watson <davejwatson@fb.com>, Chris Lameter <cl@linux.com>,
	Ben Maurer <bmaurer@fb.com>, rostedt <rostedt@goodmis.org>,
	"Paul E. McKenney" <paulmck@linux.vnet.ibm.com>,
	Josh Triplett <josh@joshtriplett.org>,
	Linus Torvalds <torvalds@linux-foundation.org>,
	Catalin Marinas <catalin.marinas@arm.com>,
	Will Deacon <will.deacon@arm.com>,
	Michael Kerrisk <mtk.manpages@gmail.com>
Subject: Re: [PATCH v4 1/5] getcpu_cache system call: cache CPU number of running thread
Date: Fri, 26 Feb 2016 12:33:04 +0100	[thread overview]
Message-ID: <20160226113304.GA6356@twins.programming.kicks-ass.net> (raw)
In-Reply-To: <2135602720.7810.1456420671941.JavaMail.zimbra@efficios.com>

On Thu, Feb 25, 2016 at 05:17:51PM +0000, Mathieu Desnoyers wrote:
> ----- On Feb 25, 2016, at 12:04 PM, Peter Zijlstra peterz@infradead.org wrote:
> 
> > On Thu, Feb 25, 2016 at 04:55:26PM +0000, Mathieu Desnoyers wrote:
> >> ----- On Feb 25, 2016, at 4:56 AM, Peter Zijlstra peterz@infradead.org wrote:
> >> The restartable sequences are intrinsically designed to work
> >> on per-cpu data, so they need to fetch the current CPU number
> >> within the rseq critical section. This is where the getcpu_cache
> >> system call becomes very useful when combined with rseq:
> >> getcpu_cache allows reading the current CPU number in a
> >> fraction of cycle.
> > 
> > Yes yes, I know how restartable sequences work.
> > 
> > But what I worry about is that they want a cpu number and a sequence
> > number, and for performance it would be very good if those live in the
> > same cacheline.
> > 
> > That means either getcpu needs to grow a seq number, or restartable
> > sequences need to _also_ provide the cpu number.
> 
> If we plan things well, we could have both the cpu number and the
> seqnum in the same cache line, registered by two different system
> calls. It's up to user-space to organize those two variables
> to fit within the same cache-line.

I feel this is more fragile than needed. Why not do a single systemcall
that does both?

> getcpu_cache GETCPU_CACHE_SET operation takes the address where
> the CPU number should live as input.
> 
> rseq system call could do the same for the seqnum address.

So I really don't like that, that means we have to track more kernel
state -- we have to carry two pointers instead of one, we have to have
more update functions etc..

That just increases the total overhead of all of this.

> The question becomes: how do we introduce this to user-space,
> considering that only a single address per thread is allowed
> for each of getcpu_cache and rseq ?
> 
> If both CPU number and seqnum are centralized in a TLS within
> e.g. glibc, that would be OK, but if we intend to allow libraries
> or applications to directly register their own getcpu_cache
> address and/or rseq, we may end up in situations where we have
> to fallback on using two different cache-lines. But how much
> should we care about performance in cases where non-generic
> libraries directly use those system calls ?
> 
> Thoughts ?

Yeah, not sure, but that is a separate problem. Both your proposed code
and the rseq code have this. Having them separate system calls just
increases the amount of ways you can do it wrong.

  reply	other threads:[~2016-02-26 11:33 UTC|newest]

Thread overview: 55+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2016-02-23 23:28 [PATCH v4 0/5] getcpu_cache system call for 4.6 Mathieu Desnoyers
2016-02-23 23:28 ` [PATCH v4 1/5] getcpu_cache system call: cache CPU number of running thread Mathieu Desnoyers
2016-02-24 11:11   ` Thomas Gleixner
2016-02-24 17:17     ` Mathieu Desnoyers
2016-02-25 23:32     ` Rasmus Villemoes
2016-02-26 17:47       ` Mathieu Desnoyers
2016-02-25  9:56   ` Peter Zijlstra
2016-02-25 16:55     ` Mathieu Desnoyers
2016-02-25 17:04       ` Peter Zijlstra
2016-02-25 17:17         ` Mathieu Desnoyers
2016-02-26 11:33           ` Peter Zijlstra [this message]
2016-02-26 16:29             ` Thomas Gleixner
2016-02-26 17:20               ` Mathieu Desnoyers
2016-02-26 18:01                 ` Thomas Gleixner
2016-02-26 20:24                   ` Mathieu Desnoyers
2016-02-26 23:04                     ` H. Peter Anvin
2016-02-27  0:40                       ` Mathieu Desnoyers
2016-02-27  6:24                         ` H. Peter Anvin
2016-02-27 14:15                           ` Mathieu Desnoyers
2016-02-27 14:58                             ` Peter Zijlstra
2016-02-27 18:35                               ` Linus Torvalds
2016-02-27 19:01                                 ` H. Peter Anvin
2016-02-27 23:53                                 ` Mathieu Desnoyers
     [not found]                                   ` <CA+55aFwcgwRxvVBz5kk_3O8dESXAGJ4KHBkf=pSXjiS7Xh4NwA@mail.gmail.com>
     [not found]                                     ` <1082926946.10326.1456619994590.JavaMail.zimbra@efficios.com>
2016-02-28  0:57                                       ` Linus Torvalds
2016-02-28 14:32                                         ` Mathieu Desnoyers
2016-02-29 10:35                                           ` Peter Zijlstra
2016-03-01 20:23                                             ` Mathieu Desnoyers
2016-03-01 21:32                                               ` Peter Zijlstra
2016-03-01 21:36                                                 ` Peter Zijlstra
2016-03-01 21:47                                                 ` H. Peter Anvin
2016-03-02 10:34                                                   ` Peter Zijlstra
2016-02-29 10:32                                       ` Peter Zijlstra
2016-02-29 10:39                                         ` Arnd Bergmann
2016-02-29 12:41                                           ` Mathieu Desnoyers
2016-02-29 13:08                                             ` Arnd Bergmann
2016-02-29 18:19                                             ` H. Peter Anvin
2016-03-02 10:44                                             ` Geert Uytterhoeven
2016-03-01 18:25                                       ` H. Peter Anvin
2016-03-01 18:40                                         ` Mathieu Desnoyers
2016-02-28 13:07                                 ` Geert Uytterhoeven
2016-02-28 16:21                                   ` Linus Torvalds
2016-02-29 10:01                                 ` Peter Zijlstra
2016-02-27 15:04                             ` H. Peter Anvin
2016-02-23 23:28 ` [PATCH v4 2/5] getcpu_cache: ARM resume notifier Mathieu Desnoyers
2016-02-23 23:28 ` [PATCH v4 3/5] getcpu_cache: wire up ARM system call Mathieu Desnoyers
2016-02-24  0:54   ` kbuild test robot
2016-02-24  1:05   ` [PATCH v4 (updated)] " Mathieu Desnoyers
2016-02-24  5:28     ` kbuild test robot
2016-02-24  6:54     ` kbuild test robot
2016-02-23 23:28 ` [PATCH v4 4/5] getcpu_cache: x86 32/64 resume notifier Mathieu Desnoyers
2016-02-23 23:28 ` [PATCH v4 5/5] getcpu_cache: wire up x86 32/64 system call Mathieu Desnoyers
2016-02-24  1:36 ` [PATCH v4 0/5] getcpu_cache system call for 4.6 H. Peter Anvin
2016-02-24  4:09   ` Mathieu Desnoyers
2016-02-24 20:07     ` H. Peter Anvin
2016-02-24 22:38       ` Mathieu Desnoyers

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=20160226113304.GA6356@twins.programming.kicks-ass.net \
    --to=peterz@infradead.org \
    --cc=ahh@google.com \
    --cc=akpm@linux-foundation.org \
    --cc=andi@firstfloor.org \
    --cc=bmaurer@fb.com \
    --cc=catalin.marinas@arm.com \
    --cc=cl@linux.com \
    --cc=davejwatson@fb.com \
    --cc=hpa@zytor.com \
    --cc=josh@joshtriplett.org \
    --cc=linux-api@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux@arm.linux.org.uk \
    --cc=luto@amacapital.net \
    --cc=mathieu.desnoyers@efficios.com \
    --cc=mingo@redhat.com \
    --cc=mtk.manpages@gmail.com \
    --cc=paulmck@linux.vnet.ibm.com \
    --cc=pjt@google.com \
    --cc=rostedt@goodmis.org \
    --cc=tglx@linutronix.de \
    --cc=torvalds@linux-foundation.org \
    --cc=will.deacon@arm.com \
    /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).