vserver 2.0 rc7
[linux-2.6.git] / include / asm-ppc / irq.h
index df5b763..06b86be 100644 (file)
@@ -6,10 +6,6 @@
 #include <asm/machdep.h>               /* ppc_md */
 #include <asm/atomic.h>
 
-extern void disable_irq(unsigned int);
-extern void disable_irq_nosync(unsigned int);
-extern void enable_irq(unsigned int);
-
 /*
  * These constants are used for passing information about interrupt
  * signal polarity and level/edge sensing to the low-level PIC chip
@@ -85,6 +81,10 @@ irq_canonicalize(int irq)
 
 #elif defined(CONFIG_8xx)
 
+/* Now include the board configuration specific associations.
+*/
+#include <asm/mpc8xx.h>
+
 /* The MPC8xx cores have 16 possible interrupts.  There are eight
  * possible level sensitive interrupts assigned and generated internally
  * from such devices as CPM, PCMCIA, RTC, PIT, TimeBase and Decrementer.
@@ -93,10 +93,22 @@ irq_canonicalize(int irq)
  *
  * On some implementations, there is also the possibility of an 8259
  * through the PCI and PCI-ISA bridges.
+ *
+ * We are "flattening" the interrupt vectors of the cascaded CPM
+ * and 8259 interrupt controllers so that we can uniquely identify
+ * any interrupt source with a single integer.
  */
 #define NR_SIU_INTS    16
+#define NR_CPM_INTS    32
+#ifndef NR_8259_INTS
+#define NR_8259_INTS 0
+#endif
+
+#define SIU_IRQ_OFFSET         0
+#define CPM_IRQ_OFFSET         (SIU_IRQ_OFFSET + NR_SIU_INTS)
+#define I8259_IRQ_OFFSET       (CPM_IRQ_OFFSET + NR_CPM_INTS)
 
