From: Mathieu Desnoyers <mathieu.desnoyers-vg+e7yoeK/dWk0Htik3J/w@public.gmane.org>
To: Peter Zijlstra <peterz-wEGCiKHe2LqWVfeAwA7xHQ@public.gmane.org>,
"H. Peter Anvin" <hpa-YMNOUZJC4hwAvxtiuMwx3w@public.gmane.org>
Cc: Linus Torvalds
<torvalds-de/tnXTf+JLsfHDXvbKv3WD2FQJk+8+b@public.gmane.org>,
Ben Maurer <bmaurer-b10kYP2dOMg@public.gmane.org>,
Thomas Gleixner <tglx-hfZtesqFncYOwBW4kG4KsQ@public.gmane.org>,
Ingo Molnar <mingo-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>,
Russell King <linux-lFZ/pmaqli7XmaaqVzeoHQ@public.gmane.org>,
linux-api <linux-api-u79uwXL29TY76Z2rM5mHXA@public.gmane.org>,
Andrew Morton
<akpm-de/tnXTf+JLsfHDXvbKv3WD2FQJk+8+b@public.gmane.org>,
Michael Kerrisk
<mtk.manpages-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>,
Dave Watson <davejwatson-b10kYP2dOMg@public.gmane.org>,
rostedt <rostedt-nx8X9YLhiw1AfugRpC6u6w@public.gmane.org>,
Andy Lutomirski <luto-kltTT9wpgjJwATOyAt5JVQ@public.gmane.org>,
Will Deacon <will.deacon-5wv7dgnIgG8@public.gmane.org>,
"Paul E. McKenney"
<paulmck-23VcF4HTsmIX0ybBhKVfKdBPR1lH4CV8@public.gmane.org>,
Chris Lameter <cl-vYTEC60ixJUAvxtiuMwx3w@public.gmane.org>,
Andi Kleen <andi-Vw/NltI1exuRpAAqCnN02g@public.gmane.org>,
Josh Triplett <josh-iaAMLnmF4UmaiuxdJuQwMA@public.gmane.org>,
Paul Turner <pjt-hpIqsD4AKlfQT0dZR+AlfA@public.gmane.org>,
Linux Kernel Mailing List
<linux-kernel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org>,
Catalin Marinas <catalin.marinas-5wv7dgnIgG8@public.gmane.org>,
Andrew Hunter <ahh-hpIqsD4AKlfQT0dZR+AlfA@public.gmane.org>
Subject: Re: [PATCH v4 1/5] getcpu_cache system call: cache CPU number of running thread
Date: Tue, 1 Mar 2016 20:23:12 +0000 (UTC) [thread overview]
Message-ID: <676569856.13488.1456863792603.JavaMail.zimbra@efficios.com> (raw)
In-Reply-To: <20160229103506.GJ6356-ndre7Fmf5hadTX5a5knrm8zTDFooKrT+cvkQGrU6aU0@public.gmane.org>
----- On Feb 29, 2016, at 5:35 AM, Peter Zijlstra peterz-wEGCiKHe2LqWVfeAwA7xHQ@public.gmane.org wrote:
> On Sun, Feb 28, 2016 at 02:32:28PM +0000, Mathieu Desnoyers wrote:
>> The part of ABI I'm trying to express here is for discoverability
>> of available features by user-space. For instance, a kernel
>> could be configured with "CONFIG_RSEQ=n", and userspace should
>> not rely on the rseq fields of the thread-local ABI in that case.
>
> Per the just proposed interface; discoverability would end with:
>
> thread_local_abi_register(NULL, TLA_ENABLE_RSEQ, 0);
>
> failing. This would indicate your kernel does not support (or your glibc
> failed to register, depending on error code I suppose).
>
> Then your program can either fall back to full atomics or just bail.
I think it's important that user-space fast-paths can quickly
detect whether the feature is enabled without having to rely on
always reading a separate cache-line. I've put together an ABI
proposal that take into account the feedback received so far.
The main trick here is to use "-1" value in cpu_id and rseq_seqnum
to mean "the feature is inactive" so user-space can call the system
call to register the feature, and the value "-2" can be set by the
kernel when it knows the feature is not available. It does mean
that seqnum would wrap from MAX_INT to 0 in the kernel, skipping
negative values.
Please let me know if I missed anything.
#ifdef __LP64__
# define TLABI_FIELD_u32_u64(field) uint64_t field
#elif __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__
# define TLABI_FIELD_u32_u64(field) uint32_t field, _padding ## field
#else
# define TLABI_FIELD_u32_u64(field) uint32_t _padding ## field, field
#endif
/*
* The thread-local ABI structure needs to be aligned at least on 32
* bytes multiples.
*/
#define TLABI_ALIGNMENT 32
struct thread_local_abi {
/*
* Thread-local ABI cpu_id field.
* Updated by the kernel, and read by user-space with
* single-copy atomicity semantics. Aligned on 32-bit.
* Values:
* >= 0: CPU number of running thread.
* -1 (initial value): means the cpu_id feature is inactive.
* -2: cpu_id feature is not available.
*/
int32_t cpu_id;
/*
* Thread-local ABI rseq_seqnum field.
* Updated by the kernel, and read by user-space with
* single-copy atomicity semantics. Aligned on 32-bit.
* Values:
* >= 0: current seqnum for this thread (feature is active).
* -1 (initial value): means the rseq feature is inactive.
* -2: rseq feature is not available.
*/
int32_t rseq_seqnum;
/*
* Thread-local ABI rseq_post_commit_ip field.
* Updated by user-space, and read by the kernel with
* single-copy atomicity semantics.
* Aligned on 64-bit.
*/
TLABI_FIELD_u32_u64(rseq_post_commit_ip);
/* Add new fields at the end. */
} __attribute__ ((aligned(TLABI_ALIGNMENT)));
enum thread_local_abi_feature {
TLA_FEATURE_NONE = 0,
TLA_FEATURE_CPU_ID = (1 << 0),
TLA_FEATURE_RSEQ = (1 << 1),
};
/*
* Thread local ABI system call.
*
* First call with (NULL, 0, 0), returns the size of the struct
* thread_local_abi expected by the kernel, or -1 on error.
*
* Second, allocate a memory area to hold the struct thread_local_abi,
* and call with (ptr, 0, 0). Returns 0 on success, or -1 on error.
*
* Third, enable specific features by passing a mask, e.g. call with
* (NULL, TLA_FEATURE_CPU_ID | TLA_FEATURE_RSEQ, 0).
* Returns 0 on success, -1 on error.
*
* Then the fields associated with the enabled features are managed by
* the kernel.
*/
ssize_t thread_local_abi(struct thread_local_abi *tlabi,
uint64_t feature_mask, int flags);
Thanks for your feedback!
Mathieu
--
Mathieu Desnoyers
EfficiOS Inc.
http://www.efficios.com
WARNING: multiple messages have this Message-ID (diff)
From: Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
To: Peter Zijlstra <peterz@infradead.org>, "H. Peter Anvin" <hpa@zytor.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>
Subject: Re: [PATCH v4 1/5] getcpu_cache system call: cache CPU number of running thread
Date: Tue, 1 Mar 2016 20:23:12 +0000 (UTC) [thread overview]
Message-ID: <676569856.13488.1456863792603.JavaMail.zimbra@efficios.com> (raw)
In-Reply-To: <20160229103506.GJ6356@twins.programming.kicks-ass.net>
----- On Feb 29, 2016, at 5:35 AM, Peter Zijlstra peterz@infradead.org wrote:
> On Sun, Feb 28, 2016 at 02:32:28PM +0000, Mathieu Desnoyers wrote:
>> The part of ABI I'm trying to express here is for discoverability
>> of available features by user-space. For instance, a kernel
>> could be configured with "CONFIG_RSEQ=n", and userspace should
>> not rely on the rseq fields of the thread-local ABI in that case.
>
> Per the just proposed interface; discoverability would end with:
>
> thread_local_abi_register(NULL, TLA_ENABLE_RSEQ, 0);
>
> failing. This would indicate your kernel does not support (or your glibc
> failed to register, depending on error code I suppose).
>
> Then your program can either fall back to full atomics or just bail.
I think it's important that user-space fast-paths can quickly
detect whether the feature is enabled without having to rely on
always reading a separate cache-line. I've put together an ABI
proposal that take into account the feedback received so far.
The main trick here is to use "-1" value in cpu_id and rseq_seqnum
to mean "the feature is inactive" so user-space can call the system
call to register the feature, and the value "-2" can be set by the
kernel when it knows the feature is not available. It does mean
that seqnum would wrap from MAX_INT to 0 in the kernel, skipping
negative values.
Please let me know if I missed anything.
#ifdef __LP64__
# define TLABI_FIELD_u32_u64(field) uint64_t field
#elif __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__
# define TLABI_FIELD_u32_u64(field) uint32_t field, _padding ## field
#else
# define TLABI_FIELD_u32_u64(field) uint32_t _padding ## field, field
#endif
/*
* The thread-local ABI structure needs to be aligned at least on 32
* bytes multiples.
*/
#define TLABI_ALIGNMENT 32
struct thread_local_abi {
/*
* Thread-local ABI cpu_id field.
* Updated by the kernel, and read by user-space with
* single-copy atomicity semantics. Aligned on 32-bit.
* Values:
* >= 0: CPU number of running thread.
* -1 (initial value): means the cpu_id feature is inactive.
* -2: cpu_id feature is not available.
*/
int32_t cpu_id;
/*
* Thread-local ABI rseq_seqnum field.
* Updated by the kernel, and read by user-space with
* single-copy atomicity semantics. Aligned on 32-bit.
* Values:
* >= 0: current seqnum for this thread (feature is active).
* -1 (initial value): means the rseq feature is inactive.
* -2: rseq feature is not available.
*/
int32_t rseq_seqnum;
/*
* Thread-local ABI rseq_post_commit_ip field.
* Updated by user-space, and read by the kernel with
* single-copy atomicity semantics.
* Aligned on 64-bit.
*/
TLABI_FIELD_u32_u64(rseq_post_commit_ip);
/* Add new fields at the end. */
} __attribute__ ((aligned(TLABI_ALIGNMENT)));
enum thread_local_abi_feature {
TLA_FEATURE_NONE = 0,
TLA_FEATURE_CPU_ID = (1 << 0),
TLA_FEATURE_RSEQ = (1 << 1),
};
/*
* Thread local ABI system call.
*
* First call with (NULL, 0, 0), returns the size of the struct
* thread_local_abi expected by the kernel, or -1 on error.
*
* Second, allocate a memory area to hold the struct thread_local_abi,
* and call with (ptr, 0, 0). Returns 0 on success, or -1 on error.
*
* Third, enable specific features by passing a mask, e.g. call with
* (NULL, TLA_FEATURE_CPU_ID | TLA_FEATURE_RSEQ, 0).
* Returns 0 on success, -1 on error.
*
* Then the fields associated with the enabled features are managed by
* the kernel.
*/
ssize_t thread_local_abi(struct thread_local_abi *tlabi,
uint64_t feature_mask, int flags);
Thanks for your feedback!
Mathieu
--
Mathieu Desnoyers
EfficiOS Inc.
http://www.efficios.com
next prev parent reply other threads:[~2016-03-01 20:23 UTC|newest]
Thread overview: 96+ 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 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
[not found] ` <1456270120-7560-4-git-send-email-mathieu.desnoyers-vg+e7yoeK/dWk0Htik3J/w@public.gmane.org>
2016-02-24 0:54 ` kbuild test robot
2016-02-24 0:54 ` kbuild test robot
2016-02-24 1:05 ` [PATCH v4 (updated)] " Mathieu Desnoyers
2016-02-24 1:05 ` Mathieu Desnoyers
[not found] ` <1456275925-12071-1-git-send-email-mathieu.desnoyers-vg+e7yoeK/dWk0Htik3J/w@public.gmane.org>
2016-02-24 5:28 ` kbuild test robot
2016-02-24 5:28 ` kbuild test robot
2016-02-24 6:54 ` 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
[not found] ` <1456270120-7560-1-git-send-email-mathieu.desnoyers-vg+e7yoeK/dWk0Htik3J/w@public.gmane.org>
2016-02-23 23:28 ` [PATCH v4 1/5] getcpu_cache system call: cache CPU number of running thread Mathieu Desnoyers
2016-02-23 23:28 ` 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-25 23:32 ` Rasmus Villemoes
2016-02-26 17:47 ` Mathieu Desnoyers
[not found] ` <1456270120-7560-2-git-send-email-mathieu.desnoyers-vg+e7yoeK/dWk0Htik3J/w@public.gmane.org>
2016-02-25 9:56 ` Peter Zijlstra
2016-02-25 9:56 ` Peter Zijlstra
[not found] ` <20160225095635.GO6356-ndre7Fmf5hadTX5a5knrm8zTDFooKrT+cvkQGrU6aU0@public.gmane.org>
2016-02-25 16:55 ` Mathieu Desnoyers
2016-02-25 16:55 ` Mathieu Desnoyers
[not found] ` <390571988.7745.1456419326288.JavaMail.zimbra-vg+e7yoeK/dWk0Htik3J/w@public.gmane.org>
2016-02-25 17:04 ` Peter Zijlstra
2016-02-25 17:04 ` Peter Zijlstra
[not found] ` <20160225170416.GV6356-ndre7Fmf5hadTX5a5knrm8zTDFooKrT+cvkQGrU6aU0@public.gmane.org>
2016-02-25 17:17 ` Mathieu Desnoyers
2016-02-25 17:17 ` Mathieu Desnoyers
[not found] ` <2135602720.7810.1456420671941.JavaMail.zimbra-vg+e7yoeK/dWk0Htik3J/w@public.gmane.org>
2016-02-26 11:33 ` Peter Zijlstra
2016-02-26 11:33 ` Peter Zijlstra
[not found] ` <20160226113304.GA6356-ndre7Fmf5hadTX5a5knrm8zTDFooKrT+cvkQGrU6aU0@public.gmane.org>
2016-02-26 16:29 ` Thomas Gleixner
2016-02-26 16:29 ` Thomas Gleixner
2016-02-26 17:20 ` Mathieu Desnoyers
[not found] ` <967083634.8940.1456507201156.JavaMail.zimbra-vg+e7yoeK/dWk0Htik3J/w@public.gmane.org>
2016-02-26 18:01 ` Thomas Gleixner
2016-02-26 18:01 ` Thomas Gleixner
2016-02-26 20:24 ` Mathieu Desnoyers
2016-02-26 20:24 ` Mathieu Desnoyers
2016-02-26 23:04 ` H. Peter Anvin
[not found] ` <7096DA23-3908-40DC-A46B-C4CF2252CEE8-YMNOUZJC4hwAvxtiuMwx3w@public.gmane.org>
2016-02-27 0:40 ` Mathieu Desnoyers
2016-02-27 0:40 ` Mathieu Desnoyers
[not found] ` <1150363257.9781.1456533630895.JavaMail.zimbra-vg+e7yoeK/dWk0Htik3J/w@public.gmane.org>
2016-02-27 6:24 ` H. Peter Anvin
2016-02-27 6:24 ` H. Peter Anvin
[not found] ` <56D14132.5050100-YMNOUZJC4hwAvxtiuMwx3w@public.gmane.org>
2016-02-27 14:15 ` Mathieu Desnoyers
2016-02-27 14:15 ` Mathieu Desnoyers
[not found] ` <2053850250.10158.1456582501604.JavaMail.zimbra-vg+e7yoeK/dWk0Htik3J/w@public.gmane.org>
2016-02-27 14:58 ` Peter Zijlstra
2016-02-27 14:58 ` Peter Zijlstra
[not found] ` <20160227145809.GD6356-ndre7Fmf5hadTX5a5knrm8zTDFooKrT+cvkQGrU6aU0@public.gmane.org>
2016-02-27 18:35 ` Linus Torvalds
2016-02-27 18:35 ` Linus Torvalds
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>
[not found] ` <1082926946.10326.1456619994590.JavaMail.zimbra-vg+e7yoeK/dWk0Htik3J/w@public.gmane.org>
2016-02-28 0:57 ` Linus Torvalds
2016-02-28 0:57 ` Linus Torvalds
[not found] ` <CA+55aFwZY1BR5NdjAP-rytd29hE2EZEXgcaBKjepWFFj+oR1SA-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2016-02-28 14:32 ` Mathieu Desnoyers
2016-02-28 14:32 ` Mathieu Desnoyers
[not found] ` <1538518747.10504.1456669948568.JavaMail.zimbra-vg+e7yoeK/dWk0Htik3J/w@public.gmane.org>
2016-02-29 10:35 ` Peter Zijlstra
2016-02-29 10:35 ` Peter Zijlstra
[not found] ` <20160229103506.GJ6356-ndre7Fmf5hadTX5a5knrm8zTDFooKrT+cvkQGrU6aU0@public.gmane.org>
2016-03-01 20:23 ` Mathieu Desnoyers [this message]
2016-03-01 20:23 ` Mathieu Desnoyers
[not found] ` <676569856.13488.1456863792603.JavaMail.zimbra-vg+e7yoeK/dWk0Htik3J/w@public.gmane.org>
2016-03-01 21:32 ` Peter Zijlstra
2016-03-01 21:32 ` Peter Zijlstra
[not found] ` <20160301213202.GY6357-ndre7Fmf5hadTX5a5knrm8zTDFooKrT+cvkQGrU6aU0@public.gmane.org>
2016-03-01 21:36 ` 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:32 ` Peter Zijlstra
[not found] ` <20160229103221.GI6356-ndre7Fmf5hadTX5a5knrm8zTDFooKrT+cvkQGrU6aU0@public.gmane.org>
2016-02-29 10:39 ` Arnd Bergmann
2016-02-29 10:39 ` Arnd Bergmann
2016-02-29 12:41 ` Mathieu Desnoyers
2016-02-29 12:41 ` Mathieu Desnoyers
[not found] ` <1811549980.11849.1456749709589.JavaMail.zimbra-vg+e7yoeK/dWk0Htik3J/w@public.gmane.org>
2016-02-29 13:08 ` Arnd Bergmann
2016-02-29 13:08 ` Arnd Bergmann
2016-02-29 18:19 ` H. Peter Anvin
2016-02-29 18:19 ` H. Peter Anvin
2016-03-02 10:44 ` Geert Uytterhoeven
2016-03-02 10:44 ` Geert Uytterhoeven
2016-03-01 18:25 ` H. Peter Anvin
2016-03-01 18:25 ` H. Peter Anvin
[not found] ` <56D5DEA8.3040908-YMNOUZJC4hwAvxtiuMwx3w@public.gmane.org>
2016-03-01 18:40 ` Mathieu Desnoyers
2016-03-01 18:40 ` Mathieu Desnoyers
[not found] ` <CA+55aFysWipEagSdgeXbLx+Au4vomvyttdNFJtM+HffmBECQiA-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2016-02-27 19:01 ` H. Peter Anvin
2016-02-27 19:01 ` H. Peter Anvin
2016-02-28 13:07 ` Geert Uytterhoeven
2016-02-28 13:07 ` Geert Uytterhoeven
[not found] ` <CAMuHMdV2dHsJfchyHBnQEAVEMSQ+1N7X4-iqGZ7K7J=Lf8qs4A-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2016-02-28 16:21 ` Linus Torvalds
2016-02-28 16:21 ` Linus Torvalds
2016-02-29 10:01 ` Peter Zijlstra
2016-02-29 10:01 ` Peter Zijlstra
2016-02-27 15:04 ` H. Peter Anvin
2016-02-27 15:04 ` H. Peter Anvin
2016-02-24 1:36 ` [PATCH v4 0/5] getcpu_cache system call for 4.6 H. Peter Anvin
2016-02-24 1:36 ` H. Peter Anvin
2016-02-24 4:09 ` Mathieu Desnoyers
[not found] ` <1452699925.6549.1456286963485.JavaMail.zimbra-vg+e7yoeK/dWk0Htik3J/w@public.gmane.org>
2016-02-24 20:07 ` H. Peter Anvin
2016-02-24 20:07 ` H. Peter Anvin
[not found] ` <F6BC367F-127F-4254-8E4E-E7BF60A027F3-YMNOUZJC4hwAvxtiuMwx3w@public.gmane.org>
2016-02-24 22:38 ` Mathieu Desnoyers
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=676569856.13488.1456863792603.JavaMail.zimbra@efficios.com \
--to=mathieu.desnoyers-vg+e7yoek/dwk0htik3j/w@public.gmane.org \
--cc=ahh-hpIqsD4AKlfQT0dZR+AlfA@public.gmane.org \
--cc=akpm-de/tnXTf+JLsfHDXvbKv3WD2FQJk+8+b@public.gmane.org \
--cc=andi-Vw/NltI1exuRpAAqCnN02g@public.gmane.org \
--cc=bmaurer-b10kYP2dOMg@public.gmane.org \
--cc=catalin.marinas-5wv7dgnIgG8@public.gmane.org \
--cc=cl-vYTEC60ixJUAvxtiuMwx3w@public.gmane.org \
--cc=davejwatson-b10kYP2dOMg@public.gmane.org \
--cc=hpa-YMNOUZJC4hwAvxtiuMwx3w@public.gmane.org \
--cc=josh-iaAMLnmF4UmaiuxdJuQwMA@public.gmane.org \
--cc=linux-api-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
--cc=linux-kernel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
--cc=linux-lFZ/pmaqli7XmaaqVzeoHQ@public.gmane.org \
--cc=luto-kltTT9wpgjJwATOyAt5JVQ@public.gmane.org \
--cc=mingo-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org \
--cc=mtk.manpages-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org \
--cc=paulmck-23VcF4HTsmIX0ybBhKVfKdBPR1lH4CV8@public.gmane.org \
--cc=peterz-wEGCiKHe2LqWVfeAwA7xHQ@public.gmane.org \
--cc=pjt-hpIqsD4AKlfQT0dZR+AlfA@public.gmane.org \
--cc=rostedt-nx8X9YLhiw1AfugRpC6u6w@public.gmane.org \
--cc=tglx-hfZtesqFncYOwBW4kG4KsQ@public.gmane.org \
--cc=torvalds-de/tnXTf+JLsfHDXvbKv3WD2FQJk+8+b@public.gmane.org \
--cc=will.deacon-5wv7dgnIgG8@public.gmane.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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.