ih_stm32.c 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370
  1. /*
  2. * Copyright (C) 2013 Uwe Bonnes(bon@elektron.ikp.physik.tu-darmstadty.de).
  3. *
  4. * Redistribution and use in source and binary forms, with or without
  5. * modification, are permitted provided that the following conditions
  6. * are met:
  7. *
  8. * 1. Redistributions of source code must retain the above copyright
  9. * notice, this list of conditions and the following disclaimer.
  10. * 2. Redistributions in binary form must reproduce the above copyright
  11. * notice, this list of conditions and the following disclaimer in the
  12. * documentation and/or other materials provided with the distribution.
  13. * 3. Neither the name of the copyright holders nor the names of
  14. * contributors may be used to endorse or promote products derived
  15. * from this software without specific prior written permission.
  16. *
  17. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  18. * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  19. * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
  20. * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
  21. * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
  22. * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
  23. * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
  24. * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
  25. * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
  26. * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
  27. * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  28. * SUCH DAMAGE.
  29. *
  30. * For additional information see http://www.ethernut.de/
  31. *
  32. */
  33. /*
  34. * $Log$
  35. * Revision 1.0 2011/12/09 17:30:10 ulrichprinz
  36. * Initial version.
  37. *
  38. */
  39. #include <cfg/arch.h>
  40. #include <cfg/devices.h>
  41. #include <arch/cm3.h>
  42. #include <dev/irqreg.h>
  43. #ifndef NUT_IRQPRI_DEF
  44. #define NUT_IRQPRI_DEF 4
  45. #endif
  46. /* sig_INTERRUPTX needs special handling for level sensivity and multiple
  47. occupancy*/
  48. /* We can't use XXX_IRQn to check for availability, as XXX_IRQn is an enum
  49. not usable for the preprocessor.
  50. - If the Device is available on all devices in a family but not for all
  51. families, for the device specific structure (e.g. USART6).
  52. - If the device is only available on some F1 devices, create a configurator
  53. item with the HW_XXX_STM32 value.
  54. */
  55. CREATE_HANDLER(WWDG, WWDG, NUT_IRQPRI_DEF); /* Window Watchdog */
  56. #if defined (STM32F072)
  57. CREATE_HANDLER(PVD, PVD_VDDIO2, NUT_IRQPRI_DEF); /* PVD through EXTI */
  58. #else
  59. CREATE_HANDLER(PVD, PVD, NUT_IRQPRI_DEF); /* PVD through EXTI */
  60. #endif
  61. CREATE_HANDLER(FLASH, FLASH, NUT_IRQPRI_DEF); /* Flash global */
  62. #if defined (STM32F072)
  63. CREATE_HANDLER(RCC, RCC_CRS, NUT_IRQPRI_DEF); /* RCC global */
  64. #else
  65. CREATE_HANDLER(RCC, RCC, NUT_IRQPRI_DEF); /* RCC global */
  66. #endif
  67. #if defined(HW_RTC_STM32F1)
  68. CREATE_HANDLER(RTC, RTC, NUT_IRQPRI_DEF); // Real Time Clock
  69. #endif
  70. #if defined(HW_RTC_STM32_V2)
  71. CREATE_HANDLER(RTC, RTC_Alarm,NUT_IRQPRI_DEF); // Real Time Clock
  72. #endif
  73. CREATE_HANDLER(SPI1, SPI1, NUT_IRQPRI_DEF); // SPI 1 Controller
  74. #if defined(HW_SPI2_STM32)
  75. CREATE_HANDLER(SPI2, SPI2, NUT_IRQPRI_DEF); // SPI 2 Controller
  76. #endif
  77. #if defined(HW_SPI3_STM32)
  78. CREATE_HANDLER(SPI3, SPI3, NUT_IRQPRI_DEF); // SPI 3 Controller
  79. #endif
  80. #if defined(HW_SPI4_STM32)
  81. CREATE_HANDLER(SPI4, SPI4, NUT_IRQPRI_DEF); // SPI 4 Controller
  82. #endif
  83. #if defined(HW_SPI5_STM32)
  84. CREATE_HANDLER(SPI5, SPI5, NUT_IRQPRI_DEF); // SPI 5 Controller
  85. #endif
  86. #if defined(HW_SPI6_STM32)
  87. CREATE_HANDLER(SPI6, SPI6, NUT_IRQPRI_DEF); // SPI 6 Controller
  88. #endif
  89. #if defined(HW_SDIO_STM32)
  90. CREATE_HANDLER(SDIO, SDIO, NUT_IRQPRI_DEF); // SDIO Controller
  91. #endif
  92. #if defined(HW_SAI1_STM32)
  93. CREATE_HANDLER(SAI1, SAI1, NUT_IRQPRI_DEF); // SPI 2 Controller
  94. #endif
  95. #if defined (MCU_STM32F0)
  96. CREATE_HANDLER(TWI1, I2C1, NUT_IRQPRI_DEF); // I2C 1 Data/Event
  97. #else
  98. CREATE_HANDLER(TWI1_EV, I2C1_EV, NUT_IRQPRI_DEF); // I2C 1 Data/Event
  99. CREATE_HANDLER(TWI1_ER, I2C1_ER, NUT_IRQPRI_DEF); // I2C 2 Data/Event
  100. #endif
  101. #if defined(HW_I2C2_STM32)
  102. #if defined (MCU_STM32F0)
  103. CREATE_HANDLER(TWI2, I2C2, NUT_IRQPRI_DEF); // I2C 1 Data/Event
  104. #else
  105. CREATE_HANDLER(TWI2_EV, I2C2_EV, NUT_IRQPRI_DEF); // I2C 2 Data/Event
  106. CREATE_HANDLER(TWI2_ER, I2C2_ER, NUT_IRQPRI_DEF); // I2C 1 Error
  107. #endif
  108. #endif
  109. #if defined(HW_I2C3_STM32)
  110. CREATE_HANDLER(TWI3_EV, I2C3_EV, NUT_IRQPRI_DEF); // I2C 2 Error
  111. CREATE_HANDLER(TWI3_ER, I2C3_ER, NUT_IRQPRI_DEF); // I2C 2 Error
  112. #endif
  113. #if defined(HW_USB_CAN1_STM32) || defined(STM32F30X)
  114. CREATE_HANDLER(CAN1_TX, USB_HP_CAN1_TX, NUT_IRQPRI_DEF); // CAN 1 TX
  115. CREATE_HANDLER(CAN1_RX0, USB_LP_CAN1_RX0, NUT_IRQPRI_DEF); // CAN 1 RX0
  116. CREATE_HANDLER(CAN1_RX1, CAN1_RX1, NUT_IRQPRI_DEF); // CAN 1 RX1
  117. CREATE_HANDLER(CAN1_SCE, CAN1_SCE, NUT_IRQPRI_DEF); // CAN 1 SCE
  118. #elif defined(HW_CAN1_STM32)
  119. CREATE_HANDLER(CAN1_TX, CAN1_TX, NUT_IRQPRI_DEF); // CAN 1 TX
  120. CREATE_HANDLER(CAN1_RX0, CAN1_RX0, NUT_IRQPRI_DEF); // CAN 1 RX0
  121. CREATE_HANDLER(CAN1_RX1, CAN1_RX1, NUT_IRQPRI_DEF); // CAN 1 RX1
  122. CREATE_HANDLER(CAN1_SCE, CAN1_SCE, NUT_IRQPRI_DEF); // CAN 1 SCE
  123. #endif
  124. #if defined(HW_CAN2_STM32)
  125. CREATE_HANDLER(CAN2_TX, CAN2_TX, NUT_IRQPRI_DEF); // CAN 2 TX
  126. CREATE_HANDLER(CAN2_RX0, CAN2_RX0, NUT_IRQPRI_DEF); // CAN 2 RX0
  127. CREATE_HANDLER(CAN2_RX1, CAN2_RX1, NUT_IRQPRI_DEF); // CAN 2 RX1
  128. CREATE_HANDLER(CAN2_SCE, CAN2_SCE, NUT_IRQPRI_DEF); // CAN 2 SCE
  129. #endif
  130. #if defined(HW_USB_STM32)
  131. CREATE_HANDLER(USB_HP, USB_HP, NUT_IRQPRI_DEF); // USB High Priority, separted
  132. CREATE_HANDLER(USB_LP, USB_LP, NUT_IRQPRI_DEF); // USB Low Priority, separted
  133. #if defined(STM32F30X)
  134. CREATE_HANDLER(USB_WAKE, USBWakeUp_RMP, NUT_IRQPRI_DEF); // USB Wake Priority, separted
  135. #else
  136. CREATE_HANDLER(USB_WAKE, USBWakeUp, NUT_IRQPRI_DEF); // USB Wake Priority, separted
  137. #endif
  138. #endif
  139. CREATE_HANDLER(USART1, USART1, NUT_IRQPRI_DEF); // USART 1
  140. #if defined(HW_USART2_STM32)
  141. CREATE_HANDLER(USART2, USART2, NUT_IRQPRI_DEF); // USART 2
  142. #endif
  143. #if defined(HW_USART3_STM32)
  144. CREATE_HANDLER(USART3, USART3, NUT_IRQPRI_DEF); // USART 3
  145. #endif
  146. #if defined(HW_UART4_STM32)
  147. CREATE_HANDLER(UART4, UART4, NUT_IRQPRI_DEF); // UART 4
  148. #endif
  149. #if defined(HW_USART3_4_STM32)
  150. CREATE_HANDLER(UART3_4, UART3_4, NUT_IRQPRI_DEF); // UART 3/4 combined
  151. #endif
  152. #if defined(HW_UART5_STM32)
  153. CREATE_HANDLER(UART5, UART5, NUT_IRQPRI_DEF); // UART 5
  154. #endif
  155. #if defined(HW_USART6_STM32)
  156. CREATE_HANDLER(USART6, USART6, NUT_IRQPRI_DEF); // USART 6
  157. #endif
  158. #if defined(HW_UART7_STM32)
  159. CREATE_HANDLER(UART7, UART7, NUT_IRQPRI_DEF); // UART 7
  160. #endif
  161. #if defined(HW_UART8_STM32)
  162. CREATE_HANDLER(UART8, UART8, NUT_IRQPRI_DEF); // UART 8
  163. #endif
  164. #if defined (STM32F072)
  165. CREATE_HANDLER(DMA1_CH1, DMA1_Channel1 , NUT_IRQPRI_DEF); // DMA Controller 1 Channel 1
  166. CREATE_HANDLER(DMA1_CH2, DMA1_Channel2_3 , NUT_IRQPRI_DEF); // DMA Controller 1 Channel 1
  167. CREATE_HANDLER(DMA1_CH3, DMA1_Channel4_5_6_7, NUT_IRQPRI_DEF); // DMA Controller 1 Channel 1
  168. #elif defined (MCU_STM32F0)
  169. CREATE_HANDLER(DMA1_CH1, DMA1_Channel1 , NUT_IRQPRI_DEF); // DMA Controller 1 Channel 1
  170. CREATE_HANDLER(DMA1_CH2, DMA1_Channel2_3 , NUT_IRQPRI_DEF); // DMA Controller 1 Channel 1
  171. CREATE_HANDLER(DMA1_CH3, DMA1_Channel4_5 , NUT_IRQPRI_DEF); // DMA Controller 1 Channel 1
  172. #elif defined (DMA1_Channel1_BASE)
  173. CREATE_HANDLER(DMA1_CH1, DMA1_Channel1, NUT_IRQPRI_DEF); // DMA Controller 1 Channel 1
  174. CREATE_HANDLER(DMA1_CH2, DMA1_Channel2, NUT_IRQPRI_DEF); // DMA Controller 1 Channel 1
  175. CREATE_HANDLER(DMA1_CH3, DMA1_Channel3, NUT_IRQPRI_DEF); // DMA Controller 1 Channel 1
  176. CREATE_HANDLER(DMA1_CH4, DMA1_Channel4, NUT_IRQPRI_DEF); // DMA Controller 1 Channel 1
  177. CREATE_HANDLER(DMA1_CH5, DMA1_Channel5, NUT_IRQPRI_DEF); // DMA Controller 1 Channel 1
  178. CREATE_HANDLER(DMA1_CH6, DMA1_Channel6, NUT_IRQPRI_DEF); // DMA Controller 1 Channel 1
  179. CREATE_HANDLER(DMA1_CH7, DMA1_Channel7, NUT_IRQPRI_DEF); // DMA Controller 1 Channel 1
  180. #endif
  181. #if defined(HW_DMA2_STM32F1)
  182. CREATE_HANDLER(DMA2_CH1, DMA2_Channel1, NUT_IRQPRI_DEF); // DMA Controller 1 Channel 1
  183. CREATE_HANDLER(DMA2_CH2, DMA2_Channel2, NUT_IRQPRI_DEF); // DMA Controller 1 Channel 1
  184. CREATE_HANDLER(DMA2_CH3, DMA2_Channel3, NUT_IRQPRI_DEF); // DMA Controller 1 Channel 1
  185. CREATE_HANDLER(DMA2_CH4, DMA2_Channel4, NUT_IRQPRI_DEF); // DMA Controller 1 Channel 1
  186. CREATE_HANDLER(DMA2_CH5, DMA2_Channel5, NUT_IRQPRI_DEF); // DMA Controller 1 Channel 1
  187. #endif
  188. #if defined(DMA1_Stream0)
  189. CREATE_HANDLER(DMA1_STREAM0, DMA1_Stream0, NUT_IRQPRI_DEF); // DMA Controller 0 Stream 1
  190. CREATE_HANDLER(DMA1_STREAM1, DMA1_Stream1, NUT_IRQPRI_DEF); // DMA Controller 0 Stream 1
  191. CREATE_HANDLER(DMA1_STREAM2, DMA1_Stream2, NUT_IRQPRI_DEF); // DMA Controller 0 Stream 2
  192. CREATE_HANDLER(DMA1_STREAM3, DMA1_Stream3, NUT_IRQPRI_DEF); // DMA Controller 0 Stream 3
  193. CREATE_HANDLER(DMA1_STREAM4, DMA1_Stream4, NUT_IRQPRI_DEF); // DMA Controller 0 Stream 4
  194. CREATE_HANDLER(DMA1_STREAM5, DMA1_Stream5, NUT_IRQPRI_DEF); // DMA Controller 0 Stream 5
  195. CREATE_HANDLER(DMA1_STREAM6, DMA1_Stream6, NUT_IRQPRI_DEF); // DMA Controller 0 Stream 6
  196. CREATE_HANDLER(DMA1_STREAM7, DMA1_Stream7, NUT_IRQPRI_DEF); // DMA Controller 0 Stream 7
  197. CREATE_HANDLER(DMA2_STREAM0, DMA2_Stream0, NUT_IRQPRI_DEF); // DMA Controller 1 Stream 1
  198. CREATE_HANDLER(DMA2_STREAM1, DMA2_Stream1, NUT_IRQPRI_DEF); // DMA Controller 1 Stream 2
  199. CREATE_HANDLER(DMA2_STREAM2, DMA2_Stream2, NUT_IRQPRI_DEF); // DMA Controller 1 Stream 3
  200. CREATE_HANDLER(DMA2_STREAM3, DMA2_Stream3, NUT_IRQPRI_DEF); // DMA Controller 1 Stream 4
  201. CREATE_HANDLER(DMA2_STREAM4, DMA2_Stream4, NUT_IRQPRI_DEF); // DMA Controller 1 Stream 5
  202. CREATE_HANDLER(DMA2_STREAM5, DMA2_Stream5, NUT_IRQPRI_DEF); // DMA Controller 1 Stream 6
  203. CREATE_HANDLER(DMA2_STREAM6, DMA2_Stream6, NUT_IRQPRI_DEF); // DMA Controller 1 Stream 7
  204. CREATE_HANDLER(DMA2_STREAM7, DMA2_Stream7, NUT_IRQPRI_DEF); // DMA Controller 1 Stream 7
  205. #endif
  206. #if defined(HW_EMAC_STM32)
  207. CREATE_HANDLER(EMAC, ETH, NUT_IRQPRI_DEF); // Ethernet global interrupt
  208. CREATE_HANDLER(EMAC_WAKE, ETH_WKUP, NUT_IRQPRI_DEF); // Ethernet global interrupt
  209. #endif
  210. #if defined(MCU_STM32F0)
  211. CREATE_HANDLER(TIM1_BRK_UP_TRG_COM, TIM1_BRK_UP_TRG_COM, NUT_IRQPRI_DEF);
  212. CREATE_HANDLER(TIM1_CC, TIM1_CC, NUT_IRQPRI_DEF);
  213. #elif defined(STM32F30X) || defined(STM32F10X_LD_VL) || defined (STM32F10X_MD_VL) || defined(STM32F10X_HD_VL)
  214. CREATE_HANDLER(TIM1_BRK_TIM15, TIM1_BRK_TIM15, NUT_IRQPRI_DEF);
  215. CREATE_HANDLER(TIM1_UP_TIM16, TIM1_UP_TIM16, NUT_IRQPRI_DEF);
  216. CREATE_HANDLER(TIM1_TRG_COM_TIM17, TIM1_TRG_COM_TIM17, NUT_IRQPRI_DEF);
  217. CREATE_HANDLER(TIM1_CC, TIM1_CC, NUT_IRQPRI_DEF);
  218. #elif defined(MCU_STM32F4) || defined (MCU_STM32F2)
  219. CREATE_HANDLER(TIM1_BRK_TIM9, TIM1_BRK_TIM9, NUT_IRQPRI_DEF);
  220. CREATE_HANDLER(TIM1_UP_TIM10, TIM1_UP_TIM10, NUT_IRQPRI_DEF);
  221. CREATE_HANDLER(TIM1_TRG_COM_TIM11, TIM1_TRG_COM_TIM11, NUT_IRQPRI_DEF);
  222. CREATE_HANDLER(TIM1_CC, TIM1_CC, NUT_IRQPRI_DEF);
  223. #elif defined(HW_TIM1_STM32)
  224. CREATE_HANDLER(TIM1_BRK, TIM1_BRK, NUT_IRQPRI_DEF);
  225. CREATE_HANDLER(TIM1_UP, TIM1_UP, NUT_IRQPRI_DEF);
  226. CREATE_HANDLER(TIM1_TRG_COM, TIM1_TRG_COM, NUT_IRQPRI_DEF);
  227. CREATE_HANDLER(TIM1_CC, TIM1_CC, NUT_IRQPRI_DEF);
  228. #endif
  229. /* Only Tim2 up to TIM5 have always a single TIMx_IRQn*/
  230. CREATE_HANDLER(TIM2, TIM2, NUT_IRQPRI_DEF);
  231. CREATE_HANDLER(TIM3, TIM3, NUT_IRQPRI_DEF);
  232. #if defined(HW_TIM4_STM32)
  233. CREATE_HANDLER(TIM4, TIM4, NUT_IRQPRI_DEF);
  234. #endif
  235. #if defined(HW_TIM5_STM32)
  236. CREATE_HANDLER(TIM5, TIM5, NUT_IRQPRI_DEF);
  237. #endif
  238. #if defined(HW_TIM6_STM32)
  239. CREATE_HANDLER(TIM6, TIM6, NUT_IRQPRI_DEF);
  240. #endif
  241. #if defined(HW_TIM7_STM32)
  242. CREATE_HANDLER(TIM7, TIM7, NUT_IRQPRI_DEF);
  243. #endif
  244. #if defined(HW_TIM8_STM32)
  245. CREATE_HANDLER(TIM8_BRK, TIM8_BRK, NUT_IRQPRI_DEF);
  246. CREATE_HANDLER(TIM8_UP, TIM8_UP, NUT_IRQPRI_DEF);
  247. CREATE_HANDLER(TIM8_TRG_COM, TIM8_TRG_COM, NUT_IRQPRI_DEF);
  248. CREATE_HANDLER(TIM8_CC, TIM8_CC, NUT_IRQPRI_DEF);
  249. #endif
  250. #if defined(HW_TIM10_STM32)
  251. CREATE_HANDLER(TIM10, TIM10, NUT_IRQPRI_DEF);
  252. #endif
  253. #if defined(HW_TIM11_STM32)
  254. CREATE_HANDLER(TIM11, TIM11, NUT_IRQPRI_DEF);
  255. #endif
  256. #if defined(HW_TIM12_STM32)
  257. CREATE_HANDLER(TIM12, TIM12, NUT_IRQPRI_DEF);
  258. #endif
  259. #if defined(HW_TIM13_STM32)
  260. CREATE_HANDLER(TIM13, TIM13, NUT_IRQPRI_DEF);
  261. #endif
  262. #if defined(HW_TIM14_STM32)
  263. CREATE_HANDLER(TIM14, TIM14, NUT_IRQPRI_DEF);
  264. #endif
  265. #if defined(HW_TIM15_STM32)
  266. CREATE_HANDLER(TIM15, TIM15, NUT_IRQPRI_DEF);
  267. #endif
  268. #if defined(HW_TIM16_STM32)
  269. CREATE_HANDLER(TIM16, TIM16, NUT_IRQPRI_DEF);
  270. #endif
  271. #if defined(HW_TIM17_STM32)
  272. CREATE_HANDLER(TIM17, TIM17, NUT_IRQPRI_DEF);
  273. #endif
  274. #if defined(HW_TIM19_STM32)
  275. CREATE_HANDLER(TIM19, TIM19, NUT_IRQPRI_DEF);
  276. #endif
  277. #if defined(HW_ADC_STM32)
  278. CREATE_HANDLER(ADC, ADC, NUT_IRQPRI_DEF);
  279. #endif
  280. #if defined(HW_ADC1_STM32) || defined(HW_ADC1_STM32F1)
  281. CREATE_HANDLER(ADC1, ADC1, NUT_IRQPRI_DEF);
  282. #endif
  283. #if defined(HW_ADC1_2_STM32) || defined(HW_ADC1_2_STM32F1)
  284. CREATE_HANDLER(ADC1_2, ADC1_2, NUT_IRQPRI_DEF);
  285. #endif
  286. #if defined(HW_ADC3_STM32) || defined(HW_ADC3_STM32F1)
  287. CREATE_HANDLER(ADC3, ADC3, NUT_IRQPRI_DEF);
  288. #endif
  289. #if defined(HW_ADC4_STM32)
  290. CREATE_HANDLER(ADC4, ADC4, NUT_IRQPRI_DEF);
  291. #endif
  292. #if defined(HW_SDADC1_STM32)
  293. CREATE_HANDLER(SDADC1, SDADC1, NUT_IRQPRI_DEF);
  294. #endif
  295. #if defined(HW_SDADC2_STM32)
  296. CREATE_HANDLER(SDADC2, SDADC2, NUT_IRQPRI_DEF);
  297. #endif
  298. #if defined(HW_SDADC3_STM32)
  299. CREATE_HANDLER(SDADC3, SDADC3, NUT_IRQPRI_DEF);
  300. #endif
  301. #if defined(HW_HASH_STM32)
  302. CREATE_HANDLER(HASH, HASH, NUT_IRQPRI_DEF);
  303. #endif
  304. #if defined(HW_RNG_STM32)
  305. CREATE_HANDLER(RNG, HASH_RNG, NUT_IRQPRI_DEF);
  306. #endif
  307. #if defined(HW_HASH_RNG_STM32)
  308. CREATE_HANDLER(HASH_RNG, HASH_RNG, NUT_IRQPRI_DEF);
  309. #endif
  310. #if defined(HW_CRYP_STM32)
  311. CREATE_HANDLER(CRYP, CRYP, NUT_IRQPRI_DEF);
  312. #endif
  313. #if defined(HW_DCMI_STM32)
  314. CREATE_HANDLER(DCMI, DCMI, NUT_IRQPRI_DEF);
  315. #endif
  316. #if defined(HW_DMA2D_STM32)
  317. CREATE_HANDLER(DMA2D, DMA2D, NUT_IRQPRI_DEF);
  318. #endif
  319. #if defined(HW_LTDC_STM32)
  320. CREATE_HANDLER(LTDC, LTDC, NUT_IRQPRI_DEF);
  321. #endif
  322. #if defined(HW_FSMC_STM32)
  323. CREATE_HANDLER(FSMC, FSMC, NUT_IRQPRI_DEF);
  324. #endif
  325. #if defined(HW_FMC_STM32)
  326. CREATE_HANDLER(FMC, FMC, NUT_IRQPRI_DEF);
  327. #endif
  328. #if defined(HW_COMP1_2_3_STM32)
  329. CREATE_HANDLER(COMP1_2_3, COMP1_2_3, NUT_IRQPRI_DEF);
  330. #endif
  331. #if defined(HW_COMP4_5_6_STM32)
  332. CREATE_HANDLER(COMP4_5_6, COMP4_5_6, NUT_IRQPRI_DEF);
  333. #endif
  334. #if defined(HW_COMP_STM32)
  335. CREATE_HANDLER(COMP, COMP, NUT_IRQPRI_DEF);
  336. #endif
  337. #if defined(HW_COMP_ACQ_STM32)
  338. CREATE_HANDLER(COMP_ACQ, COMP_ACQ, NUT_IRQPRI_DEF);
  339. #endif
  340. #if defined(HW_CEC_STM32)
  341. CREATE_HANDLER(CEC, CEC, NUT_IRQPRI_DEF);
  342. #endif
  343. #if defined( __FPU_PRESENT)
  344. CREATE_HANDLER(FPU, FPU, NUT_IRQPRI_DEF);
  345. #endif