Re: [RFC -v2 PATCH 2/3] sched: add yield_to function

Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]
From: Mike Galbraith
Date: Sunday, December 19, 2010 - 3:05 am

On Sun, 2010-12-19 at 08:21 +0200, Avi Kivity wrote:


That's why you'd drop lag, set to max(se->vruntime, cfs_rq->min_vruntime).


I don't get this part.  How does the whole process yield if one thread
yields?


And that's the hard part.  If can drop lag, you may hurt yourself, but
at least only yourself.


That makes it difficult to the point of impossible.

You want a specific task to run NOW for good reasons, but any number of
tasks may want the same godlike power for equally good reasons.

You could create a force select which only godly tasks could use that
didn't try to play games with vruntimes, just let the bugger run, and
let him also eat the latency hit he'll pay for that extra bit of cpu IFF
you didn't care about being able to mix loads.

Or, you could just bump his nice level with an automated return to
previous level on resched.

Any intervention has unavoidable consequences for all comers though.


(dropping lag on the floor)


SOME tasks receive gifts from the void.  The difference is the bias.


What's that? :)  No task may run until there are enough of you to fill
the box?  God help you when somebody else wakes up Mr. Early-bird? ...


It doesn't ignore it complete, it just doesn't try to do all the math
continuously (danger Will Robinson: Peter has scary patches).  Prodding
it in the right general direction with migrations is cheaper.

	-Mike

--
Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]

Messages in current thread:
[RFC -v2 PATCH 2/3] sched: add yield_to function, Rik van Riel, (Mon Dec 13, 8:46 pm)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Mike Galbraith, (Mon Dec 13, 11:08 pm)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Srivatsa Vaddagiri, (Tue Dec 14, 3:24 am)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Mike Galbraith, (Tue Dec 14, 4:03 am)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Srivatsa Vaddagiri, (Tue Dec 14, 4:26 am)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Peter Zijlstra, (Tue Dec 14, 5:22 am)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Mike Galbraith, (Tue Dec 14, 5:47 am)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Rik van Riel, (Thu Dec 16, 12:49 pm)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Mike Galbraith, (Thu Dec 16, 11:56 pm)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Mike Galbraith, (Fri Dec 17, 12:15 am)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Avi Kivity, (Fri Dec 17, 8:09 am)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Mike Galbraith, (Fri Dec 17, 12:51 pm)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Rik van Riel, (Sat Dec 18, 7:50 am)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Avi Kivity, (Sat Dec 18, 10:02 am)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Avi Kivity, (Sat Dec 18, 10:08 am)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Mike Galbraith, (Sat Dec 18, 12:06 pm)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Mike Galbraith, (Sat Dec 18, 12:13 pm)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Avi Kivity, (Sat Dec 18, 11:08 pm)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Avi Kivity, (Sat Dec 18, 11:21 pm)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Avi Kivity, (Sun Dec 19, 2:19 am)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Mike Galbraith, (Sun Dec 19, 3:05 am)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Mike Galbraith, (Sun Dec 19, 4:18 am)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Mike Galbraith, (Mon Dec 20, 1:39 am)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Avi Kivity, (Mon Dec 20, 1:45 am)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Mike Galbraith, (Mon Dec 20, 1:55 am)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Avi Kivity, (Mon Dec 20, 2:03 am)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Mike Galbraith, (Mon Dec 20, 2:30 am)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Avi Kivity, (Mon Dec 20, 2:46 am)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Mike Galbraith, (Mon Dec 20, 3:33 am)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Avi Kivity, (Mon Dec 20, 3:39 am)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Mike Galbraith, (Mon Dec 20, 3:46 am)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Avi Kivity, (Mon Dec 20, 3:49 am)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Mike Galbraith, (Mon Dec 20, 3:50 am)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Avi Kivity, (Mon Dec 20, 4:06 am)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Rik van Riel, (Mon Dec 20, 8:40 am)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Mike Galbraith, (Mon Dec 20, 9:04 am)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Mike Galbraith, (Mon Dec 27, 10:54 pm)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Gene Heskett, (Mon Dec 27, 11:08 pm)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Mike Galbraith, (Mon Dec 27, 11:16 pm)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Gene Heskett, (Tue Dec 28, 9:18 am)
Re: [RFC -v2 PATCH 2/3] sched: add yield_to function, Rik van Riel, (Tue Dec 28, 3:34 pm)