From: Pavel Emelyanov <xemul-GEFAQzZX7r8dnm+yROfE0A@public.gmane.org>
To: "Serge E. Hallyn" <serue-r/Jw6+rmf7HQT0dZR+AlfA@public.gmane.org>
Cc: containers-cunTk1MwBs9QetFLy7KEm3xJsTq8ys+cHZ5vskTnxNA@public.gmane.org
Subject: Re: [RFC][PATCH 4/4] PID: use the target ID specified in procfs
Date: Tue, 11 Mar 2008 19:55:44 +0300 [thread overview]
Message-ID: <47D6B990.4080400@openvz.org> (raw)
In-Reply-To: <20080311164725.GA12918-6s5zFf/epYLPQpwDFJZrxKsjOiXwFzmk@public.gmane.org>
Serge E. Hallyn wrote:
> Quoting Pavel Emelyanov (xemul-GEFAQzZX7r8dnm+yROfE0A@public.gmane.org):
>> Nadia Derbey wrote:
>>> Pavel Emelyanov wrote:
>>>> Nadia.Derbey-6ktuUTfB/bM@public.gmane.org wrote:
>>>>
>>>>> @@ -122,14 +122,26 @@ static void free_pidmap(struct upid *upi
>>>>> atomic_inc(&map->nr_free);
>>>>> }
>>>>>
>>>>> -static int alloc_pidmap(struct pid_namespace *pid_ns)
>>>>> +static int alloc_pidmap(struct pid_namespace *pid_ns, struct pid_list *pid_l,
>>>>> + int level)
>>>>> {
>>>>> int i, offset, max_scan, pid, last = pid_ns->last_pid;
>>>>> struct pidmap *map;
>>>>>
>>>>> - pid = last + 1;
>>>>> - if (pid >= pid_max)
>>>>> - pid = RESERVED_PIDS;
>>>>> + if (!pid_l) {
>>>>> + pid = last + 1;
>>>>> + if (pid >= pid_max)
>>>>> + pid = RESERVED_PIDS;
>>>>> + } else {
>>>>> + /*
>>>>> + * There's a target pid, so use it instead
>>>>> + */
>>>>> + BUG_ON(level < 0);
>>>>> + pid = PID_AT(pid_l, level);
>>>>> + if (pid >= pid_max)
>>>>> + return -EINVAL;
>>>>> + }
>>>>> +
>>>>> offset = pid & BITS_PER_PAGE_MASK;
>>>>> map = &pid_ns->pidmap[pid/BITS_PER_PAGE];
>>>>> max_scan = (pid_max + BITS_PER_PAGE - 1)/BITS_PER_PAGE - !offset;
>>>>> @@ -153,9 +165,16 @@ static int alloc_pidmap(struct pid_names
>>>>> do {
>>>>> if (!test_and_set_bit(offset, map->page)) {
>>>>> atomic_dec(&map->nr_free);
>>>>> - pid_ns->last_pid = pid;
>>>>> + if (!pid_l)
>>>>> + pid_ns->last_pid = pid;
>>>>> + else
>>>>> + pid_ns->last_pid = max(last,
>>>>> + pid);
>>>>> return pid;
>>>>> }
>>>>> + if (pid_l)
>>>>> + /* Target pid is already in use */
>>>>> + return -EBUSY;
>>>>> offset = find_next_offset(map, offset);
>>>>> pid = mk_pid(pid_ns, map, offset);
>>>>> /*
>>>>> @@ -179,7 +198,7 @@ static int alloc_pidmap(struct pid_names
>>>>> }
>>>>> pid = mk_pid(pid_ns, map, offset);
>>>>> }
>>>>> - return -1;
>>>>> + return -ENOMEM;
>>>>> }
>>>>>
>>>>> int next_pidmap(struct pid_namespace *pid_ns, int last)
>>>> As fas as this particular piece of code is concerned this all can
>>>> be shrunk down to
>>>>
>>>> static int set_vpidmap(struct pid_namespace *ns, int pid)
>>>> {
>>>> int offset;
>>>> pidmap_t *map;
>>>>
>>>> offset = pid & BITS_PER_PAGE_MASK;
>>>> map = ns->pidmap + vpid / BITS_PER_PAGE;
>>>>
>>>> if (unlikely(alloc_pidmap_page(map)))
>>>> return -ENOMEM;
>>>>
>>>> if (test_and_set_bit(offset, map->page))
>>>> return -EEXIST;
>>>>
>>>> atomic_dec(&map->nr_free);
>>>> return pid;
>>>> }
>>>>
>>>> where the alloc_pidmap_page is a consolidated part of code from alloc_pidmap.
>>>>
>>>> And I'm scared of what the alloc_pid is going to become.
>>>>
>>>>
>>> It's true that I made alloc_pid() become uggly, but this patchset was
>>> more intended to continue a discussion.
>>>
>>> What we could do is the following (not compiled, not tested...):
>>>
>>> struct pid *alloc_pid(struct pid_namespace *ns)
>>> {
>>> struct pid *pid;
>>> enum pid_type type;
>>> int i, nr;
>>> struct pid_namespace *tmp;
>>> struct upid *upid;
>>>
>>> pid = kmem_cache_alloc(ns->pid_cachep, GFP_KERNEL);
>>> if (!pid) {
>>> pid = ERR_PTR(-ENOMEM);
>>> goto out;
>>> }
>>>
>>> tmp = ns;
>>> i = ns->level;
>>>
>>> if (current->next_id && (current->next_id->flag & SYS_ID_PID)) {
>>> tmp = set_predefined_pids(ns,
>>> current->next_id->pid_ids);
>>> if (IS_ERR(tmp)) {
>>> nr = PTR_ERR(tmp);
>>> goto out_free;
>>> }
>>> }
>>>
>>> /*
>>> * Let the lower levels upid nrs be automatically allocated
>>> */
>>> for ( ; i >= 0; i--) {
>>> nr = alloc_pidmap(tmp, NULL, -1);
>>> if (nr < 0)
>>> goto out_free;
>>> ....
>>>
>>> which would only add a test and a function call to alloc_pid() ==> more
>>> readable.
>>> with set_predefined_pids defined as follows (still not compiled, not
>>> tested, ...):
>>>
>>> struct pid_namespace *set_predefined_pids(struct pid_namespace *ns,
>>> struct pid_list *pid_l)
>>> {
>>> int rel_level;
>>>
>>> BUG_ON(!pid_l);
>>>
>>> rel_level = pid_l->npids - 1;
>>> if (rel_level > ns->level)
>>> return ERR_PTR(-EINVAL);
>>>
>>> /*
>>> * Use the predefined upid nrs for levels ns->level down to
>>> * ns->level - rel_level
>>> */
>>> for ( ; rel_level >= 0; i--, rel_level--) {
>>> nr = alloc_pidmap(tmp, pid_l, rel_level);
>>> if (nr < 0)
>>> return ERR_PTR(nr);
>>>
>>> pid->numbers[i].nr = nr;
>>> pid->numbers[i].ns = tmp;
>>> tmp = tmp->parent;
>>> }
>>>
>>> current->next_id->flag &= ~SYS_ID_PID;
>>> pids_free(pid_l);
>>> current->next_id->pid_ids = NULL;
>>>
>>> return tmp;
>>> }
>>>
>>>
>>> Don't you think that mixing this with your 1st proposal (the
>>> set_vpidmap() one), would make things look better?
>> I'd prefer seeing
>>
>> --- a/kernel/pid.c
>> +++ b/kernel/pid.c
>> @@ -247,7 +247,7 @@ struct pid *alloc_pid(struct pid_namespace *ns)
>> {
>> struct pid *pid;
>> enum pid_type type;
>> - int i, nr;
>> + int i, nr, req_nr;
>> struct pid_namespace *tmp;
>> struct upid *upid;
>>
>> @@ -257,7 +257,11 @@ struct pid *alloc_pid(struct pid_namespace *ns)
>>
>> tmp = ns;
>> for (i = ns->level; i >= 0; i--) {
>> - nr = alloc_pidmap(tmp);
>> + req_nr = get_required_pidnr(ns, i);
>> + if (req_nr > 0)
>> + nr = set_pidmap(tmp, req_nr);
>
> I assume you mean set_vpidmap(tmp, req_nr); here?
:) or however this one is called.
>> + else
>> + nr = alloc_pidmap(tmp);
>> if (nr < 0)
>> goto out_free;
>>
>>
>> in alloc_pid() and not much than that.
>
> So get_required_pidnr(ns, i) would do something like
>
> int get_required_pidnr(struct pid_namespace *ns, int i)
> {
> if (current->next_id && (current->next_id->flag & SYS_ID_PID)) {
> pid_l = current->next_id->pid_ids;
> if (!pid_l) return 0;
> rel_level = pid_l->npids - 1;
> if (rel_level <= i)
> return PID_AT(pid_l, i);
> }
> return 0;
> }
>
> ?
Well, yes, sort of. I haven't looked close to this part of patch,
but looks correct.
>>> Regards,
>>> Nadia
>>>
>> _______________________________________________
>> Containers mailing list
>> Containers-cunTk1MwBs9QetFLy7KEm3xJsTq8ys+cHZ5vskTnxNA@public.gmane.org
>> https://lists.linux-foundation.org/mailman/listinfo/containers
>
next prev parent reply other threads:[~2008-03-11 16:55 UTC|newest]
Thread overview: 33+ messages / expand[flat|nested] mbox.gz Atom feed top
2008-03-10 13:50 [RFC][PATCH 0/4] Object creation with a specified id Nadia.Derbey-6ktuUTfB/bM
2008-03-10 13:50 ` [RFC][PATCH 1/4] Provide a new procfs interface to set next ipc id Nadia.Derbey-6ktuUTfB/bM
2008-03-10 13:50 ` [RFC][PATCH 2/4] Provide a new procfs interface to set next upid nr(s) Nadia.Derbey-6ktuUTfB/bM
2008-03-10 13:50 ` [RFC][PATCH 3/4] IPC: use the target ID specified in procfs Nadia.Derbey-6ktuUTfB/bM
2008-03-10 13:50 ` [RFC][PATCH 4/4] PID: " Nadia.Derbey-6ktuUTfB/bM
[not found] ` <20080310135209.769712000-6ktuUTfB/bM@public.gmane.org>
2008-03-11 12:04 ` Pavel Emelyanov
[not found] ` <47D67557.7080506-GEFAQzZX7r8dnm+yROfE0A@public.gmane.org>
2008-03-11 15:28 ` Nadia Derbey
[not found] ` <47D6A52D.6030701-6ktuUTfB/bM@public.gmane.org>
2008-03-11 15:37 ` Pavel Emelyanov
[not found] ` <47D6A741.9080708-GEFAQzZX7r8dnm+yROfE0A@public.gmane.org>
2008-03-11 15:55 ` Nadia Derbey
2008-03-11 16:47 ` Serge E. Hallyn
[not found] ` <20080311164725.GA12918-6s5zFf/epYLPQpwDFJZrxKsjOiXwFzmk@public.gmane.org>
2008-03-11 16:55 ` Pavel Emelyanov [this message]
[not found] ` <47D6B990.4080400-GEFAQzZX7r8dnm+yROfE0A@public.gmane.org>
2008-03-11 17:53 ` Serge E. Hallyn
[not found] ` <20080311175328.GA14171-6s5zFf/epYLPQpwDFJZrxKsjOiXwFzmk@public.gmane.org>
2008-03-12 19:58 ` Eric W. Biederman
[not found] ` <m1zlt3yarj.fsf-T1Yj925okcoyDheHMi7gv2pdwda3JcWeAL8bYrjMMd8@public.gmane.org>
2008-03-13 10:41 ` Nadia Derbey
[not found] ` <47D904E4.4000208-6ktuUTfB/bM@public.gmane.org>
2008-03-13 17:40 ` Eric W. Biederman
[not found] ` <m1r6eewmj2.fsf-T1Yj925okcoyDheHMi7gv2pdwda3JcWeAL8bYrjMMd8@public.gmane.org>
2008-03-13 19:06 ` Serge E. Hallyn
2008-03-13 20:01 ` Oren Laadan
[not found] ` <47D987FE.9040909-eQaUEPhvms7ENvBUuze7eA@public.gmane.org>
2008-03-13 23:12 ` Eric W. Biederman
[not found] ` <m163vqw74n.fsf-T1Yj925okcoyDheHMi7gv2pdwda3JcWeAL8bYrjMMd8@public.gmane.org>
2008-03-13 23:24 ` Oren Laadan
[not found] ` <20080310135054.312992000-6ktuUTfB/bM@public.gmane.org>
2008-03-13 23:16 ` [RFC][PATCH 0/4] Object creation with a specified id Oren Laadan
[not found] ` <47D9B5B7.6060803-eQaUEPhvms7ENvBUuze7eA@public.gmane.org>
2008-03-14 6:21 ` Nadia Derbey
[not found] ` <47DA195B.8070704-6ktuUTfB/bM@public.gmane.org>
2008-03-14 15:50 ` Oren Laadan
[not found] ` <47DA9EB5.8040704-eQaUEPhvms7ENvBUuze7eA@public.gmane.org>
2008-03-14 15:56 ` Pavel Emelyanov
[not found] ` <47DAA041.9090009-GEFAQzZX7r8dnm+yROfE0A@public.gmane.org>
2008-03-14 16:02 ` Oren Laadan
[not found] ` <47DAA1A6.6010509-eQaUEPhvms7ENvBUuze7eA@public.gmane.org>
2008-03-14 16:08 ` Pavel Emelyanov
2008-03-14 16:11 ` Nadia Derbey
2008-03-14 16:11 ` Nadia Derbey
[not found] ` <47DAA3AA.4050906-6ktuUTfB/bM@public.gmane.org>
2008-03-14 16:45 ` Oren Laadan
[not found] ` <47DAABAB.7000706-eQaUEPhvms7ENvBUuze7eA@public.gmane.org>
2008-03-16 3:43 ` Serge E. Hallyn
[not found] ` <20080316034320.GA19793-6s5zFf/epYLPQpwDFJZrxFMas7LaWZ9n@public.gmane.org>
2008-03-16 19:08 ` Oren Laadan
[not found] ` <47DD703C.4030809-eQaUEPhvms7ENvBUuze7eA@public.gmane.org>
2008-03-17 14:44 ` Serge E. Hallyn
-- strict thread matches above, loose matches on Subject: below --
2008-03-28 9:53 [RFC][PATCH 0/4] Object creation with a pre-defined id (v2) Nadia.Derbey-6ktuUTfB/bM
2008-03-28 9:53 ` [RFC][PATCH 4/4] PID: use the target ID specified in procfs Nadia.Derbey-6ktuUTfB/bM
[not found] <20080404145129.637145000@bull.net>
2008-04-04 14:51 ` Nadia.Derbey-6ktuUTfB/bM
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=47D6B990.4080400@openvz.org \
--to=xemul-gefaqzzx7r8dnm+yrofe0a@public.gmane.org \
--cc=containers-cunTk1MwBs9QetFLy7KEm3xJsTq8ys+cHZ5vskTnxNA@public.gmane.org \
--cc=serue-r/Jw6+rmf7HQT0dZR+AlfA@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