diff options
author | Christoph Hellwig <hch@lst.de> | 2007-03-23 10:12:26 -0400 |
---|---|---|
committer | Paul Mackerras <paulus@samba.org> | 2007-04-12 13:55:15 -0400 |
commit | dbf8eefa2b814d6922492120bfa46d4bc42ceb20 (patch) | |
tree | bb70c85fdcbce38001e9a5d9f1bb556e1eb4379f | |
parent | 28066ae91b2050d79531a6f2d5e35dd8f666bafd (diff) |
[POWERPC] spufs: don't yield CPU in spu_yield
There is no reason to yield the CPU in spu_yield - if the backing
thread reenters spu_run it gets added to the end of the runqueue for
it's priority. So the yield is just a slowdown for the case where
we have higher priority contexts waiting.
Signed-off-by: Christoph Hellwig <hch@lst.de>
Acked-by: Arnd Bergmann <arnd@arndb.de>
Signed-off-by: Paul Mackerras <paulus@samba.org>
-rw-r--r-- | arch/powerpc/platforms/cell/spufs/sched.c | 4 |
1 files changed, 0 insertions, 4 deletions
diff --git a/arch/powerpc/platforms/cell/spufs/sched.c b/arch/powerpc/platforms/cell/spufs/sched.c index 39823cec0844..c9561582ce2a 100644 --- a/arch/powerpc/platforms/cell/spufs/sched.c +++ b/arch/powerpc/platforms/cell/spufs/sched.c | |||
@@ -438,7 +438,6 @@ void spu_deactivate(struct spu_context *ctx) | |||
438 | void spu_yield(struct spu_context *ctx) | 438 | void spu_yield(struct spu_context *ctx) |
439 | { | 439 | { |
440 | struct spu *spu; | 440 | struct spu *spu; |
441 | int need_yield = 0; | ||
442 | 441 | ||
443 | if (mutex_trylock(&ctx->state_mutex)) { | 442 | if (mutex_trylock(&ctx->state_mutex)) { |
444 | if ((spu = ctx->spu) != NULL) { | 443 | if ((spu = ctx->spu) != NULL) { |
@@ -447,13 +446,10 @@ void spu_yield(struct spu_context *ctx) | |||
447 | pr_debug("%s: yielding SPU %d NODE %d\n", | 446 | pr_debug("%s: yielding SPU %d NODE %d\n", |
448 | __FUNCTION__, spu->number, spu->node); | 447 | __FUNCTION__, spu->number, spu->node); |
449 | spu_deactivate(ctx); | 448 | spu_deactivate(ctx); |
450 | need_yield = 1; | ||
451 | } | 449 | } |
452 | } | 450 | } |
453 | mutex_unlock(&ctx->state_mutex); | 451 | mutex_unlock(&ctx->state_mutex); |
454 | } | 452 | } |
455 | if (unlikely(need_yield)) | ||
456 | yield(); | ||
457 | } | 453 | } |
458 | 454 | ||
459 | int __init spu_sched_init(void) | 455 | int __init spu_sched_init(void) |