On Wed, 1 Mar 2017 10:44:09 +0100
Peter Zijlstra <pet...@infradead.org> wrote:

> On Tue, Feb 28, 2017 at 03:50:30PM -0500, Steven Rostedt wrote:
> > + * The overloaded RT CPU, wher receiving an IPI, will try to push off its  
> 
> "wher" isn't in my dictionary, I'm thinking you mean: "when". Fixed that
> for you.

Heh, thanks. Hmm, I looked at all the highlighted words when I pulled
in the patch into claws-mail. I'm surprised I missed that.

> 
> > + * overloaded RT tasks and then send an IPI to the next CPU that has
> > + * overloaded RT tasks. This stops when all CPUs with overloaded RT tasks
> > + * have completed. Just because a CPU may have pushed off its own 
> > overloaded
> > + * RT task does not mean it should stop sending the IPI around to other
> > + * overloaded CPUs. There may be another RT task waiting to run on one of
> > + * those CPUs that are of higher priority than the one that was just
> > + * pushed.
> > + *
> > + * An optimization that could possibly be made is to make a CPU array 
> > similar
> > + * to the cpupri array mask of all running RT tasks, but for the overloaded
> > + * case, then the IPI could be sent to only the CPU with the highest 
> > priority
> > + * RT task waiting, and that CPU could send off further IPIs to the CPU 
> > with
> > + * the next highest waiting task. Since the overloaded case is much less 
> > likely
> > + * to happen, the complexity of this implementation may not be worth it.
> > + * Instead, just send an IPI around to all overloaded CPUs.  
> 
> Yeah, not sure, I'll leave it in though.

OK,

Thanks!

-- Steve

Reply via email to