aboutsummaryrefslogtreecommitdiffstats
path: root/arch/mips/sgi-ip32/ip32-irq.c
diff options
context:
space:
mode:
Diffstat (limited to 'arch/mips/sgi-ip32/ip32-irq.c')
-rw-r--r--arch/mips/sgi-ip32/ip32-irq.c63
1 files changed, 45 insertions, 18 deletions
diff --git a/arch/mips/sgi-ip32/ip32-irq.c b/arch/mips/sgi-ip32/ip32-irq.c
index 0d6b6663d5f6..0aefc5319a03 100644
--- a/arch/mips/sgi-ip32/ip32-irq.c
+++ b/arch/mips/sgi-ip32/ip32-irq.c
@@ -325,16 +325,11 @@ static void mask_and_ack_maceisa_irq(unsigned int irq)
325{ 325{
326 unsigned long mace_int; 326 unsigned long mace_int;
327 327
328 switch (irq) { 328 /* edge triggered */
329 case MACEISA_PARALLEL_IRQ: 329 mace_int = mace->perif.ctrl.istat;
330 case MACEISA_SERIAL1_TDMAPR_IRQ: 330 mace_int &= ~(1 << (irq - MACEISA_AUDIO_SW_IRQ));
331 case MACEISA_SERIAL2_TDMAPR_IRQ: 331 mace->perif.ctrl.istat = mace_int;
332 /* edge triggered */ 332
333 mace_int = mace->perif.ctrl.istat;
334 mace_int &= ~(1 << (irq - MACEISA_AUDIO_SW_IRQ));
335 mace->perif.ctrl.istat = mace_int;
336 break;
337 }
338 disable_maceisa_irq(irq); 333 disable_maceisa_irq(irq);
339} 334}
340 335
@@ -344,7 +339,16 @@ static void end_maceisa_irq(unsigned irq)
344 enable_maceisa_irq(irq); 339 enable_maceisa_irq(irq);
345} 340}
346 341
347static struct irq_chip ip32_maceisa_interrupt = { 342static struct irq_chip ip32_maceisa_level_interrupt = {
343 .name = "IP32 MACE ISA",
344 .ack = disable_maceisa_irq,
345 .mask = disable_maceisa_irq,
346 .mask_ack = disable_maceisa_irq,
347 .unmask = enable_maceisa_irq,
348 .end = end_maceisa_irq,
349};
350
351static struct irq_chip ip32_maceisa_edge_interrupt = {
348 .name = "IP32 MACE ISA", 352 .name = "IP32 MACE ISA",
349 .ack = mask_and_ack_maceisa_irq, 353 .ack = mask_and_ack_maceisa_irq,
350 .mask = disable_maceisa_irq, 354 .mask = disable_maceisa_irq,
@@ -500,27 +504,50 @@ void __init arch_init_irq(void)
500 for (irq = CRIME_IRQ_BASE; irq <= IP32_IRQ_MAX; irq++) { 504 for (irq = CRIME_IRQ_BASE; irq <= IP32_IRQ_MAX; irq++) {
501 switch (irq) { 505 switch (irq) {
502 case MACE_VID_IN1_IRQ ... MACE_PCI_BRIDGE_IRQ: 506 case MACE_VID_IN1_IRQ ... MACE_PCI_BRIDGE_IRQ:
503 set_irq_chip(irq, &ip32_mace_interrupt); 507 set_irq_chip_and_handler_name(irq,&ip32_mace_interrupt,
508 handle_level_irq, "level");
504 break; 509 break;
510
505 case MACEPCI_SCSI0_IRQ ... MACEPCI_SHARED2_IRQ: 511 case MACEPCI_SCSI0_IRQ ... MACEPCI_SHARED2_IRQ:
506 set_irq_chip(irq, &ip32_macepci_interrupt); 512 set_irq_chip_and_handler_name(irq,
513 &ip32_macepci_interrupt, handle_level_irq,
514 "level");
507 break; 515 break;
516
508 case CRIME_GBE0_IRQ ... CRIME_GBE3_IRQ: 517 case CRIME_GBE0_IRQ ... CRIME_GBE3_IRQ:
509 set_irq_chip(irq, &crime_edge_interrupt); 518 set_irq_chip_and_handler_name(irq,
519 &crime_edge_interrupt, handle_edge_irq, "edge");
510 break; 520 break;
511 case CRIME_CPUERR_IRQ: 521 case CRIME_CPUERR_IRQ:
512 case CRIME_MEMERR_IRQ: 522 case CRIME_MEMERR_IRQ:
513 set_irq_chip(irq, &crime_level_interrupt); 523 set_irq_chip_and_handler_name(irq,
524 &crime_level_interrupt, handle_level_irq,
525 "level");
514 break; 526 break;
527
515 case CRIME_RE_EMPTY_E_IRQ ... CRIME_RE_IDLE_E_IRQ: 528 case CRIME_RE_EMPTY_E_IRQ ... CRIME_RE_IDLE_E_IRQ:
516 case CRIME_SOFT0_IRQ ... CRIME_SOFT2_IRQ: 529 case CRIME_SOFT0_IRQ ... CRIME_SOFT2_IRQ:
517 set_irq_chip(irq, &crime_edge_interrupt); 530 set_irq_chip_and_handler_name(irq,
531 &crime_edge_interrupt, handle_edge_irq, "edge");
518 break; 532 break;
533
519 case CRIME_VICE_IRQ: 534 case CRIME_VICE_IRQ:
520 set_irq_chip(irq, &crime_edge_interrupt); 535 set_irq_chip_and_handler_name(irq,
536 &crime_edge_interrupt, handle_edge_irq, "edge");
537 break;
538
539 case MACEISA_PARALLEL_IRQ:
540 case MACEISA_SERIAL1_TDMAPR_IRQ:
541 case MACEISA_SERIAL2_TDMAPR_IRQ:
542 set_irq_chip_and_handler_name(irq,
543 &ip32_maceisa_edge_interrupt, handle_edge_irq,
544 "edge");
521 break; 545 break;
546
522 default: 547 default:
523 set_irq_chip(irq, &ip32_maceisa_interrupt); 548 set_irq_chip_and_handler_name(irq,
549 &ip32_maceisa_level_interrupt, handle_level_irq,
550 "level");
524 break; 551 break;
525 } 552 }
526 } 553 }