3  *    Copyright (c) 1999 Grant Erickson <grant@lcse.umn.edu>
 
   5  *    Module name: ppc403_pic.c
 
   8  *      Interrupt controller driver for PowerPC 403-based processors.
 
  12  * The PowerPC 403 cores' Asynchronous Interrupt Controller (AIC) has
 
  13  * 32 possible interrupts, a majority of which are not implemented on
 
  14  * all cores. There are six configurable, external interrupt pins and
 
  15  * there are eight internal interrupts for the on-chip serial port
 
  16  * (SPU), DMA controller, and JTAG controller.
 
  20 #include <linux/init.h>
 
  21 #include <linux/sched.h>
 
  22 #include <linux/signal.h>
 
  23 #include <linux/stddef.h>
 
  25 #include <asm/processor.h>
 
  26 #include <asm/system.h>
 
  28 #include <asm/ppc4xx_pic.h>
 
  30 /* Function Prototypes */
 
  32 static void ppc403_aic_enable(unsigned int irq);
 
  33 static void ppc403_aic_disable(unsigned int irq);
 
  34 static void ppc403_aic_disable_and_ack(unsigned int irq);
 
  36 static struct hw_interrupt_type ppc403_aic = {
 
  37         .typename = "403GC AIC",
 
  38         .enable = ppc403_aic_enable,
 
  39         .disable = ppc403_aic_disable,
 
  40         .ack = ppc403_aic_disable_and_ack,
 
  44 ppc403_pic_get_irq(struct pt_regs *regs)
 
  50          * Only report the status of those interrupts that are actually
 
  54         bits = mfdcr(DCRN_EXISR) & mfdcr(DCRN_EXIER);
 
  57          * Walk through the interrupts from highest priority to lowest, and
 
  58          * report the first pending interrupt found.
 
  59          * We want PPC, not C bit numbering, so just subtract the ffs()
 
  64         if (irq == NR_AIC_IRQS)
 
  71 ppc403_aic_enable(unsigned int irq)
 
  78         ppc_cached_irq_mask[word] |= (1 << (31 - bit));
 
  79         mtdcr(DCRN_EXIER, ppc_cached_irq_mask[word]);
 
  83 ppc403_aic_disable(unsigned int irq)
 
  90         ppc_cached_irq_mask[word] &= ~(1 << (31 - bit));
 
  91         mtdcr(DCRN_EXIER, ppc_cached_irq_mask[word]);
 
  95 ppc403_aic_disable_and_ack(unsigned int irq)
 
 102         ppc_cached_irq_mask[word] &= ~(1 << (31 - bit));
 
 103         mtdcr(DCRN_EXIER, ppc_cached_irq_mask[word]);
 
 104         mtdcr(DCRN_EXISR, (1 << (31 - bit)));
 
 108 ppc4xx_pic_init(void)
 
 113          * Disable all external interrupts until they are
 
 114          * explicity requested.
 
 116         ppc_cached_irq_mask[0] = 0;
 
 118         mtdcr(DCRN_EXIER, ppc_cached_irq_mask[0]);
 
 120         ppc_md.get_irq = ppc403_pic_get_irq;
 
 122         for (i = 0; i < NR_IRQS; i++)
 
 123                 irq_desc[i].handler = &ppc403_aic;