From: Peter Zijlstra <peterz@infradead.org>
To: Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
Cc: Linus Torvalds <torvalds@linux-foundation.org>,
Ben Maurer <bmaurer@fb.com>, Thomas Gleixner <tglx@linutronix.de>,
Ingo Molnar <mingo@redhat.com>,
Russell King <linux@arm.linux.org.uk>,
linux-api <linux-api@vger.kernel.org>,
Andrew Morton <akpm@linux-foundation.org>,
Michael Kerrisk <mtk.manpages@gmail.com>,
Dave Watson <davejwatson@fb.com>, rostedt <rostedt@goodmis.org>,
Andy Lutomirski <luto@amacapital.net>,
Will Deacon <will.deacon@arm.com>,
"Paul E. McKenney" <paulmck@linux.vnet.ibm.com>,
Chris Lameter <cl@linux.com>, Andi Kleen <andi@firstfloor.org>,
Josh Triplett <josh@joshtriplett.org>,
Paul Turner <pjt@google.com>,
Linux Kernel Mailing List <linux-kernel@vger.kernel.org>,
Catalin Marinas <catalin.marinas@arm.com>,
Andrew Hunter <ahh@google.com>, "H. Peter Anvin" <hpa@zytor.com>
Subject: Re: [PATCH v4 1/5] getcpu_cache system call: cache CPU number of running thread
Date: Mon, 29 Feb 2016 11:32:21 +0100 [thread overview]
Message-ID: <20160229103221.GI6356@twins.programming.kicks-ass.net> (raw)
In-Reply-To: <1082926946.10326.1456619994590.JavaMail.zimbra@efficios.com>
On Sun, Feb 28, 2016 at 12:39:54AM +0000, Mathieu Desnoyers wrote:
> /* This structure needs to be aligned cache line size. */
> struct thread_local_abi {
> int32_t cpu_id;
> uint32_t rseq_seqnum;
> uint64_t rseq_post_commit_ip;
> /* Add new fields at the end. */
> } __attribute__((packed));
I would really not use packed; that can lead to horrible layout.
Suppose someone would add:
uint32_t foo;
uint64_t bar;
With packed, you get an unaligned uint64_t in there, which is horrible.
Without packed, you get a hole, which you can later fill.
> /* Thread local ABI system calls. */
>
> int thread_local_abi_len(size_t *features_mask_len, size_t *tlabi_len);
See below; maybe we can fudge the register call to return the size when
called 'right', maybe that'll end up too ugly, dunno. But I don't think
we need the feature mask bits.
Maybe: TLA_FLAG_GETSIZE ?
> int thread_local_abi_features(uint8_t *mask);
Not sure you need this; see below. Either you know about a
TLA_ENABLE_feat flag and you can attempt enabling it (failing if the
kernel doesn't support it), or you don't, in which case you won't
attempt use.
> int thread_local_abi_register(struct thread_local_abi *tlabi);
This has the problem that the moment you register for this, we must have
all features enabled. And esp. the rseq stuff has non-trivial overhead.
I would much rather have something where we only enable the features
actually used by the program at hand.
Also, every syscall should have a flags argument, so maybe we can do
something like:
#define TLA_ENABLE_CPU 0x01
#define TLA_ENABLE_RSEQ 0x03 /* RSEQ must imply CPU */
int thread_local_abi_register(struct tla *tla, unsigned int enable, unsigned int flags);
Where (g)libc would unconditionally set up the structure with
.enabled=0, .flags=0, and anybody actually wanting to make use of the
thing do:
thread_local_abi_register(NULL, TLA_ENABLE_CPU, 0);
Obviously calling register with !NULL address twice will error (you
already registered), calling with NULL before !NULL will also error.
And if you really worry about running out of feature bits, we could of
course pass it in a mask, but I'm not sure I can see 30 other features
we would want to cram into this (yes, yes, famous last words etc.. 640kb
anyone?).
next prev parent reply other threads:[~2016-02-29 10:32 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
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 [this message]
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=20160229103221.GI6356@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).