irqs.h
上传用户:szlgq88
上传日期:2009-04-28
资源大小:48287k
文件大小:6k
源码类别:

嵌入式Linux

开发平台:

Unix_Linux

  1. /*
  2.  * linux/include/asm-arm/arch-ixp2000/irqs.h
  3.  *
  4.  * Original Author: Naeem Afzal <naeem.m.afzal@intel.com>
  5.  * Maintainer: Deepak Saxena <dsaxena@plexity.net>
  6.  *
  7.  * Copyright (C) 2002 Intel Corp.
  8.  * Copyright (C) 2003-2004 MontaVista Software, Inc.
  9.  * 
  10.  * This program is free software; you can redistribute it and/or modify
  11.  * it under the terms of the GNU General Public License version 2 as
  12.  * published by the Free Software Foundation.
  13.  */
  14. #ifndef _IRQS_H
  15. #define _IRQS_H
  16. /*
  17.  * Do NOT add #ifdef MACHINE_FOO in here.
  18.  * Simpy add your machine IRQs here and increase NR_IRQS if needed to
  19.  * hold your machine's IRQ table.
  20.  */
  21. /*
  22.  * Some interrupt numbers go unused b/c the IRQ mask/ummask/status
  23.  * register has those bit reserved. We just mark those interrupts
  24.  * as invalid and this allows us to do mask/unmask with a single
  25.  * shift operation instead of having to map the IRQ number to
  26.  * a HW IRQ number.
  27.  */
  28. #define IRQ_IXP2000_SOFT_INT 0 /* soft interrupt */
  29. #define IRQ_IXP2000_ERRSUM 1 /* OR of all bits in ErrorStatus reg*/
  30. #define IRQ_IXP2000_UART 2
  31. #define IRQ_IXP2000_GPIO 3
  32. #define IRQ_IXP2000_TIMER1      4
  33. #define IRQ_IXP2000_TIMER2      5
  34. #define IRQ_IXP2000_TIMER3      6
  35. #define IRQ_IXP2000_TIMER4      7
  36. #define IRQ_IXP2000_PMU         8               
  37. #define IRQ_IXP2000_SPF         9  /* Slow port framer IRQ */
  38. #define IRQ_IXP2000_DMA1       10
  39. #define IRQ_IXP2000_DMA2       11
  40. #define IRQ_IXP2000_DMA3       12
  41. #define IRQ_IXP2000_PCI_DOORBELL 13
  42. #define IRQ_IXP2000_ME_ATTN        14 
  43. #define IRQ_IXP2000_PCI    15 /* PCI INTA or INTB */
  44. #define IRQ_IXP2000_THDA0    16 /* thread 0-31A */
  45. #define IRQ_IXP2000_THDA1   17 /* thread 32-63A, IXP2800 only */
  46. #define IRQ_IXP2000_THDA2 18 /* thread 64-95A */
  47. #define IRQ_IXP2000_THDA3  19 /* thread 96-127A, IXP2800 only */
  48. #define IRQ_IXP2000_THDB0 24 /* thread 0-31B */
  49. #define IRQ_IXP2000_THDB1 25 /* thread 32-63B, IXP2800 only */
  50. #define IRQ_IXP2000_THDB2 26 /* thread 64-95B */
  51. #define IRQ_IXP2000_THDB3 27 /* thread 96-127B, IXP2800 only */
  52. /* define generic GPIOs */
  53. #define IRQ_IXP2000_GPIO0 32
  54. #define IRQ_IXP2000_GPIO1 33
  55. #define IRQ_IXP2000_GPIO2 34
  56. #define IRQ_IXP2000_GPIO3 35
  57. #define IRQ_IXP2000_GPIO4 36
  58. #define IRQ_IXP2000_GPIO5 37
  59. #define IRQ_IXP2000_GPIO6 38
  60. #define IRQ_IXP2000_GPIO7 39
  61. /* split off the 2 PCI sources */
  62. #define IRQ_IXP2000_PCIA 40
  63. #define IRQ_IXP2000_PCIB 41
  64. #define NR_IXP2000_IRQS                 42
  65. #define IXP2000_BOARD_IRQ(x) (NR_IXP2000_IRQS + (x))
  66. #define IXP2000_BOARD_IRQ_MASK(irq) (1 << (irq - NR_IXP2000_IRQS))
  67. /*
  68.  * This allows for all the on-chip sources plus up to 32 CPLD based
  69.  * IRQs. Should be more than enough.
  70.  */
  71. #define IXP2000_BOARD_IRQS 32
  72. #define NR_IRQS (NR_IXP2000_IRQS + IXP2000_BOARD_IRQS)
  73. /* 
  74.  * IXDP2400 specific IRQs
  75.  */
  76. #define IRQ_IXDP2400_INGRESS_NPU IXP2000_BOARD_IRQ(0) 
  77. #define IRQ_IXDP2400_ENET IXP2000_BOARD_IRQ(1) 
  78. #define IRQ_IXDP2400_MEDIA_PCI IXP2000_BOARD_IRQ(2) 
  79. #define IRQ_IXDP2400_MEDIA_SP IXP2000_BOARD_IRQ(3) 
  80. #define IRQ_IXDP2400_SF_PCI IXP2000_BOARD_IRQ(4) 
  81. #define IRQ_IXDP2400_SF_SP IXP2000_BOARD_IRQ(5) 
  82. #define IRQ_IXDP2400_PMC IXP2000_BOARD_IRQ(6) 
  83. #define IRQ_IXDP2400_TVM IXP2000_BOARD_IRQ(7) 
  84. #define NR_IXDP2400_IRQS ((IRQ_IXDP2400_TVM)+1)  
  85. #define IXDP2400_NR_IRQS NR_IXDP2400_IRQS - NR_IXP2000_IRQS
  86. /* IXDP2800 specific IRQs */
  87. #define IRQ_IXDP2800_EGRESS_ENET IXP2000_BOARD_IRQ(0)
  88. #define IRQ_IXDP2800_INGRESS_NPU IXP2000_BOARD_IRQ(1)
  89. #define IRQ_IXDP2800_PMC IXP2000_BOARD_IRQ(2)
  90. #define IRQ_IXDP2800_FABRIC_PCI IXP2000_BOARD_IRQ(3)
  91. #define IRQ_IXDP2800_FABRIC IXP2000_BOARD_IRQ(4)
  92. #define IRQ_IXDP2800_MEDIA IXP2000_BOARD_IRQ(5)
  93. #define NR_IXDP2800_IRQS ((IRQ_IXDP2800_MEDIA)+1)
  94. #define IXDP2800_NR_IRQS NR_IXDP2800_IRQS - NR_IXP2000_IRQS
  95. /* 
  96.  * IRQs on both IXDP2x01 boards
  97.  */
  98. #define IRQ_IXDP2X01_SPCI_DB_0 IXP2000_BOARD_IRQ(2)
  99. #define IRQ_IXDP2X01_SPCI_DB_1 IXP2000_BOARD_IRQ(3)
  100. #define IRQ_IXDP2X01_SPCI_PMC_INTA IXP2000_BOARD_IRQ(4)
  101. #define IRQ_IXDP2X01_SPCI_PMC_INTB IXP2000_BOARD_IRQ(5)
  102. #define IRQ_IXDP2X01_SPCI_PMC_INTC IXP2000_BOARD_IRQ(6)
  103. #define IRQ_IXDP2X01_SPCI_PMC_INTD IXP2000_BOARD_IRQ(7)
  104. #define IRQ_IXDP2X01_SPCI_FIC_INT IXP2000_BOARD_IRQ(8)
  105. #define IRQ_IXDP2X01_IPMI_FROM IXP2000_BOARD_IRQ(16)
  106. #define IRQ_IXDP2X01_125US IXP2000_BOARD_IRQ(17)
  107. #define IRQ_IXDP2X01_DB_0_ADD IXP2000_BOARD_IRQ(18)
  108. #define IRQ_IXDP2X01_DB_1_ADD IXP2000_BOARD_IRQ(19)
  109. #define IRQ_IXDP2X01_UART1 IXP2000_BOARD_IRQ(21)
  110. #define IRQ_IXDP2X01_UART2 IXP2000_BOARD_IRQ(22)
  111. #define IRQ_IXDP2X01_FIC_ADD_INT IXP2000_BOARD_IRQ(24)
  112. #define IRQ_IXDP2X01_CS8900 IXP2000_BOARD_IRQ(25)
  113. #define IRQ_IXDP2X01_BBSRAM IXP2000_BOARD_IRQ(26)
  114. #define IXDP2X01_VALID_IRQ_MASK ( 
  115. IXP2000_BOARD_IRQ_MASK(IRQ_IXDP2X01_SPCI_DB_0) | 
  116. IXP2000_BOARD_IRQ_MASK(IRQ_IXDP2X01_SPCI_DB_1) | 
  117. IXP2000_BOARD_IRQ_MASK(IRQ_IXDP2X01_SPCI_PMC_INTA) | 
  118. IXP2000_BOARD_IRQ_MASK(IRQ_IXDP2X01_SPCI_PMC_INTB) | 
  119. IXP2000_BOARD_IRQ_MASK(IRQ_IXDP2X01_SPCI_PMC_INTC) | 
  120. IXP2000_BOARD_IRQ_MASK(IRQ_IXDP2X01_SPCI_PMC_INTD) | 
  121. IXP2000_BOARD_IRQ_MASK(IRQ_IXDP2X01_SPCI_FIC_INT) | 
  122. IXP2000_BOARD_IRQ_MASK(IRQ_IXDP2X01_IPMI_FROM) | 
  123. IXP2000_BOARD_IRQ_MASK(IRQ_IXDP2X01_125US) | 
  124. IXP2000_BOARD_IRQ_MASK(IRQ_IXDP2X01_DB_0_ADD) | 
  125. IXP2000_BOARD_IRQ_MASK(IRQ_IXDP2X01_DB_1_ADD) | 
  126. IXP2000_BOARD_IRQ_MASK(IRQ_IXDP2X01_UART1) | 
  127. IXP2000_BOARD_IRQ_MASK(IRQ_IXDP2X01_UART2) | 
  128. IXP2000_BOARD_IRQ_MASK(IRQ_IXDP2X01_FIC_ADD_INT) | 
  129. IXP2000_BOARD_IRQ_MASK(IRQ_IXDP2X01_CS8900) | 
  130. IXP2000_BOARD_IRQ_MASK(IRQ_IXDP2X01_BBSRAM) )
  131. /* 
  132.  * IXDP2401 specific IRQs
  133.  */
  134. #define IRQ_IXDP2401_INTA_82546 IXP2000_BOARD_IRQ(0)
  135. #define IRQ_IXDP2401_INTB_82546 IXP2000_BOARD_IRQ(1)
  136. #define IXDP2401_VALID_IRQ_MASK ( 
  137. IXDP2X01_VALID_IRQ_MASK | 
  138. IXP2000_BOARD_IRQ_MASK(IRQ_IXDP2401_INTA_82546) |
  139. IXP2000_BOARD_IRQ_MASK(IRQ_IXDP2401_INTB_82546))
  140. /*
  141.  * IXDP2801-specific IRQs
  142.  */
  143. #define IRQ_IXDP2801_RIV IXP2000_BOARD_IRQ(0)
  144. #define IRQ_IXDP2801_CNFG_MEDIA IXP2000_BOARD_IRQ(27)
  145. #define IRQ_IXDP2801_CLOCK_REF IXP2000_BOARD_IRQ(28)
  146. #define IXDP2801_VALID_IRQ_MASK ( 
  147. IXDP2X01_VALID_IRQ_MASK | 
  148. IXP2000_BOARD_IRQ_MASK(IRQ_IXDP2801_RIV) |
  149. IXP2000_BOARD_IRQ_MASK(IRQ_IXDP2801_CNFG_MEDIA) |
  150. IXP2000_BOARD_IRQ_MASK(IRQ_IXDP2801_CLOCK_REF))
  151. #define NR_IXDP2X01_IRQS ((IRQ_IXDP2801_CLOCK_REF) + 1)
  152. #endif /*_IRQS_H*/