Nosched context sould never be scheduled out, thus we must not
deactivate them in spu_yield ever.
Signed-off-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Jeremy Kerr <jk@ozlabs.org>
Signed-off-by: Paul Mackerras <paulus@samba.org>
  */
 void spu_yield(struct spu_context *ctx)
 {
-       mutex_lock(&ctx->state_mutex);
-       __spu_deactivate(ctx, 0, MAX_PRIO);
-       mutex_unlock(&ctx->state_mutex);
+       if (!(ctx->flags & SPU_CREATE_NOSCHED)) {
+               mutex_lock(&ctx->state_mutex);
+               __spu_deactivate(ctx, 0, MAX_PRIO);
+               mutex_unlock(&ctx->state_mutex);
+       }
 }
 
 void spu_sched_tick(struct work_struct *work)