-#define NR_IRQS        (NR_SIU_INTS + NR_8259_INTS)
+#define NR_IRQS        (NR_SIU_INTS + NR_CPM_INTS + NR_8259_INTS)
 
 /* These values must be zero-based and map 1:1 with the SIU configuration.
  * They are used throughout the 8xx I/O subsystem to generate
@@ -121,10 +133,6 @@ irq_canonicalize(int irq)
 #define        SIU_IRQ7        (14)
 #define        SIU_LEVEL7      (15)
 
-/* Now include the board configuration specific associations.
-*/
-#include <asm/mpc8xx.h>
-
 /* The internal interrupts we can configure as we see fit.
  * My personal preference is CPM at level 2, which puts it above the
  * MBX PCI/ISA/IDE interrupts.
@@ -153,6 +161,136 @@ static __inline__ int irq_canonicalize(int irq)
        return irq;
 }
 
+#elif defined(CONFIG_83xx)
+#include <asm/mpc83xx.h>
+
+static __inline__ int irq_canonicalize(int irq)
+{
+       return irq;
+}
+
+#define        NR_IRQS (NR_IPIC_INTS)
+
+#elif defined(CONFIG_85xx)
+/* Now include the board configuration specific associations.
+*/
+#include <asm/mpc85xx.h>
+
+/* The MPC8560 openpic has  32 internal interrupts and 12 external
+ * interrupts.
+ *
+ * We are "flattening" the interrupt vectors of the cascaded CPM
+ * so that we can uniquely identify any interrupt source with a
+ * single integer.
+ */
+#define NR_CPM_INTS    64
+#define NR_EPIC_INTS   44
+#ifndef NR_8259_INTS
+#define NR_8259_INTS   0
+#endif
+#define NUM_8259_INTERRUPTS NR_8259_INTS
+
+#ifndef CPM_IRQ_OFFSET
+#define CPM_IRQ_OFFSET 0
+#endif
+
+#define NR_IRQS        (NR_EPIC_INTS + NR_CPM_INTS + NR_8259_INTS)
+
+/* Internal IRQs on MPC85xx OpenPIC */
+
+#ifndef MPC85xx_OPENPIC_IRQ_OFFSET
+#ifdef CONFIG_CPM2
+#define MPC85xx_OPENPIC_IRQ_OFFSET     (CPM_IRQ_OFFSET + NR_CPM_INTS)
+#else
+#define MPC85xx_OPENPIC_IRQ_OFFSET     0
+#endif
+#endif
+
+/* Not all of these exist on all MPC85xx implementations */
+#define MPC85xx_IRQ_L2CACHE    ( 0 + MPC85xx_OPENPIC_IRQ_OFFSET)
+#define MPC85xx_IRQ_ECM                ( 1 + MPC85xx_OPENPIC_IRQ_OFFSET)
+#define MPC85xx_IRQ_DDR                ( 2 + MPC85xx_OPENPIC_IRQ_OFFSET)
+#define MPC85xx_IRQ_LBIU       ( 3 + MPC85xx_OPENPIC_IRQ_OFFSET)
+#define MPC85xx_IRQ_DMA0       ( 4 + MPC85xx_OPENPIC_IRQ_OFFSET)
+#define MPC85xx_IRQ_DMA1       ( 5 + MPC85xx_OPENPIC_IRQ_OFFSET)
+#define MPC85xx_IRQ_DMA2       ( 6 + MPC85xx_OPENPIC_IRQ_OFFSET)
+#define MPC85xx_IRQ_DMA3       ( 7 + MPC85xx_OPENPIC_IRQ_OFFSET)
+#define MPC85xx_IRQ_PCI1       ( 8 + MPC85xx_OPENPIC_IRQ_OFFSET)
+#define MPC85xx_IRQ_PCI2       ( 9 + MPC85xx_OPENPIC_IRQ_OFFSET)
+#define MPC85xx_IRQ_RIO_ERROR  ( 9 + MPC85xx_OPENPIC_IRQ_OFFSET)
+#define MPC85xx_IRQ_RIO_BELL   (10 + MPC85xx_OPENPIC_IRQ_OFFSET)
+#define MPC85xx_IRQ_RIO_TX     (11 + MPC85xx_OPENPIC_IRQ_OFFSET)
+#define MPC85xx_IRQ_RIO_RX     (12 + MPC85xx_OPENPIC_IRQ_OFFSET)
+#define MPC85xx_IRQ_TSEC1_TX   (13 + MPC85xx_OPENPIC_IRQ_OFFSET)
+#define MPC85xx_IRQ_TSEC1_RX   (14 + MPC85xx_OPENPIC_IRQ_OFFSET)
+#define MPC85xx_IRQ_TSEC1_ERROR        (18 + MPC85xx_OPENPIC_IRQ_OFFSET)
+#define MPC85xx_IRQ_TSEC2_TX   (19 + MPC85xx_OPENPIC_IRQ_OFFSET)
+#define MPC85xx_IRQ_TSEC2_RX   (20 + MPC85xx_OPENPIC_IRQ_OFFSET)
+#define MPC85xx_IRQ_TSEC2_ERROR        (24 + MPC85xx_OPENPIC_IRQ_OFFSET)
+#define MPC85xx_IRQ_FEC                (25 + MPC85xx_OPENPIC_IRQ_OFFSET)
+#define MPC85xx_IRQ_DUART      (26 + MPC85xx_OPENPIC_IRQ_OFFSET)
+#define MPC85xx_IRQ_IIC1       (27 + MPC85xx_OPENPIC_IRQ_OFFSET)
+#define MPC85xx_IRQ_PERFMON    (28 + MPC85xx_OPENPIC_IRQ_OFFSET)
+#define MPC85xx_IRQ_SEC2       (29 + MPC85xx_OPENPIC_IRQ_OFFSET)
+#define MPC85xx_IRQ_CPM                (30 + MPC85xx_OPENPIC_IRQ_OFFSET)
+
+/* The 12 external interrupt lines */
+#define MPC85xx_IRQ_EXT0        (32 + MPC85xx_OPENPIC_IRQ_OFFSET)
+#define MPC85xx_IRQ_EXT1        (33 + MPC85xx_OPENPIC_IRQ_OFFSET)
+#define MPC85xx_IRQ_EXT2        (34 + MPC85xx_OPENPIC_IRQ_OFFSET)
+#define MPC85xx_IRQ_EXT3        (35 + MPC85xx_OPENPIC_IRQ_OFFSET)
+#define MPC85xx_IRQ_EXT4        (36 + MPC85xx_OPENPIC_IRQ_OFFSET)
+#define MPC85xx_IRQ_EXT5        (37 + MPC85xx_OPENPIC_IRQ_OFFSET)
+#define MPC85xx_IRQ_EXT6        (38 + MPC85xx_OPENPIC_IRQ_OFFSET)
+#define MPC85xx_IRQ_EXT7        (39 + MPC85xx_OPENPIC_IRQ_OFFSET)
+#define MPC85xx_IRQ_EXT8        (40 + MPC85xx_OPENPIC_IRQ_OFFSET)
+#define MPC85xx_IRQ_EXT9        (41 + MPC85xx_OPENPIC_IRQ_OFFSET)
+#define MPC85xx_IRQ_EXT10       (42 + MPC85xx_OPENPIC_IRQ_OFFSET)
+#define MPC85xx_IRQ_EXT11       (43 + MPC85xx_OPENPIC_IRQ_OFFSET)
+
+/* CPM related interrupts */
+#define        SIU_INT_ERROR           ((uint)0x00+CPM_IRQ_OFFSET)
+#define        SIU_INT_I2C             ((uint)0x01+CPM_IRQ_OFFSET)
+#define        SIU_INT_SPI             ((uint)0x02+CPM_IRQ_OFFSET)
+#define        SIU_INT_RISC            ((uint)0x03+CPM_IRQ_OFFSET)
+#define        SIU_INT_SMC1            ((uint)0x04+CPM_IRQ_OFFSET)
+#define        SIU_INT_SMC2            ((uint)0x05+CPM_IRQ_OFFSET)
+#define        SIU_INT_USB             ((uint)0x0b+CPM_IRQ_OFFSET)
+#define        SIU_INT_TIMER1          ((uint)0x0c+CPM_IRQ_OFFSET)
+#define        SIU_INT_TIMER2          ((uint)0x0d+CPM_IRQ_OFFSET)
+#define        SIU_INT_TIMER3          ((uint)0x0e+CPM_IRQ_OFFSET)
+#define        SIU_INT_TIMER4          ((uint)0x0f+CPM_IRQ_OFFSET)
+#define        SIU_INT_FCC1            ((uint)0x20+CPM_IRQ_OFFSET)
+#define        SIU_INT_FCC2            ((uint)0x21+CPM_IRQ_OFFSET)
+#define        SIU_INT_FCC3            ((uint)0x22+CPM_IRQ_OFFSET)
+#define        SIU_INT_MCC1            ((uint)0x24+CPM_IRQ_OFFSET)
+#define        SIU_INT_MCC2            ((uint)0x25+CPM_IRQ_OFFSET)
+#define        SIU_INT_SCC1            ((uint)0x28+CPM_IRQ_OFFSET)
+#define        SIU_INT_SCC2            ((uint)0x29+CPM_IRQ_OFFSET)
+#define        SIU_INT_SCC3            ((uint)0x2a+CPM_IRQ_OFFSET)
+#define        SIU_INT_SCC4            ((uint)0x2b+CPM_IRQ_OFFSET)
+#define        SIU_INT_PC15            ((uint)0x30+CPM_IRQ_OFFSET)
+#define        SIU_INT_PC14            ((uint)0x31+CPM_IRQ_OFFSET)
+#define        SIU_INT_PC13            ((uint)0x32+CPM_IRQ_OFFSET)
+#define        SIU_INT_PC12            ((uint)0x33+CPM_IRQ_OFFSET)
+#define        SIU_INT_PC11            ((uint)0x34+CPM_IRQ_OFFSET)
+#define        SIU_INT_PC10            ((uint)0x35+CPM_IRQ_OFFSET)
+#define        SIU_INT_PC9             ((uint)0x36+CPM_IRQ_OFFSET)
+#define        SIU_INT_PC8             ((uint)0x37+CPM_IRQ_OFFSET)
+#define        SIU_INT_PC7             ((uint)0x38+CPM_IRQ_OFFSET)
+#define        SIU_INT_PC6             ((uint)0x39+CPM_IRQ_OFFSET)
+#define        SIU_INT_PC5             ((uint)0x3a+CPM_IRQ_OFFSET)
+#define        SIU_INT_PC4             ((uint)0x3b+CPM_IRQ_OFFSET)
+#define        SIU_INT_PC3             ((uint)0x3c+CPM_IRQ_OFFSET)
+#define        SIU_INT_PC2             ((uint)0x3d+CPM_IRQ_OFFSET)
+#define        SIU_INT_PC1             ((uint)0x3e+CPM_IRQ_OFFSET)
+#define        SIU_INT_PC0             ((uint)0x3f+CPM_IRQ_OFFSET)
+
+static __inline__ int irq_canonicalize(int irq)
+{
+       return irq;
+}
+
 #else /* CONFIG_40x + CONFIG_8xx */
 /*
  * this is the # irq's for all ppc arch's (pmac/chrp/prep)
@@ -175,19 +313,62 @@ static __inline__ int irq_canonicalize(int irq)
  * (Document errata updates have fixed this...make sure you have up to
  * date processor documentation -- Dan).
  */
