All of lore.kernel.org
 help / color / mirror / Atom feed
From: Max Krasnyansky <maxk@qualcomm.com>
To: Paul Menage <menage@google.com>
Cc: mingo@elte.hu, pj@sgi.com, linux-kernel@vger.kernel.org,
	a.p.zijlstra@chello.nl
Subject: Re: [PATCH] cpuset: Make rebuild_sched_domains() usable from any context
Date: Tue, 15 Jul 2008 10:27:49 -0700	[thread overview]
Message-ID: <487CDE15.1070401@qualcomm.com> (raw)
In-Reply-To: <6599ad830807150914h152e3716n914dfa5e28288d28@mail.gmail.com>

Paul Menage wrote:
> On Tue, Jul 15, 2008 at 4:44 AM, Max Krasnyansky <maxk@qualcomm.com> wrote:
>> From: Max Krasnyanskiy <maxk@qualcomm.com>
>>
>> I do not really like the current solution of dropping cgroup lock
>> but it shows what I have in mind in general.
> 
> I think that dropping the cgroup lock will open up races for cpusets.
> The idea of a separate workqueue/thread to do the sched domain
> rebuilding is simplest.

Actually I audited (to the best of my knowledge) all the paths in 
cpusets and rebuild_sched_domains() is the last action. ie We drop the 
lock right after it anyways. It's just it's embedded deep in the call 
stack and therefor I cannot drop it at the higher level.

The only path where I think it's not safe is the cgroup destroy thing 
where we do
	
cgroup.c
	cgroup_lock();
	for_each_cgroups(...)
		cg->destroy();
	cgroup_unlock();

So in theory it's just that one patch that really needs the workqueue 
trick. But I do agree that it'll make it less tricky across the board.
So I'll pick up you work queue based patch, convert it to single 
threaded, bang on a bit later today and send a patch on top of this one.

Max



  reply	other threads:[~2008-07-15 17:28 UTC|newest]

Thread overview: 7+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2008-07-15 11:44 [PATCH] cpuset: Make rebuild_sched_domains() usable from any context Max Krasnyansky
2008-07-15 16:07 ` Paul Jackson
2008-07-15 16:11   ` Paul Menage
2008-07-15 17:19     ` Max Krasnyansky
2008-07-15 16:14 ` Paul Menage
2008-07-15 17:27   ` Max Krasnyansky [this message]
2008-07-15 20:51   ` Max Krasnyansky

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=487CDE15.1070401@qualcomm.com \
    --to=maxk@qualcomm.com \
    --cc=a.p.zijlstra@chello.nl \
    --cc=linux-kernel@vger.kernel.org \
    --cc=menage@google.com \
    --cc=mingo@elte.hu \
    --cc=pj@sgi.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 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.