From: Pavel Emelyanov <xemul-GEFAQzZX7r8dnm+yROfE0A@public.gmane.org>
To: Oleg Nesterov <oleg-6lXkIZvqkOAvJsYlp49lxw@public.gmane.org>
Cc: Linux Containers
<containers-qjLDD68F18O7TbgM5vRIOg@public.gmane.org>,
"Eric W. Biederman"
<ebiederm-aS9lmoZGLiVWk0Htik3J/w@public.gmane.org>
Subject: Re: [RFC][PATCH] Make access to taks's nsproxy liter
Date: Thu, 09 Aug 2007 11:09:55 +0400 [thread overview]
Message-ID: <46BABDC3.9090608@openvz.org> (raw)
In-Reply-To: <20070808171955.GA655-6lXkIZvqkOAvJsYlp49lxw@public.gmane.org>
Oleg Nesterov wrote:
> On 08/08, Eric W. Biederman wrote:
>> Oleg Nesterov <oleg-6lXkIZvqkOAvJsYlp49lxw@public.gmane.org> writes:
>>
>>> On 08/08, Pavel Emelyanov wrote:
>>>> +void switch_task_namespaces(struct task_struct *p, struct nsproxy *new)
>>>> +{
>>>> + struct nsproxy *ns;
>>>> +
>>>> + might_sleep();
>>>> +
>>>> + ns = p->nsproxy;
>>>> + if (ns == new)
>>>> + return;
>>>> +
>>>> + if (new)
>>>> + get_nsproxy(new);
>>>> + rcu_assign_pointer(p->nsproxy, new);
>>>> +
>>>> + if (ns && atomic_dec_and_test(&ns->count)) {
>>>> + /*
>>>> + * wait for others to get what they want from this
>>>> + * nsproxy. cannot release this nsproxy via the
>>>> + * call_rcu() since put_mnt_ns will want to sleep
>>>> + */
>>>> + synchronize_rcu();
>>>> + free_nsproxy(ns);
>>>> + }
>>>> +}
>>> (I may be wrong, Paul cc'ed)
>>>
>>> This is correct with the current implementation of RCU, but strictly speaking,
>>> we can't use synchronize_rcu() here, because write_lock_irq() doesn't imply
>>> rcu_read_lock() in theory.
void __lockfunc _write_lock(rwlock_t *lock)
{
preempt_disable();
rwlock_acquire(&lock->dep_map, 0, 0, _RET_IP_);
LOCK_CONTENDED(lock, _raw_write_trylock, _raw_write_lock);
}
preempt_disable == rcu_read_lock() due to
#define rcu_read_lock() \
do { \
preempt_disable(); \
__acquire(RCU); \
} while(0)
so currently this is enough to write_lock()
>> But we should be able to do:
>>
>> write_lock_irq();
>> rcu_read_lock();
>> muck with other tasks nsproxy.
>> rcu_read_unlock();
>> write_unlock_irq();
>>
>> Which would make rcu fine.
>
> Yes sure. I just meant that the patch looks incomplete. But we didn't
> hear Paul yet, perhaps I'm just wrong.
>
>> The real locking we have is that only a task is allowed to modify it's
>> own nsproxy pointer. Other processes are not.
>>
>> The practical question is how do we enable other processes to read
>> a particular tasks nsproxy or something pointed to by it?
>
> task_lock(). The only problem we can't take it in do_notify_parent(),
> but if we add read_lock(tasklist) to sys_unshare, we can safely access
> ->parent->nsproxy.
we can safely access parent's nsproxy with this patch like this:
rcu_read_lock();
nsproxy = task_nsproxy(p->parent);
BUG_ON(nsproxy == NULL); /* parent should reparent us before exiting nsproxy */
pid_ns = nsproxy->pid_ns;
...
rcu_read_unlock();
>
> Oleg.
>
>
next prev parent reply other threads:[~2007-08-09 7:09 UTC|newest]
Thread overview: 23+ messages / expand[flat|nested] mbox.gz Atom feed top
2007-08-08 15:37 [RFC][PATCH] Make access to taks's nsproxy liter Pavel Emelyanov
[not found] ` <46B9E321.6070602-GEFAQzZX7r8dnm+yROfE0A@public.gmane.org>
2007-08-08 16:29 ` Eric W. Biederman
[not found] ` <m1ps1yc7mp.fsf-T1Yj925okcoyDheHMi7gv2pdwda3JcWeAL8bYrjMMd8@public.gmane.org>
2007-08-09 7:10 ` Pavel Emelyanov
[not found] ` <46BABDE9.6090508-GEFAQzZX7r8dnm+yROfE0A@public.gmane.org>
2007-08-09 8:00 ` Eric W. Biederman
[not found] ` <m13aytb0j0.fsf-T1Yj925okcoyDheHMi7gv2pdwda3JcWeAL8bYrjMMd8@public.gmane.org>
2007-08-09 8:17 ` Pavel Emelyanov
2007-08-08 16:37 ` Oleg Nesterov
[not found] ` <20070808163757.GA578-6lXkIZvqkOAvJsYlp49lxw@public.gmane.org>
2007-08-08 17:03 ` Eric W. Biederman
[not found] ` <m14pjac61z.fsf-T1Yj925okcoyDheHMi7gv2pdwda3JcWeAL8bYrjMMd8@public.gmane.org>
2007-08-08 17:19 ` Oleg Nesterov
[not found] ` <20070808171955.GA655-6lXkIZvqkOAvJsYlp49lxw@public.gmane.org>
2007-08-09 7:09 ` Pavel Emelyanov [this message]
2007-08-08 16:41 ` Oleg Nesterov
[not found] ` <20070808164107.GB578-6lXkIZvqkOAvJsYlp49lxw@public.gmane.org>
2007-08-08 17:23 ` Paul E. McKenney
[not found] ` <20070808172309.GA8909-23VcF4HTsmIX0ybBhKVfKdBPR1lH4CV8@public.gmane.org>
2007-08-08 17:36 ` Oleg Nesterov
[not found] ` <20070808173647.GA676-6lXkIZvqkOAvJsYlp49lxw@public.gmane.org>
2007-08-08 18:48 ` Paul E. McKenney
2007-08-09 7:15 ` Pavel Emelyanov
[not found] ` <46BABF25.1090307-GEFAQzZX7r8dnm+yROfE0A@public.gmane.org>
2007-08-09 7:39 ` Oleg Nesterov
[not found] ` <20070809073900.GA86-6lXkIZvqkOAvJsYlp49lxw@public.gmane.org>
2007-08-09 7:46 ` Pavel Emelyanov
[not found] ` <46BAC671.4070908-GEFAQzZX7r8dnm+yROfE0A@public.gmane.org>
2007-08-09 8:06 ` Oleg Nesterov
2007-08-09 7:49 ` Oleg Nesterov
2007-08-09 7:14 ` Pavel Emelyanov
2007-08-08 16:48 ` Serge E. Hallyn
[not found] ` <20070808164854.GB28455-6s5zFf/epYLPQpwDFJZrxKsjOiXwFzmk@public.gmane.org>
2007-08-08 16:58 ` Oleg Nesterov
2007-08-09 7:12 ` Pavel Emelyanov
[not found] ` <46BABE53.6050604-GEFAQzZX7r8dnm+yROfE0A@public.gmane.org>
2007-08-09 14:10 ` Serge E. Hallyn
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=46BABDC3.9090608@openvz.org \
--to=xemul-gefaqzzx7r8dnm+yrofe0a@public.gmane.org \
--cc=containers-qjLDD68F18O7TbgM5vRIOg@public.gmane.org \
--cc=ebiederm-aS9lmoZGLiVWk0Htik3J/w@public.gmane.org \
--cc=oleg-6lXkIZvqkOAvJsYlp49lxw@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.