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>
 
  29 #include <asm/machdep.h>
 
  31 /* Function Prototypes */
 
  33 static void ppc403_aic_enable(unsigned int irq);
 
  34 static void ppc403_aic_disable(unsigned int irq);
 
  35 static void ppc403_aic_disable_and_ack(unsigned int irq);
 
  37 static struct hw_interrupt_type ppc403_aic = {
 
  38         .typename = "403GC AIC",
 
  39         .enable = ppc403_aic_enable,
 
  40         .disable = ppc403_aic_disable,
 
  41         .ack = ppc403_aic_disable_and_ack,
 
  45 ppc403_pic_get_irq(struct pt_regs *regs)
 
  51          * Only report the status of those interrupts that are actually
 
  55         bits = mfdcr(DCRN_EXISR) & mfdcr(DCRN_EXIER);
 
  58          * Walk through the interrupts from highest priority to lowest, and
 
  59          * report the first pending interrupt found.
 
  60          * We want PPC, not C bit numbering, so just subtract the ffs()
 
  65         if (irq == NR_AIC_IRQS)
 
  72 ppc403_aic_enable(unsigned int irq)
 
  79         ppc_cached_irq_mask[word] |= (1 << (31 - bit));
 
  80         mtdcr(DCRN_EXIER, ppc_cached_irq_mask[word]);
 
  84 ppc403_aic_disable(unsigned int irq)
 
  91         ppc_cached_irq_mask[word] &= ~(1 << (31 - bit));
 
  92         mtdcr(DCRN_EXIER, ppc_cached_irq_mask[word]);
 
  96 ppc403_aic_disable_and_ack(unsigned int irq)
 
 103         ppc_cached_irq_mask[word] &= ~(1 << (31 - bit));
 
 104         mtdcr(DCRN_EXIER, ppc_cached_irq_mask[word]);
 
 105         mtdcr(DCRN_EXISR, (1 << (31 - bit)));
 
 109 ppc4xx_pic_init(void)
 
 114          * Disable all external interrupts until they are
 
 115          * explicity requested.
 
 117         ppc_cached_irq_mask[0] = 0;
 
 119         mtdcr(DCRN_EXIER, ppc_cached_irq_mask[0]);
 
 121         ppc_md.get_irq = ppc403_pic_get_irq;
 
 123         for (i = 0; i < NR_IRQS; i++)
 
 124                 irq_desc[i].handler = &ppc403_aic;