-#define NR_SIU_INTS    64
 
-/* There are many more than these, we will add them as we need them.
-*/
-#define        SIU_INT_SMC1            ((uint)0x04)
-#define        SIU_INT_SMC2            ((uint)0x05)
-#define        SIU_INT_FCC1            ((uint)0x20)
-#define        SIU_INT_FCC2            ((uint)0x21)
-#define        SIU_INT_FCC3            ((uint)0x22)
-#define        SIU_INT_SCC1            ((uint)0x28)
-#define        SIU_INT_SCC2            ((uint)0x29)
-#define        SIU_INT_SCC3            ((uint)0x2a)
-#define        SIU_INT_SCC4            ((uint)0x2b)
+#ifndef CPM_IRQ_OFFSET
+#define CPM_IRQ_OFFSET 0
+#endif
+
+#define NR_CPM_INTS    64
+
+#define        SIU_INT_ERROR           ((uint)0x00 + CPM_IRQ_OFFSET)
+#define        SIU_INT_I2C             ((uint)0x01 + CPM_IRQ_OFFSET)
+#define        SIU_INT_SPI             ((uint)0x02 + CPM_IRQ_OFFSET)
+#define        SIU_INT_RISC            ((uint)0x03 + CPM_IRQ_OFFSET)
+#define        SIU_INT_SMC1            ((uint)0x04 + CPM_IRQ_OFFSET)
+#define        SIU_INT_SMC2            ((uint)0x05 + CPM_IRQ_OFFSET)
+#define        SIU_INT_IDMA1           ((uint)0x06 + CPM_IRQ_OFFSET)
+#define        SIU_INT_IDMA2           ((uint)0x07 + CPM_IRQ_OFFSET)
+#define        SIU_INT_IDMA3           ((uint)0x08 + CPM_IRQ_OFFSET)
+#define        SIU_INT_IDMA4           ((uint)0x09 + CPM_IRQ_OFFSET)
+#define        SIU_INT_SDMA            ((uint)0x0a + CPM_IRQ_OFFSET)
+#define        SIU_INT_TIMER1          ((uint)0x0c + CPM_IRQ_OFFSET)
+#define        SIU_INT_TIMER2          ((uint)0x0d + CPM_IRQ_OFFSET)
+#define        SIU_INT_TIMER3          ((uint)0x0e + CPM_IRQ_OFFSET)
+#define        SIU_INT_TIMER4          ((uint)0x0f + CPM_IRQ_OFFSET)
+#define        SIU_INT_TMCNT           ((uint)0x10 + CPM_IRQ_OFFSET)
+#define        SIU_INT_PIT             ((uint)0x11 + CPM_IRQ_OFFSET)
+#define        SIU_INT_IRQ1            ((uint)0x13 + CPM_IRQ_OFFSET)
+#define        SIU_INT_IRQ2            ((uint)0x14 + CPM_IRQ_OFFSET)
+#define        SIU_INT_IRQ3            ((uint)0x15 + CPM_IRQ_OFFSET)
+#define        SIU_INT_IRQ4            ((uint)0x16 + CPM_IRQ_OFFSET)
+#define        SIU_INT_IRQ5            ((uint)0x17 + CPM_IRQ_OFFSET)
+#define        SIU_INT_IRQ6            ((uint)0x18 + CPM_IRQ_OFFSET)
+#define        SIU_INT_IRQ7            ((uint)0x19 + CPM_IRQ_OFFSET)
+#define        SIU_INT_FCC1            ((uint)0x20 + CPM_IRQ_OFFSET)
+#define        SIU_INT_FCC2            ((uint)0x21 + CPM_IRQ_OFFSET)
+#define        SIU_INT_FCC3            ((uint)0x22 + CPM_IRQ_OFFSET)
+#define        SIU_INT_MCC1            ((uint)0x24 + CPM_IRQ_OFFSET)
+#define        SIU_INT_MCC2            ((uint)0x25 + CPM_IRQ_OFFSET)
+#define        SIU_INT_SCC1            ((uint)0x28 + CPM_IRQ_OFFSET)
+#define        SIU_INT_SCC2            ((uint)0x29 + CPM_IRQ_OFFSET)
+#define        SIU_INT_SCC3            ((uint)0x2a + CPM_IRQ_OFFSET)
+#define        SIU_INT_SCC4            ((uint)0x2b + CPM_IRQ_OFFSET)
+#define        SIU_INT_PC15            ((uint)0x30 + CPM_IRQ_OFFSET)
+#define        SIU_INT_PC14            ((uint)0x31 + CPM_IRQ_OFFSET)
+#define        SIU_INT_PC13            ((uint)0x32 + CPM_IRQ_OFFSET)
+#define        SIU_INT_PC12            ((uint)0x33 + CPM_IRQ_OFFSET)
+#define        SIU_INT_PC11            ((uint)0x34 + CPM_IRQ_OFFSET)
+#define        SIU_INT_PC10            ((uint)0x35 + CPM_IRQ_OFFSET)
+#define        SIU_INT_PC9             ((uint)0x36 + CPM_IRQ_OFFSET)
+#define        SIU_INT_PC8             ((uint)0x37 + CPM_IRQ_OFFSET)
+#define        SIU_INT_PC7             ((uint)0x38 + CPM_IRQ_OFFSET)
+#define        SIU_INT_PC6             ((uint)0x39 + CPM_IRQ_OFFSET)
+#define        SIU_INT_PC5             ((uint)0x3a + CPM_IRQ_OFFSET)
+#define        SIU_INT_PC4             ((uint)0x3b + CPM_IRQ_OFFSET)
+#define        SIU_INT_PC3             ((uint)0x3c + CPM_IRQ_OFFSET)
+#define        SIU_INT_PC2             ((uint)0x3d + CPM_IRQ_OFFSET)
+#define        SIU_INT_PC1             ((uint)0x3e + CPM_IRQ_OFFSET)
+#define        SIU_INT_PC0             ((uint)0x3f + CPM_IRQ_OFFSET)
 
 #endif /* CONFIG_8260 */