From: Steven Rostedt <rostedt@goodmis.org>
To: Peter Williams <pwil3058@bigpond.net.au>
Cc: Ingo Molnar <mingo@elte.hu>, Thomas Gleixner <tglx@linutronix.de>,
Andrew Morton <akpm@osdl.org>,
LKML <linux-kernel@vger.kernel.org>,
Nick Piggin <nickpiggin@yahoo.com.au>
Subject: Re: [PATCH] Avoid moving tasks when a schedule can be made.
Date: Wed, 01 Feb 2006 21:48:31 -0500 [thread overview]
Message-ID: <1138848511.6632.41.camel@localhost.localdomain> (raw)
In-Reply-To: <43E15FAE.6040707@bigpond.net.au>
On Thu, 2006-02-02 at 12:26 +1100, Peter Williams wrote:
> >
> > Actually, one of the tasks that was moved might need to resched right
> > away, since it preempts the current task that is doing the moving.
>
> Good point but I'd say that this was an instance when you didn't want to
> bail out of the load balance. E.g. during idle balancing the very first
> task moved would trigger it regardless of its priority. Also, if the
> task was of sufficiently high priority for it to warrant bailing out of
> the load balance why wasn't the current task (i.e. why didn't it preempt
> on its current CPU).
Because the task running on the current CPU is higher in priority. That
doesn't mean that the next one down shouldn't get scheduled on another
CPU if it is a higher priority than the currently running one. Of
course one needs to be careful not to cause too much cache blasting by
popping RT tasks all over CPUS.
>
> >
> >
> >>However, a newly woken task that preempts the current task isn't the
> >>only way that needs_resched() can become true just before load balancing
> >>is started. E.g. scheduler_tick() calls set_tsk_need_resched(p) when a
> >>task finishes a time slice and this patch would cause rebalance_tick()
> >>to be aborted after a lot of work has been done in this case.
> >
> >
> > No real work is lost. This is a loop that individually pulls tasks. So
> > the bail only stops the work of looking for more tasks to pull and we
> > don't lose the tasks that have already been pulled.
>
> I disagree. A bunch of work is done to determine which CPU to pull from
> and how many tasks to pull and then it will bail out before any of them
> are moved (and for no good reason).
Yeah, that was my mistake. There is work lost. So nuke that argument of
mine :)
>
> >
> >
> >>In summary, I think that the bail out is badly placed and needs some way
> >>of knowing if the reason need_resched() has become true is because of
> >>preemption of a newly woken task and not some other reason.
> >
> >
> > I need that bail in the loop, so it can stop if needed. Like I said, it
> > can be a task that is pulled to cause the bail. Also, having the run
> > queue locks and interrupts off for over a msec is really a bad idea.
>
> Clearly, the way to handle this is to impose some limit on the number of
> tasks to be moved or split large moves into a number of smaller moves
> (releasing and reacquiring locks in between). This could be done in the
> bits of code that set things up before move_tasks() is called.
I think that's something like what Ingo wants to do. Or something other
than my first brain dead patch.
>
> >
> >
> >>Peter
> >>PS I've added Nick Piggin to the CC list as he is interested in load
> >>balancing issues.
> >
> >
> > Thanks, and thanks for the comments too. I'm up for all suggestions and
> > ideas. I just feel it is important that we don't have unbounded
> > latencies of spin locks and interrupts off.
>
> Well, you seem to have succeeded in starting a discussion :-)
:)
-- Steve
next prev parent reply other threads:[~2006-02-02 2:48 UTC|newest]
Thread overview: 33+ messages / expand[flat|nested] mbox.gz Atom feed top
2006-01-31 19:43 [PATCH] Avoid moving tasks when a schedule can be made Steven Rostedt
2006-02-01 3:36 ` Peter Williams
2006-02-01 12:44 ` Steven Rostedt
2006-02-01 13:06 ` Nick Piggin
2006-02-01 13:10 ` Nick Piggin
2006-02-01 13:20 ` Ingo Molnar
2006-02-01 13:47 ` Nick Piggin
2006-02-01 13:54 ` Nick Piggin
2006-02-01 14:12 ` Ingo Molnar
2006-02-01 14:25 ` Nick Piggin
2006-02-01 14:37 ` Ingo Molnar
2006-02-01 14:54 ` Nick Piggin
2006-02-01 15:11 ` Ingo Molnar
2006-02-01 15:31 ` Nick Piggin
2006-02-01 16:10 ` Ingo Molnar
2006-02-01 16:25 ` Nick Piggin
2006-02-01 17:24 ` Ingo Molnar
2006-02-06 11:21 ` Nick Piggin
2006-02-01 14:00 ` Ingo Molnar
2006-02-01 14:09 ` Nick Piggin
2006-02-01 14:22 ` Ingo Molnar
2006-02-01 14:32 ` Steven Rostedt
2006-02-02 1:26 ` Peter Williams
2006-02-02 2:48 ` Steven Rostedt [this message]
2006-02-02 3:19 ` Peter Williams
2006-02-01 13:08 ` Ingo Molnar
2006-02-01 13:11 ` Ingo Molnar
2006-02-02 1:42 ` Peter Williams
2006-02-02 2:51 ` Steven Rostedt
2006-02-01 13:15 ` Steven Rostedt
2006-02-01 13:23 ` Steven Rostedt
2006-02-01 13:26 ` Ingo Molnar
2006-02-01 16:11 ` Steven Rostedt
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=1138848511.6632.41.camel@localhost.localdomain \
--to=rostedt@goodmis.org \
--cc=akpm@osdl.org \
--cc=linux-kernel@vger.kernel.org \
--cc=mingo@elte.hu \
--cc=nickpiggin@yahoo.com.au \
--cc=pwil3058@bigpond.net.au \
--cc=tglx@linutronix.de \
/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