diff options
Diffstat (limited to 'kernel/sched/core.c')
-rw-r--r-- | kernel/sched/core.c | 20 |
1 files changed, 18 insertions, 2 deletions
diff --git a/kernel/sched/core.c b/kernel/sched/core.c index 8781cec7c3e6..47614a5cdd47 100644 --- a/kernel/sched/core.c +++ b/kernel/sched/core.c | |||
@@ -4577,8 +4577,24 @@ EXPORT_SYMBOL(__cond_resched_softirq); | |||
4577 | /** | 4577 | /** |
4578 | * yield - yield the current processor to other threads. | 4578 | * yield - yield the current processor to other threads. |
4579 | * | 4579 | * |
4580 | * This is a shortcut for kernel-space yielding - it marks the | 4580 | * Do not ever use this function, there's a 99% chance you're doing it wrong. |
4581 | * thread runnable and calls sys_sched_yield(). | 4581 | * |
4582 | * The scheduler is at all times free to pick the calling task as the most | ||
4583 | * eligible task to run, if removing the yield() call from your code breaks | ||
4584 | * it, its already broken. | ||
4585 | * | ||
4586 | * Typical broken usage is: | ||
4587 | * | ||
4588 | * while (!event) | ||
4589 | * yield(); | ||
4590 | * | ||
4591 | * where one assumes that yield() will let 'the other' process run that will | ||
4592 | * make event true. If the current task is a SCHED_FIFO task that will never | ||
4593 | * happen. Never use yield() as a progress guarantee!! | ||
4594 | * | ||
4595 | * If you want to use yield() to wait for something, use wait_event(). | ||
4596 | * If you want to use yield() to be 'nice' for others, use cond_resched(). | ||
4597 | * If you still want to use yield(), do not! | ||
4582 | */ | 4598 | */ |
4583 | void __sched yield(void) | 4599 | void __sched yield(void) |
4584 | { | 4600 | { |