aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorArnd Bergmann <arnd@arndb.de>2007-07-20 15:39:49 -0400
committerArnd Bergmann <arnd@klappe.arndb.de>2007-07-20 15:42:18 -0400
commitcbc23d3e7cb3c9fd3c9fce0bc3f44f687a9517c0 (patch)
tree4adcbbfa5402e46c816788cd86f992082d2a6f61
parentc5fc8d2a92461fcabd00dfd678204cba36b93119 (diff)
[CELL] spufs: integration of SPE affinity with the scheduller
This patch makes the scheduller honor affinity information for each context being scheduled. If the context has no affinity information, behaviour is unchanged. If there are affinity information, context is schedulled to be run on the exact spu recommended by the affinity placement algorithm. Signed-off-by: Andre Detsch <adetsch@br.ibm.com> Signed-off-by: Arnd Bergmann <arnd.bergmann@de.ibm.com>
-rw-r--r--arch/powerpc/platforms/cell/spu_base.c19
-rw-r--r--arch/powerpc/platforms/cell/spufs/sched.c4
2 files changed, 23 insertions, 0 deletions
diff --git a/arch/powerpc/platforms/cell/spu_base.c b/arch/powerpc/platforms/cell/spu_base.c
index 75b5af0a7e21..5f399313b472 100644
--- a/arch/powerpc/platforms/cell/spu_base.c
+++ b/arch/powerpc/platforms/cell/spu_base.c
@@ -425,6 +425,25 @@ static void spu_init_channels(struct spu *spu)
425 } 425 }
426} 426}
427 427
428struct spu *spu_alloc_spu(struct spu *req_spu)
429{
430 struct spu *spu, *ret = NULL;
431
432 mutex_lock(&spu_mutex);
433 list_for_each_entry(spu, &cbe_spu_info[req_spu->node].free_spus, list) {
434 if (spu == req_spu) {
435 list_del_init(&spu->list);
436 pr_debug("Got SPU %d %d\n", spu->number, spu->node);
437 spu_init_channels(spu);
438 ret = spu;
439 break;
440 }
441 }
442 mutex_unlock(&spu_mutex);
443 return ret;
444}
445EXPORT_SYMBOL_GPL(spu_alloc_spu);
446
428struct spu *spu_alloc_node(int node) 447struct spu *spu_alloc_node(int node)
429{ 448{
430 struct spu *spu = NULL; 449 struct spu *spu = NULL;
diff --git a/arch/powerpc/platforms/cell/spufs/sched.c b/arch/powerpc/platforms/cell/spufs/sched.c
index a9569de4c141..49b8f6867a96 100644
--- a/arch/powerpc/platforms/cell/spufs/sched.c
+++ b/arch/powerpc/platforms/cell/spufs/sched.c
@@ -507,6 +507,10 @@ static struct spu *spu_get_idle(struct spu_context *ctx)
507 int node = cpu_to_node(raw_smp_processor_id()); 507 int node = cpu_to_node(raw_smp_processor_id());
508 int n; 508 int n;
509 509
510 spu = affinity_check(ctx);
511 if (spu)
512 return spu_alloc_spu(spu);
513
510 for (n = 0; n < MAX_NUMNODES; n++, node++) { 514 for (n = 0; n < MAX_NUMNODES; n++, node++) {
511 node = (node < MAX_NUMNODES) ? node : 0; 515 node = (node < MAX_NUMNODES) ? node : 0;
512 if (!node_allowed(ctx, node)) 516 if (!node_allowed(ctx, node))