mc_irqs.c 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202
  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. void ADC0_1_IRQHandler(void)
  83. {
  84. ADC_IRQHandler();
  85. adc_clear_irq_flags();
  86. }
  87. void TIMER0_UP_IRQHandler(void) {
  88. if (timer_interrupt_flag_get(TIMER0, TIMER_INT_FLAG_UP)) {
  89. timer_interrupt_flag_clear(TIMER0, TIMER_INT_FLAG_UP);
  90. TIMER_UP_IRQHandler();
  91. }
  92. }
  93. void TIMER0_BRK_IRQHandler(void) {
  94. if (timer_interrupt_flag_get(TIMER0, TIMER_INT_FLAG_BRK)) {
  95. timer_interrupt_flag_clear(TIMER0, TIMER_INT_FLAG_BRK);
  96. MC_Protect_IRQHandler();
  97. }
  98. }
  99. void EXTI0_IRQHandler(void)
  100. {
  101. if(RESET != exti_interrupt_flag_get(EXTI_0)){
  102. exti_interrupt_flag_clear(EXTI_0);
  103. #if (ENC_I_EXTI == EXTI_0)
  104. ABI_I_IRQHandler();
  105. #elif defined (USE_ENCODER_HALL)
  106. HALL_IRQHandler();
  107. #else
  108. #error "Postion sensor ERROR"
  109. #endif
  110. }
  111. }
  112. void EXTI2_IRQHandler(void)
  113. {
  114. if(RESET != exti_interrupt_flag_get(EXTI_2)){
  115. exti_interrupt_flag_clear(EXTI_2);
  116. #if (GPIO_BRAKE_EXTI == EXTI_2)
  117. MC_Brake_IRQHandler();
  118. #endif
  119. }
  120. }
  121. void EXTI3_IRQHandler(void)
  122. {
  123. if(RESET != exti_interrupt_flag_get(EXTI_3)){
  124. exti_interrupt_flag_clear(EXTI_3);
  125. }
  126. }
  127. void EXTI4_IRQHandler(void)
  128. {
  129. if(RESET != exti_interrupt_flag_get(EXTI_4)){
  130. exti_interrupt_flag_clear(EXTI_4);
  131. MC_Brake_IRQHandler();
  132. }
  133. }
  134. void EXTI5_9_IRQHandler(void){
  135. if(RESET != exti_interrupt_flag_get(EXTI_5)){
  136. exti_interrupt_flag_clear(EXTI_5);
  137. MC_Brake_IRQHandler();
  138. }
  139. if(RESET != exti_interrupt_flag_get(EXTI_6)){
  140. exti_interrupt_flag_clear(EXTI_6);
  141. HALL_IRQHandler();
  142. }
  143. if(RESET != exti_interrupt_flag_get(EXTI_7)){
  144. exti_interrupt_flag_clear(EXTI_7);
  145. HALL_IRQHandler();
  146. }
  147. if(RESET != exti_interrupt_flag_get(EXTI_8)){
  148. exti_interrupt_flag_clear(EXTI_8);
  149. #if (ENC_I_EXTI == EXTI_8)
  150. ABI_I_IRQHandler();
  151. #endif
  152. }
  153. if(RESET != exti_interrupt_flag_get(EXTI_9)){
  154. exti_interrupt_flag_clear(EXTI_9);
  155. }
  156. }
  157. void EXTI10_15_IRQHandler(void){
  158. if(RESET != exti_interrupt_flag_get(EXTI_10)){
  159. exti_interrupt_flag_clear(EXTI_10);
  160. }
  161. if(RESET != exti_interrupt_flag_get(EXTI_11)){
  162. exti_interrupt_flag_clear(EXTI_11);
  163. }
  164. if(RESET != exti_interrupt_flag_get(EXTI_12)){
  165. exti_interrupt_flag_clear(EXTI_12);
  166. }
  167. if(RESET != exti_interrupt_flag_get(EXTI_13)){
  168. exti_interrupt_flag_clear(EXTI_13);
  169. }
  170. if(RESET != exti_interrupt_flag_get(EXTI_14)){
  171. exti_interrupt_flag_clear(EXTI_14);
  172. }
  173. if(RESET != exti_interrupt_flag_get(EXTI_15)){
  174. exti_interrupt_flag_clear(EXTI_15);
  175. }
  176. }