From: "Michael Kerrisk (man-pages)" <mtk.manpages-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
To: Josh Triplett <josh-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org>
Cc: mtk.manpages-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org,
Keno Fischer
<keno-9DCaDmOhoh+8M3too/+dENBPR1lH4CV8@public.gmane.org>,
linux-man-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
pschiffe-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org,
Mike Frysinger <vapier-aBrp7R+bbdUdnm+yROfE0A@public.gmane.org>
Subject: Re: [PATCH] clone.2: Adjust syscall prototype and expand CLONE_SETTLS description
Date: Sun, 25 Sep 2016 22:20:02 +0200 [thread overview]
Message-ID: <1bdb82c7-0450-18ba-ebb0-c12de0ba6527@gmail.com> (raw)
In-Reply-To: <20160925192930.qxrefcc46fmbnxzv@x>
On 09/25/2016 09:29 PM, Josh Triplett wrote:
> On Sun, Sep 25, 2016 at 09:03:07PM +0200, Michael Kerrisk (man-pages) wrote:
>> On 09/04/2016 07:11 AM, Josh Triplett wrote:
>>> On Sun, Sep 04, 2016 at 04:30:44PM +1200, Michael Kerrisk (man-pages) wrote:
>>>> [CC += Josh]
>>>>
>>>> Josh, I know you were submitting patches relate to the clone() TLS argument a
>>>> while back. Could you comment on this patch proposal below (also
>>>> https://bugzilla.kernel.org/show_bug.cgi?id=118241 is relevant).
>>>
>>> Sure.
>>>
>>>> On 08/24/2016 03:06 PM, Keno Fischer wrote:
>>>>> The prototype for the system call was added in 81f10dad, but looking at the
>>>>> kernel's fork.c, I believe the relevant definition is
>>>>>
>>>>> SYSCALL_DEFINE5(clone, unsigned long, clone_flags, unsigned long, newsp,
>>>>> int __user *, parent_tidptr,
>>>>> int __user *, child_tidptr,
>>>>> unsigned long, tls)
>>>>>
>>>>> so the last argument is the tls argument, not a pt_regs argument.
>>>>> I stumbled upon this while trying to understand CLONE_SETTLS, so I expanded
>>>>> that description a little to cover other architectures.
>>>
>>> This description and patch looks correct to me.
>>> Reviewed-by: Josh Triplett <josh-iaAMLnmF4UmaiuxdJuQwMA@public.gmane.org>
>>
>> Thanks, Josh.
>>
>>> Ideally, I'd suggest a follow-up patch to improve the prototypes for the
>>> various architectures. Rather than saying "x86 looks roughly this way,
>>> on these architectures swap these arguments, on these architectures
>>> ...", I'd suggest explicitly giving each of the four prototypes (normal,
>>> CONFIG_CLONE_BACKWARDS, CONFIG_CLONE_BACKWARDS2,
>>> CONFIG_CLONE_BACKWARDS3) and the corresponding architectures.
>>
>> I applied the patch below. Okay?
>
> Mostly looks good, but one comment below.
>
>> diff --git a/man2/clone.2 b/man2/clone.2
>> index 5c1e301..26c6b30 100644
>> --- a/man2/clone.2
>> +++ b/man2/clone.2
>> @@ -54,11 +54,7 @@ clone, __clone2 \- create a child process
>> .BI " /* pid_t *" ptid ", void *" newtls \
>> ", pid_t *" ctid " */ );"
>>
>> -/* Prototype for the raw system call */
>> -
>> -.BI "long clone(unsigned long " flags ", void *" child_stack ,
>> -.BI " int *" ptid ", int *" ctid ,
>> -.BI " unsigned long " newtls );
>> +/* For the prototype of the raw system call, see NOTES */
>> .fi
>> .SH DESCRIPTION
>> .BR clone ()
>> @@ -821,16 +817,58 @@ arguments of the
>> .BR clone ()
>> wrapper function are omitted.
>> Furthermore, the argument order changes.
>> -The raw system call interface on x86 and many other architectures is roughly:
>> +In addition, there are variations across architectures.
>> +
>> +The raw system call interface on x86-64 and some other architectures
>> +(including sh, tile, and alpha) is roughly:
>> +
>> .in +4
>> .nf
>> +.BI "long clone(unsigned long " flags ", void *" child_stack ,
>> +.BI " int *" ptid ", int *" ctid ,
>> +.BI " unsigned long " newtls );
>> +.fi
>> +.in
>> +
>> +On x86-32, and several other common architectures
>> +(including score, microblaze, ARM, ARM 64, PA-RISC, arc, Power PC, xtensa,
>> +and MIPS),
>> +.\" CONFIG_CLONE_BACKWARDS
>> +the order of the last two arguments is reversed:
>>
>> +.in +4
>> +.nf
>> .BI "long clone(unsigned long " flags ", void *" child_stack ,
>> +.BI " int *" ptid ", unsigned long " newtls ,
>> +.BI " int *" ctid );
>> +.fi
>> +.in
>> +
>> +On the cris and s390 architectures,
>> +.\" CONFIG_CLONE_BACKWARDS2
>> +the order of the first two arguments is reversed:
>> +
>> +.in +4
>> +.nf
>> +.BI "long clone(void *" child_stack ", unsigned long " flags ,
>> .BI " int *" ptid ", int *" ctid ,
>> .BI " unsigned long " newtls );
>> +.fi
>> +.in
>> +
>> +On the microblaze architecture,
>> +.\" CONFIG_CLONE_BACKWARDS3
>> +an additional argument is supplied:
>
> This mentions microblaze twice: one in CONFIG_CLONE_BACKWARDS and again
> here.
Ahh -- the furst mention was a mistake. Fixed now. Thanks for spotting that.
> And I don't see IA-64 mentioned anywhere.
It was already covered by existing text in the page.
Cheers,
Michael
--
Michael Kerrisk
Linux man-pages maintainer; http://www.kernel.org/doc/man-pages/
Linux/UNIX System Programming Training: http://man7.org/training/
--
To unsubscribe from this list: send the line "unsubscribe linux-man" in
the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
next prev parent reply other threads:[~2016-09-25 20:20 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-08-24 3:06 [PATCH] clone.2: Adjust syscall prototype and expand CLONE_SETTLS description Keno Fischer
[not found] ` <20160824030607.GA2596-nTuEee01erudBw3G0RLmbfBZMHv189dXZkel5v8DVj8@public.gmane.org>
2016-09-04 4:30 ` Michael Kerrisk (man-pages)
[not found] ` <2c257a1e-b7c5-c2bc-09ab-a2a685ae37b7-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
2016-09-04 5:11 ` Josh Triplett
2016-09-25 19:03 ` Michael Kerrisk (man-pages)
[not found] ` <5b7eb44c-0f9a-f143-9e3d-9927961b2139-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
2016-09-25 19:29 ` Josh Triplett
2016-09-25 20:20 ` Michael Kerrisk (man-pages) [this message]
2016-09-25 18:06 ` Michael Kerrisk (man-pages)
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=1bdb82c7-0450-18ba-ebb0-c12de0ba6527@gmail.com \
--to=mtk.manpages-re5jqeeqqe8avxtiumwx3w@public.gmane.org \
--cc=josh-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org \
--cc=keno-9DCaDmOhoh+8M3too/+dENBPR1lH4CV8@public.gmane.org \
--cc=linux-man-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
--cc=pschiffe-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org \
--cc=vapier-aBrp7R+bbdUdnm+yROfE0A@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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox