irq_numbers.h 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213
  1. /*
  2. * Copyright (c) 2012, Freescale Semiconductor, Inc.
  3. * All rights reserved.
  4. *
  5. * Redistribution and use in source and binary forms, with or without modification,
  6. * are permitted provided that the following conditions are met:
  7. *
  8. * o Redistributions of source code must retain the above copyright notice, this list
  9. * of conditions and the following disclaimer.
  10. *
  11. * o Redistributions in binary form must reproduce the above copyright notice, this
  12. * list of conditions and the following disclaimer in the documentation and/or
  13. * other materials provided with the distribution.
  14. *
  15. * o Neither the name of Freescale Semiconductor, Inc. nor the names of its
  16. * contributors may be used to endorse or promote products derived from this
  17. * software without specific prior written permission.
  18. *
  19. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
  20. * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
  21. * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
  22. * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
  23. * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
  24. * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
  25. * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
  26. * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  27. * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
  28. * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  29. */
  30. #if !defined(__IRQ_NUMBERS_H__)
  31. #define __IRQ_NUMBERS_H__
  32. ////////////////////////////////////////////////////////////////////////////////
  33. // Definitions
  34. ////////////////////////////////////////////////////////////////////////////////
  35. //! @brief i.MX6 interrupt numbers.
  36. //!
  37. //! This enumeration lists the numbers for all of the interrupts available on the i.MX6 series.
  38. //! Use these numbers when specifying an interrupt to the GIC.
  39. //!
  40. //! The first 16 interrupts are special in that they are reserved for software interrupts generated
  41. //! by the SWI instruction.
  42. enum _imx_interrupts
  43. {
  44. SW_INTERRUPT_0 = 0, //!< Software interrupt 0.
  45. SW_INTERRUPT_1 = 1, //!< Software interrupt 1.
  46. SW_INTERRUPT_2 = 2, //!< Software interrupt 2.
  47. SW_INTERRUPT_3 = 3, //!< Software interrupt 3.
  48. SW_INTERRUPT_4 = 4, //!< Software interrupt 4.
  49. SW_INTERRUPT_5 = 5, //!< Software interrupt 5.
  50. SW_INTERRUPT_6 = 6, //!< Software interrupt 6.
  51. SW_INTERRUPT_7 = 7, //!< Software interrupt 7.
  52. SW_INTERRUPT_8 = 8, //!< Software interrupt 8.
  53. SW_INTERRUPT_9 = 9, //!< Software interrupt 9.
  54. SW_INTERRUPT_10 = 10, //!< Software interrupt 10.
  55. SW_INTERRUPT_11 = 11, //!< Software interrupt 11.
  56. SW_INTERRUPT_12 = 12, //!< Software interrupt 12.
  57. SW_INTERRUPT_13 = 13, //!< Software interrupt 13.
  58. SW_INTERRUPT_14 = 14, //!< Software interrupt 14.
  59. SW_INTERRUPT_15 = 15, //!< Software interrupt 15.
  60. RSVD_INTERRUPT_16 = 16, //!< Reserved.
  61. RSVD_INTERRUPT_17 = 17, //!< Reserved.
  62. RSVD_INTERRUPT_18 = 18, //!< Reserved.
  63. RSVD_INTERRUPT_19 = 19, //!< Reserved.
  64. RSVD_INTERRUPT_20 = 20, //!< Reserved.
  65. RSVD_INTERRUPT_21 = 21, //!< Reserved.
  66. RSVD_INTERRUPT_22 = 22, //!< Reserved.
  67. RSVD_INTERRUPT_23 = 23, //!< Reserved.
  68. RSVD_INTERRUPT_24 = 24, //!< Reserved.
  69. RSVD_INTERRUPT_25 = 25, //!< Reserved.
  70. RSVD_INTERRUPT_26 = 26, //!< Reserved.
  71. RSVD_INTERRUPT_27 = 27, //!< Reserved.
  72. RSVD_INTERRUPT_28 = 28, //!< Reserved.
  73. RSVD_INTERRUPT_29 = 29, //!< Reserved.
  74. RSVD_INTERRUPT_30 = 30, //!< Reserved.
  75. RSVD_INTERRUPT_31 = 31, //!< Reserved.
  76. IMX_INT_IOMUXC_GPR = 32, //!< General Purpose Register 1 from IOMUXC. Used to notify cores on exception condition while boot.
  77. IMX_INT_CHEETAH_CSYSPWRUPREQ = 33, //!< @todo Listed as DAP in RM
  78. IMX_INT_SDMA = 34, //!< Logical OR of all 48 SDMA interrupt requests/events from all channels.
  79. IMX_INT_TSC = 35, //!< TSC
  80. IMX_INT_SNVS_LP_SET_PWR_OFF = 36, //!< PMIC power off request.
  81. IMX_INT_LCDIF = 37, //!< LCDIF interrupt request.
  82. IMX_INT_BEE = 38, //!< BEE interrupt request.
  83. IMX_INT_CSI = 39, //!< CMOS Sensor Interface interrupt request.
  84. IMX_INT_PXP = 40, //!< PXP interrupt request.
  85. IMX_INT_SCTR1 = 41, //!< SCTR1
  86. IMX_INT_SCTR2 = 42, //!< SCTR2
  87. IMX_INT_WDOG3 = 43, //!< WDOG3 timer reset interrupt request.
  88. IMX_INT_INTERRUPT_44 = 44, //!< Reserved.
  89. IMX_INT_APBH_DMA = 45, //!< APBH DMA
  90. IMX_INT_EIM = 46, //!< EIM interrupt request.
  91. IMX_INT_NAND_BCH = 47, //!< Reserved.
  92. IMX_INT_NAND_GPMI = 48, //!< Reserved.
  93. IMX_INT_UART6 = 49, //!< Logical OR of UART5 interrupt requests.
  94. IMX_INT_INTERRUPT_50 = 50, //!< Reserved.
  95. IMX_INT_SNVS = 51, //!< SNVS consolidated interrupt.
  96. IMX_INT_SNVS_SEC = 52, //!< SNVS security interrupt.
  97. IMX_INT_CSU = 53, //!< CSU interrupt request 1. Indicates to the processor that one or more alarm inputs were asserted.
  98. IMX_INT_USDHC1 = 54, //!< uSDHC1 (Enhanced SDHC) interrupt request.
  99. IMX_INT_USDHC2 = 55, //!< uSDHC2 (Enhanced SDHC) interrupt request.
  100. IMX_INT_SAI3 = 56, //!< uSDHC3 (Enhanced SDHC) interrupt request.
  101. IMX_INT_SAI4 = 57, //!< uSDHC4 (Enhanced SDHC) interrupt request.
  102. IMX_INT_UART1 = 58, //!< Logical OR of UART1 interrupt requests.
  103. IMX_INT_UART2 = 59, //!< Logical OR of UART2 interrupt requests.
  104. IMX_INT_UART3 = 60, //!< Logical OR of UART3 interrupt requests.
  105. IMX_INT_UART4 = 61, //!< Logical OR of UART4 interrupt requests.
  106. IMX_INT_UART5 = 62, //!< Logical OR of UART5 interrupt requests.
  107. IMX_INT_ECSPI1 = 63, //!< eCSPI1 interrupt request.
  108. IMX_INT_ECSPI2 = 64, //!< eCSPI2 interrupt request.
  109. IMX_INT_ECSPI3 = 65, //!< eCSPI3 interrupt request.
  110. IMX_INT_ECSPI4 = 66, //!< eCSPI4 interrupt request.
  111. IMX_INT_I2C4 = 67, //!< Reserved.
  112. IMX_INT_I2C1 = 68, //!< I2C1 interrupt request.
  113. IMX_INT_I2C2 = 69, //!< I2C2 interrupt request.
  114. IMX_INT_I2C3 = 70, //!< I2C3 interrupt request.
  115. IMX_INT_UART7 = 71, //!< Logical OR of UART5 interrupt requests.
  116. IMX_INT_UART8 = 72, //!< Logical OR of UART5 interrupt requests.
  117. IMX_INT_INTERRUPT_73 = 73, //!< Reserved.
  118. IMX_INT_USB_OTG2 = 74, //!< USB Host 1 interrupt request.
  119. IMX_INT_USB_OTG1 = 75, //!< USB OTG1 interrupt request.
  120. IMX_INT_USB_UTMI0 = 76, //!< UTMI0 interrupt request.
  121. IMX_INT_USB_UTMI1 = 77, //!< UTMI1 interrupt request.
  122. IMX_INT_CAAM_JQ2 = 78, //!< SSI1 interrupt request.
  123. IMX_INT_CAAM_ERR = 79, //!< SSI2 interrupt request.
  124. IMX_INT_CAAM_RTIC = 80, //!< SSI3 interrupt request.
  125. IMX_INT_TEMPERATURE = 81, //!< Temperature Sensor (temp. greater than threshold) interrupt request.
  126. IMX_INT_ASRC = 82, //!< Reserved.
  127. IMX_INT_INTERRUPT_83 = 83, //!< Reserved.
  128. IMX_INT_SPDIF = 84, //!< Logical OR of SPDIF TX and SPDIF RX interrupts.
  129. IMX_INT_INTERRUPT_85 = 85, //!< Reserved.
  130. IMX_INT_PMU_ANA_BO = 86, //!< PMU analog regulator brown-out interrupt request.
  131. IMX_INT_GPT1 = 87, //
  132. IMX_INT_EPIT1 = 88, //!< EPIT1 output compare interrupt.
  133. IMX_INT_EPIT2 = 89, //!< EPIT2 output compare interrupt.
  134. IMX_INT_GPIO1_INT7 = 90, //!< INT7 interrupt request.
  135. IMX_INT_GPIO1_INT6 = 91, //!< INT6 interrupt request.
  136. IMX_INT_GPIO1_INT5 = 92, //!< INT5 interrupt request.
  137. IMX_INT_GPIO1_INT4 = 93, //!< INT4 interrupt request.
  138. IMX_INT_GPIO1_INT3 = 94, //!< INT3 interrupt request.
  139. IMX_INT_GPIO1_INT2 = 95, //!< INT2 interrupt request.
  140. IMX_INT_GPIO1_INT1 = 96, //!< INT1 interrupt request.
  141. IMX_INT_GPIO1_INT0 = 97, //!< INT0 interrupt request.
  142. IMX_INT_GPIO1_INT15_0 = 98, //!< Combined interrupt indication for GPIO1 signals 0 - 15.
  143. IMX_INT_GPIO1_INT31_16 = 99, //!< Combined interrupt indication for GPIO1 signals 16 - 31.
  144. IMX_INT_GPIO2_INT15_0 = 100, //!< Combined interrupt indication for GPIO2 signals 0 - 15.
  145. IMX_INT_GPIO2_INT31_16 = 101, //!< Combined interrupt indication for GPIO2 signals 16 - 31.
  146. IMX_INT_GPIO3_INT15_0 = 102, //!< Combined interrupt indication for GPIO3 signals 0 - 15.
  147. IMX_INT_GPIO3_INT31_16 = 103, //!< Combined interrupt indication for GPIO3 signals 16 - 31.
  148. IMX_INT_GPIO4_INT15_0 = 104, //!< Combined interrupt indication for GPIO4 signals 0 - 15.
  149. IMX_INT_GPIO4_INT31_16 = 105, //!< Combined interrupt indication for GPIO4 signals 16 - 31.
  150. IMX_INT_GPIO5_INT15_0 = 106, //!< Combined interrupt indication for GPIO5 signals 0 - 15.
  151. IMX_INT_GPIO5_INT31_16 = 107, //!< Combined interrupt indication for GPIO5 signals 16 - 31.
  152. IMX_INT_INTERRUPT_108 = 108, //!< Reserved.
  153. IMX_INT_INTERRUPT_109 = 109, //!< Reserved.
  154. IMX_INT_INTERRUPT_110 = 110, //!< Reserved.
  155. IMX_INT_INTERRUPT_111 = 111, //!< Reserved.
  156. IMX_INT_WDOG1 = 112, //!< WDOG1 timer reset interrupt request.
  157. IMX_INT_WDOG2 = 113, //!< WDOG2 timer reset interrupt request.
  158. IMX_INT_KPP = 114, //!< Key Pad interrupt request.
  159. IMX_INT_PWM1 = 115, //!< Cumulative interrupt line for PWM1. Logical OR of rollover, compare, and FIFO waterlevel crossing interrupts.
  160. IMX_INT_PWM2 = 116, //!< Cumulative interrupt line for PWM2. Logical OR of rollover, compare, and FIFO waterlevel crossing interrupts.
  161. IMX_INT_PWM3 = 117, //!< Cumulative interrupt line for PWM3. Logical OR of rollover, compare, and FIFO waterlevel crossing interrupts.
  162. IMX_INT_PWM4 = 118, //!< Cumulative interrupt line for PWM4. Logical OR of rollover, compare, and FIFO waterlevel crossing interrupts.
  163. IMX_INT_CCM_INT1 = 119, //!< CCM interrupt request 1.
  164. IMX_INT_CCM_INT2 = 120, //!< CCM interrupt request 2.
  165. IMX_INT_GPC_INT1 = 121, //!< GPC interrupt request 1.
  166. IMX_INT_INTERRUPT_122 = 122, //!< Reserved.
  167. IMX_INT_SRC = 123, //!< SRC interrupt request.
  168. IMX_INT_INTERRUPT_124 = 124, //!< Logical OR of all L2 interrupt requests.
  169. IMX_INT_INTERRUPT_125 = 125, //!< Parity Check error interrupt request.
  170. IMX_INT_CHEETAH_PERFORM = 126, //!< Logical OR of Performance Unit interrupts.
  171. IMX_INT_CHEETAH_TRIGGER = 127, //!< Logical OR of CTI trigger outputs.
  172. IMX_INT_SRC_CPU_WDOG = 128, //!< Combined CPU wdog interrupts (4x) out of SRC.
  173. IMX_INT_SAI1 = 129, //!< EPDC interrupt request.
  174. IMX_INT_SAI2 = 130, //!< EPDC interrupt request.
  175. IMX_INT_INTERRUPT_131 = 131, //!< DCP general interrupt request.
  176. IMX_INT_ADC1 = 132, //!< DCP channel 0 interrupt request.
  177. IMX_INT_ADC2 = 133, //!< DCP secure interrupt request.
  178. IMX_INT_INTERRUPT_134 = 134, //!< Reserved.
  179. IMX_INT_INTERRUPT_135 = 135, //!< Reserved.
  180. IMX_INT_SJC = 136, //!< SJC interrupt from General Purpose register.
  181. IMX_INT_CAAM_0 = 137, //!< Reserved.
  182. IMX_INT_CAAM_1 = 138, //!< Reserved.
  183. IMX_INT_QSPI = 139, //!< Reserved.
  184. IMX_INT_TZASC1 = 140, //!< ASC1 interrupt request.
  185. IMX_INT_GPT2 = 141, //!< Reserved.
  186. IMX_INT_CAN1 = 142, //!< Reserved.
  187. IMX_INT_CAN2 = 143, //!< Reserved.
  188. IMX_INT_SIM1 = 144, //!< Reserved.
  189. IMX_INT_SIM2 = 145, //!< Reserved.
  190. IMX_INT_PWM5 = 146, //!< Fast Ethernet Controller interrupt request.
  191. IMX_INT_PWM6 = 147, //!< Reserved.
  192. IMX_INT_PWM7 = 148, //!< Reserved.
  193. IMX_INT_PWM8 = 149, //!< Reserved.
  194. IMX_INT_ENET1 = 150, //!< Reserved.
  195. IMX_INT_ENET1_TIMER = 151, //!< Reserved.
  196. IMX_INT_ENET2 = 152, //!< Reserved.
  197. IMX_INT_ENET2_TIMER = 153, //!< Reserved.
  198. IMX_INT_INTERRUPT_154 = 154, //!< Reserved.
  199. IMX_INT_INTERRUPT_155 = 155, //!< Reserved.
  200. IMX_INT_INTERRUPT_156 = 156, //!< Reserved.
  201. IMX_INT_INTERRUPT_157 = 157, //!< Reserved.
  202. IMX_INT_INTERRUPT_158 = 158, //!< Reserved.
  203. IMX_INT_PMU_DIG_BO = 159, //!< //!< PMU digital regulator brown-out interrupt request.
  204. IMX_INTERRUPT_COUNT = 160 //!< Total number of interrupts.
  205. };
  206. #endif // __IRQ_NUMBERS_H__
  207. ////////////////////////////////////////////////////////////////////////////////
  208. // EOF
  209. ////////////////////////////////////////////////////////////////////////////////