diff options
-rw-r--r-- | arch/powerpc/platforms/cell/spu_base.c | 42 | ||||
-rw-r--r-- | arch/powerpc/platforms/cell/spufs/backing_ops.c | 17 | ||||
-rw-r--r-- | arch/powerpc/platforms/cell/spufs/hw_ops.c | 14 | ||||
-rw-r--r-- | include/asm-powerpc/spu.h | 14 |
4 files changed, 54 insertions, 33 deletions
diff --git a/arch/powerpc/platforms/cell/spu_base.c b/arch/powerpc/platforms/cell/spu_base.c index f73263ba9841..a560277b3ad7 100644 --- a/arch/powerpc/platforms/cell/spu_base.c +++ b/arch/powerpc/platforms/cell/spu_base.c | |||
@@ -360,18 +360,18 @@ spu_irq_class_0_bottom(struct spu *spu) | |||
360 | stat = spu->class_0_pending; | 360 | stat = spu->class_0_pending; |
361 | spu->class_0_pending = 0; | 361 | spu->class_0_pending = 0; |
362 | 362 | ||
363 | if (stat & 1) /* invalid DMA alignment */ | 363 | if (stat & CLASS0_DMA_ALIGNMENT_INTR) |
364 | __spu_trap_dma_align(spu); | 364 | __spu_trap_dma_align(spu); |
365 | 365 | ||
366 | if (stat & 2) /* invalid MFC DMA */ | 366 | if (stat & CLASS0_INVALID_DMA_COMMAND_INTR) |
367 | __spu_trap_invalid_dma(spu); | 367 | __spu_trap_invalid_dma(spu); |
368 | 368 | ||
369 | if (stat & 4) /* error on SPU */ | 369 | if (stat & CLASS0_SPU_ERROR_INTR) |
370 | __spu_trap_error(spu); | 370 | __spu_trap_error(spu); |
371 | 371 | ||
372 | spin_unlock_irqrestore(&spu->register_lock, flags); | 372 | spin_unlock_irqrestore(&spu->register_lock, flags); |
373 | 373 | ||
374 | return (stat & 0x7) ? -EIO : 0; | 374 | return (stat & CLASS0_INTR_MASK) ? -EIO : 0; |
375 | } | 375 | } |
376 | EXPORT_SYMBOL_GPL(spu_irq_class_0_bottom); | 376 | EXPORT_SYMBOL_GPL(spu_irq_class_0_bottom); |
377 | 377 | ||
@@ -389,24 +389,23 @@ spu_irq_class_1(int irq, void *data) | |||
389 | stat = spu_int_stat_get(spu, 1) & mask; | 389 | stat = spu_int_stat_get(spu, 1) & mask; |
390 | dar = spu_mfc_dar_get(spu); | 390 | dar = spu_mfc_dar_get(spu); |
391 | dsisr = spu_mfc_dsisr_get(spu); | 391 | dsisr = spu_mfc_dsisr_get(spu); |
392 | if (stat & 2) /* mapping fault */ | 392 | if (stat & CLASS1_STORAGE_FAULT_INTR) |
393 | spu_mfc_dsisr_set(spu, 0ul); | 393 | spu_mfc_dsisr_set(spu, 0ul); |
394 | spu_int_stat_clear(spu, 1, stat); | 394 | spu_int_stat_clear(spu, 1, stat); |
395 | spin_unlock(&spu->register_lock); | 395 | spin_unlock(&spu->register_lock); |
396 | pr_debug("%s: %lx %lx %lx %lx\n", __FUNCTION__, mask, stat, | 396 | pr_debug("%s: %lx %lx %lx %lx\n", __FUNCTION__, mask, stat, |
397 | dar, dsisr); | 397 | dar, dsisr); |
398 | 398 | ||
399 | if (stat & 1) /* segment fault */ | 399 | if (stat & CLASS1_SEGMENT_FAULT_INTR) |
400 | __spu_trap_data_seg(spu, dar); | 400 | __spu_trap_data_seg(spu, dar); |
401 | 401 | ||
402 | if (stat & 2) { /* mapping fault */ | 402 | if (stat & CLASS1_STORAGE_FAULT_INTR) |
403 | __spu_trap_data_map(spu, dar, dsisr); | 403 | __spu_trap_data_map(spu, dar, dsisr); |
404 | } | ||
405 | 404 | ||
406 | if (stat & 4) /* ls compare & suspend on get */ | 405 | if (stat & CLASS1_LS_COMPARE_SUSPEND_ON_GET_INTR) |
407 | ; | 406 | ; |
408 | 407 | ||
409 | if (stat & 8) /* ls compare & suspend on put */ | 408 | if (stat & CLASS1_LS_COMPARE_SUSPEND_ON_PUT_INTR) |
410 | ; | 409 | ; |
411 | 410 | ||
412 | return stat ? IRQ_HANDLED : IRQ_NONE; | 411 | return stat ? IRQ_HANDLED : IRQ_NONE; |
@@ -418,6 +417,8 @@ spu_irq_class_2(int irq, void *data) | |||
418 | struct spu *spu; | 417 | struct spu *spu; |
419 | unsigned long stat; | 418 | unsigned long stat; |
420 | unsigned long mask; | 419 | unsigned long mask; |
420 | const int mailbox_intrs = | ||
421 | CLASS2_MAILBOX_THRESHOLD_INTR | CLASS2_MAILBOX_INTR; | ||
421 | 422 | ||
422 | spu = data; | 423 | spu = data; |
423 | spin_lock(&spu->register_lock); | 424 | spin_lock(&spu->register_lock); |
@@ -425,31 +426,30 @@ spu_irq_class_2(int irq, void *data) | |||
425 | mask = spu_int_mask_get(spu, 2); | 426 | mask = spu_int_mask_get(spu, 2); |
426 | /* ignore interrupts we're not waiting for */ | 427 | /* ignore interrupts we're not waiting for */ |
427 | stat &= mask; | 428 | stat &= mask; |
428 | /* | 429 | |
429 | * mailbox interrupts (0x1 and 0x10) are level triggered. | 430 | /* mailbox interrupts are level triggered. mask them now before |
430 | * mask them now before acknowledging. | 431 | * acknowledging */ |
431 | */ | 432 | if (stat & mailbox_intrs) |
432 | if (stat & 0x11) | 433 | spu_int_mask_and(spu, 2, ~(stat & mailbox_intrs)); |
433 | spu_int_mask_and(spu, 2, ~(stat & 0x11)); | ||
434 | /* acknowledge all interrupts before the callbacks */ | 434 | /* acknowledge all interrupts before the callbacks */ |
435 | spu_int_stat_clear(spu, 2, stat); | 435 | spu_int_stat_clear(spu, 2, stat); |
436 | spin_unlock(&spu->register_lock); | 436 | spin_unlock(&spu->register_lock); |
437 | 437 | ||
438 | pr_debug("class 2 interrupt %d, %lx, %lx\n", irq, stat, mask); | 438 | pr_debug("class 2 interrupt %d, %lx, %lx\n", irq, stat, mask); |
439 | 439 | ||
440 | if (stat & 1) /* PPC core mailbox */ | 440 | if (stat & CLASS2_MAILBOX_INTR) |
441 | spu->ibox_callback(spu); | 441 | spu->ibox_callback(spu); |
442 | 442 | ||
443 | if (stat & 2) /* SPU stop-and-signal */ | 443 | if (stat & CLASS2_SPU_STOP_INTR) |
444 | spu->stop_callback(spu); | 444 | spu->stop_callback(spu); |
445 | 445 | ||
446 | if (stat & 4) /* SPU halted */ | 446 | if (stat & CLASS2_SPU_HALT_INTR) |
447 | spu->stop_callback(spu); | 447 | spu->stop_callback(spu); |
448 | 448 | ||
449 | if (stat & 8) /* DMA tag group complete */ | 449 | if (stat & CLASS2_SPU_DMA_TAG_GROUP_COMPLETE_INTR) |
450 | spu->mfc_callback(spu); | 450 | spu->mfc_callback(spu); |
451 | 451 | ||
452 | if (stat & 0x10) /* SPU mailbox threshold */ | 452 | if (stat & CLASS2_MAILBOX_THRESHOLD_INTR) |
453 | spu->wbox_callback(spu); | 453 | spu->wbox_callback(spu); |
454 | 454 | ||
455 | spu->stats.class2_intr++; | 455 | spu->stats.class2_intr++; |
diff --git a/arch/powerpc/platforms/cell/spufs/backing_ops.c b/arch/powerpc/platforms/cell/spufs/backing_ops.c index 97b2d5e587cc..d4495531e5b2 100644 --- a/arch/powerpc/platforms/cell/spufs/backing_ops.c +++ b/arch/powerpc/platforms/cell/spufs/backing_ops.c | |||
@@ -106,16 +106,20 @@ static unsigned int spu_backing_mbox_stat_poll(struct spu_context *ctx, | |||
106 | if (stat & 0xff0000) | 106 | if (stat & 0xff0000) |
107 | ret |= POLLIN | POLLRDNORM; | 107 | ret |= POLLIN | POLLRDNORM; |
108 | else { | 108 | else { |
109 | ctx->csa.priv1.int_stat_class2_RW &= ~0x1; | 109 | ctx->csa.priv1.int_stat_class2_RW &= |
110 | ctx->csa.priv1.int_mask_class2_RW |= 0x1; | 110 | ~CLASS2_MAILBOX_INTR; |
111 | ctx->csa.priv1.int_mask_class2_RW |= | ||
112 | CLASS2_ENABLE_MAILBOX_INTR; | ||
111 | } | 113 | } |
112 | } | 114 | } |
113 | if (events & (POLLOUT | POLLWRNORM)) { | 115 | if (events & (POLLOUT | POLLWRNORM)) { |
114 | if (stat & 0x00ff00) | 116 | if (stat & 0x00ff00) |
115 | ret = POLLOUT | POLLWRNORM; | 117 | ret = POLLOUT | POLLWRNORM; |
116 | else { | 118 | else { |
117 | ctx->csa.priv1.int_stat_class2_RW &= ~0x10; | 119 | ctx->csa.priv1.int_stat_class2_RW &= |
118 | ctx->csa.priv1.int_mask_class2_RW |= 0x10; | 120 | ~CLASS2_MAILBOX_THRESHOLD_INTR; |
121 | ctx->csa.priv1.int_mask_class2_RW |= | ||
122 | CLASS2_ENABLE_MAILBOX_THRESHOLD_INTR; | ||
119 | } | 123 | } |
120 | } | 124 | } |
121 | spin_unlock_irq(&ctx->csa.register_lock); | 125 | spin_unlock_irq(&ctx->csa.register_lock); |
@@ -139,7 +143,7 @@ static int spu_backing_ibox_read(struct spu_context *ctx, u32 * data) | |||
139 | ret = 4; | 143 | ret = 4; |
140 | } else { | 144 | } else { |
141 | /* make sure we get woken up by the interrupt */ | 145 | /* make sure we get woken up by the interrupt */ |
142 | ctx->csa.priv1.int_mask_class2_RW |= 0x1UL; | 146 | ctx->csa.priv1.int_mask_class2_RW |= CLASS2_ENABLE_MAILBOX_INTR; |
143 | ret = 0; | 147 | ret = 0; |
144 | } | 148 | } |
145 | spin_unlock(&ctx->csa.register_lock); | 149 | spin_unlock(&ctx->csa.register_lock); |
@@ -169,7 +173,8 @@ static int spu_backing_wbox_write(struct spu_context *ctx, u32 data) | |||
169 | } else { | 173 | } else { |
170 | /* make sure we get woken up by the interrupt when space | 174 | /* make sure we get woken up by the interrupt when space |
171 | becomes available */ | 175 | becomes available */ |
172 | ctx->csa.priv1.int_mask_class2_RW |= 0x10; | 176 | ctx->csa.priv1.int_mask_class2_RW |= |
177 | CLASS2_ENABLE_MAILBOX_THRESHOLD_INTR; | ||
173 | ret = 0; | 178 | ret = 0; |
174 | } | 179 | } |
175 | spin_unlock(&ctx->csa.register_lock); | 180 | spin_unlock(&ctx->csa.register_lock); |
diff --git a/arch/powerpc/platforms/cell/spufs/hw_ops.c b/arch/powerpc/platforms/cell/spufs/hw_ops.c index a7767e3b0853..64f8540b832c 100644 --- a/arch/powerpc/platforms/cell/spufs/hw_ops.c +++ b/arch/powerpc/platforms/cell/spufs/hw_ops.c | |||
@@ -76,16 +76,18 @@ static unsigned int spu_hw_mbox_stat_poll(struct spu_context *ctx, | |||
76 | if (stat & 0xff0000) | 76 | if (stat & 0xff0000) |
77 | ret |= POLLIN | POLLRDNORM; | 77 | ret |= POLLIN | POLLRDNORM; |
78 | else { | 78 | else { |
79 | spu_int_stat_clear(spu, 2, 0x1); | 79 | spu_int_stat_clear(spu, 2, CLASS2_MAILBOX_INTR); |
80 | spu_int_mask_or(spu, 2, 0x1); | 80 | spu_int_mask_or(spu, 2, CLASS2_ENABLE_MAILBOX_INTR); |
81 | } | 81 | } |
82 | } | 82 | } |
83 | if (events & (POLLOUT | POLLWRNORM)) { | 83 | if (events & (POLLOUT | POLLWRNORM)) { |
84 | if (stat & 0x00ff00) | 84 | if (stat & 0x00ff00) |
85 | ret = POLLOUT | POLLWRNORM; | 85 | ret = POLLOUT | POLLWRNORM; |
86 | else { | 86 | else { |
87 | spu_int_stat_clear(spu, 2, 0x10); | 87 | spu_int_stat_clear(spu, 2, |
88 | spu_int_mask_or(spu, 2, 0x10); | 88 | CLASS2_MAILBOX_THRESHOLD_INTR); |
89 | spu_int_mask_or(spu, 2, | ||
90 | CLASS2_ENABLE_MAILBOX_THRESHOLD_INTR); | ||
89 | } | 91 | } |
90 | } | 92 | } |
91 | spin_unlock_irq(&spu->register_lock); | 93 | spin_unlock_irq(&spu->register_lock); |
@@ -106,7 +108,7 @@ static int spu_hw_ibox_read(struct spu_context *ctx, u32 * data) | |||
106 | ret = 4; | 108 | ret = 4; |
107 | } else { | 109 | } else { |
108 | /* make sure we get woken up by the interrupt */ | 110 | /* make sure we get woken up by the interrupt */ |
109 | spu_int_mask_or(spu, 2, 0x1); | 111 | spu_int_mask_or(spu, 2, CLASS2_ENABLE_MAILBOX_INTR); |
110 | ret = 0; | 112 | ret = 0; |
111 | } | 113 | } |
112 | spin_unlock_irq(&spu->register_lock); | 114 | spin_unlock_irq(&spu->register_lock); |
@@ -127,7 +129,7 @@ static int spu_hw_wbox_write(struct spu_context *ctx, u32 data) | |||
127 | } else { | 129 | } else { |
128 | /* make sure we get woken up by the interrupt when space | 130 | /* make sure we get woken up by the interrupt when space |
129 | becomes available */ | 131 | becomes available */ |
130 | spu_int_mask_or(spu, 2, 0x10); | 132 | spu_int_mask_or(spu, 2, CLASS2_ENABLE_MAILBOX_THRESHOLD_INTR); |
131 | ret = 0; | 133 | ret = 0; |
132 | } | 134 | } |
133 | spin_unlock_irq(&spu->register_lock); | 135 | spin_unlock_irq(&spu->register_lock); |
diff --git a/include/asm-powerpc/spu.h b/include/asm-powerpc/spu.h index 543c83c2dc62..816e3dc1f66f 100644 --- a/include/asm-powerpc/spu.h +++ b/include/asm-powerpc/spu.h | |||
@@ -527,8 +527,22 @@ struct spu_priv1 { | |||
527 | #define CLASS2_ENABLE_SPU_STOP_INTR 0x2L | 527 | #define CLASS2_ENABLE_SPU_STOP_INTR 0x2L |
528 | #define CLASS2_ENABLE_SPU_HALT_INTR 0x4L | 528 | #define CLASS2_ENABLE_SPU_HALT_INTR 0x4L |
529 | #define CLASS2_ENABLE_SPU_DMA_TAG_GROUP_COMPLETE_INTR 0x8L | 529 | #define CLASS2_ENABLE_SPU_DMA_TAG_GROUP_COMPLETE_INTR 0x8L |
530 | #define CLASS2_ENABLE_MAILBOX_THRESHOLD_INTR 0x10L | ||
530 | u8 pad_0x118_0x140[0x28]; /* 0x118 */ | 531 | u8 pad_0x118_0x140[0x28]; /* 0x118 */ |
531 | u64 int_stat_RW[3]; /* 0x140 */ | 532 | u64 int_stat_RW[3]; /* 0x140 */ |
533 | #define CLASS0_DMA_ALIGNMENT_INTR 0x1L | ||
534 | #define CLASS0_INVALID_DMA_COMMAND_INTR 0x2L | ||
535 | #define CLASS0_SPU_ERROR_INTR 0x4L | ||
536 | #define CLASS0_INTR_MASK 0x7L | ||
537 | #define CLASS1_SEGMENT_FAULT_INTR 0x1L | ||
538 | #define CLASS1_STORAGE_FAULT_INTR 0x2L | ||
539 | #define CLASS1_LS_COMPARE_SUSPEND_ON_GET_INTR 0x4L | ||
540 | #define CLASS1_LS_COMPARE_SUSPEND_ON_PUT_INTR 0x8L | ||
541 | #define CLASS2_MAILBOX_INTR 0x1L | ||
542 | #define CLASS2_SPU_STOP_INTR 0x2L | ||
543 | #define CLASS2_SPU_HALT_INTR 0x4L | ||
544 | #define CLASS2_SPU_DMA_TAG_GROUP_COMPLETE_INTR 0x8L | ||
545 | #define CLASS2_MAILBOX_THRESHOLD_INTR 0x10L | ||
532 | u8 pad_0x158_0x180[0x28]; /* 0x158 */ | 546 | u8 pad_0x158_0x180[0x28]; /* 0x158 */ |
533 | u64 int_route_RW; /* 0x180 */ | 547 | u64 int_route_RW; /* 0x180 */ |
534 | 548 | ||