mc_irqs.c 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217
  1. #include <stdbool.h>
  2. #include "bsp.h"
  3. #include "adc.h"
  4. /*!
  5. \brief this function handles NMI exception
  6. \param[in] none
  7. \param[out] none
  8. \retval none
  9. */
  10. void NMI_Handler(void)
  11. {
  12. }
  13. /*!
  14. \brief this function handles HardFault exception
  15. \param[in] none
  16. \param[out] none
  17. \retval none
  18. */
  19. __asm void HardFault_Handler(void){
  20. IMPORT fault_backtrace
  21. mov r0, lr ; get lr
  22. mov r1, sp ; get stack pointer (current is MSP)
  23. bl fault_backtrace
  24. }
  25. /*!
  26. \brief this function handles MemManage exception
  27. \param[in] none
  28. \param[out] none
  29. \retval none
  30. */
  31. void MemManage_Handler(void)
  32. {
  33. /* if Memory Manage exception occurs, go to infinite loop */
  34. while (1){
  35. }
  36. }
  37. /*!
  38. \brief this function handles BusFault exception
  39. \param[in] none
  40. \param[out] none
  41. \retval none
  42. */
  43. void BusFault_Handler(void)
  44. {
  45. /* if Bus Fault exception occurs, go to infinite loop */
  46. while (1){
  47. }
  48. }
  49. /*!
  50. \brief this function handles UsageFault exception
  51. \param[in] none
  52. \param[out] none
  53. \retval none
  54. */
  55. void UsageFault_Handler(void)
  56. {
  57. /* if Usage Fault exception occurs, go to infinite loop */
  58. while (1){
  59. }
  60. }
  61. /*!
  62. \brief this function handles DebugMon exception
  63. \param[in] none
  64. \param[out] none
  65. \retval none
  66. */
  67. void DebugMon_Handler(void)
  68. {
  69. }
  70. __weak void MC_Brake_IRQHandler(void) {
  71. }
  72. __weak void MC_Protect_IRQHandler(void) {
  73. }
  74. __weak void TIMER_UP_IRQHandler(void) {
  75. }
  76. __weak void ADC_IRQHandler(void) {
  77. }
  78. __weak void HALL_IRQHandler(void) {
  79. }
  80. __weak void ABI_I_IRQHandler(void) {
  81. }
  82. __weak void Fan_IRQHandler(int idx) {
  83. }
  84. void ADC0_1_IRQHandler(void)
  85. {
  86. ADC_IRQHandler();
  87. adc_clear_irq_flags();
  88. }
  89. void TIMER0_UP_IRQHandler(void) {
  90. if (timer_interrupt_flag_get(TIMER0, TIMER_INT_FLAG_UP)) {
  91. timer_interrupt_flag_clear(TIMER0, TIMER_INT_FLAG_UP);
  92. TIMER_UP_IRQHandler();
  93. }
  94. }
  95. void TIMER0_BRK_IRQHandler(void) {
  96. if (timer_interrupt_flag_get(TIMER0, TIMER_INT_FLAG_BRK)) {
  97. timer_interrupt_flag_clear(TIMER0, TIMER_INT_FLAG_BRK);
  98. MC_Protect_IRQHandler();
  99. }
  100. }
  101. void EXTI0_IRQHandler(void)
  102. {
  103. if(RESET != exti_interrupt_flag_get(EXTI_0)){
  104. exti_interrupt_flag_clear(EXTI_0);
  105. #if (ENC_I_EXTI == EXTI_0)
  106. ABI_I_IRQHandler();
  107. #elif defined (USE_ENCODER_HALL)
  108. HALL_IRQHandler();
  109. #else
  110. #error "Postion sensor ERROR"
  111. #endif
  112. }
  113. }
  114. void EXTI2_IRQHandler(void)
  115. {
  116. if(RESET != exti_interrupt_flag_get(EXTI_2)){
  117. exti_interrupt_flag_clear(EXTI_2);
  118. #if (GPIO_BRAKE1_EXTI == EXTI_2)
  119. MC_Brake_IRQHandler();
  120. #endif
  121. }
  122. }
  123. void EXTI3_IRQHandler(void)
  124. {
  125. if(RESET != exti_interrupt_flag_get(EXTI_3)){
  126. exti_interrupt_flag_clear(EXTI_3);
  127. #if (GPIO_BRAKE_EXTI == EXTI_3)
  128. MC_Brake_IRQHandler();
  129. #endif
  130. }
  131. }
  132. void EXTI4_IRQHandler(void)
  133. {
  134. if(RESET != exti_interrupt_flag_get(EXTI_4)){
  135. exti_interrupt_flag_clear(EXTI_4);
  136. //MC_Brake_IRQHandler();
  137. }
  138. }
  139. void EXTI5_9_IRQHandler(void){
  140. if(RESET != exti_interrupt_flag_get(EXTI_5)){
  141. exti_interrupt_flag_clear(EXTI_5);
  142. }
  143. if(RESET != exti_interrupt_flag_get(EXTI_6)){
  144. exti_interrupt_flag_clear(EXTI_6);
  145. #if (ENC_I_EXTI == EXTI_6)
  146. ABI_I_IRQHandler();
  147. #endif
  148. }
  149. if(RESET != exti_interrupt_flag_get(EXTI_7)){
  150. exti_interrupt_flag_clear(EXTI_7);
  151. }
  152. if(RESET != exti_interrupt_flag_get(EXTI_8)){
  153. exti_interrupt_flag_clear(EXTI_8);
  154. #if (ENC_I_EXTI == EXTI_8)
  155. ABI_I_IRQHandler();
  156. #endif
  157. }
  158. if(RESET != exti_interrupt_flag_get(EXTI_9)){
  159. exti_interrupt_flag_clear(EXTI_9);
  160. }
  161. }
  162. void EXTI10_15_IRQHandler(void){
  163. if(RESET != exti_interrupt_flag_get(EXTI_10)){
  164. exti_interrupt_flag_clear(EXTI_10);
  165. #if (GPIO_FAN1_EXTI==EXTI_10)
  166. Fan_IRQHandler(0);
  167. #endif
  168. }
  169. if(RESET != exti_interrupt_flag_get(EXTI_11)){
  170. exti_interrupt_flag_clear(EXTI_11);
  171. #if (GPIO_FAN1_EXTI==EXTI_11)
  172. Fan_IRQHandler(0);
  173. #elif (GPIO_FAN2_EXTI==EXTI_11)
  174. Fan_IRQHandler(1);
  175. #endif
  176. }
  177. if(RESET != exti_interrupt_flag_get(EXTI_12)){
  178. exti_interrupt_flag_clear(EXTI_12);
  179. }
  180. if(RESET != exti_interrupt_flag_get(EXTI_13)){
  181. exti_interrupt_flag_clear(EXTI_13);
  182. }
  183. if(RESET != exti_interrupt_flag_get(EXTI_14)){
  184. exti_interrupt_flag_clear(EXTI_14);
  185. }
  186. if(RESET != exti_interrupt_flag_get(EXTI_15)){
  187. exti_interrupt_flag_clear(EXTI_15);
  188. }
  189. }