mc_irqs.c 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189
  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. extern void mc_phase_current_handler(void);
  71. extern void hall_sensor_handler(void);
  72. extern void mc_brake_handler(void);
  73. extern void mc_pwm_up_handler(void);
  74. void ADC0_1_IRQHandler(void)
  75. {
  76. adc_disable_ext_trigger();
  77. mc_phase_current_handler();
  78. //adc_enable_ext_trigger();
  79. /* clear the ADC flag */
  80. adc_clear_irq_flags();
  81. }
  82. void TIMER0_UP_IRQHandler(void) {
  83. if (timer_interrupt_flag_get(TIMER0, TIMER_INT_FLAG_UP)) {
  84. timer_interrupt_flag_clear(TIMER0, TIMER_INT_FLAG_UP);
  85. mc_pwm_up_handler();
  86. }
  87. }
  88. void TIMER0_BRK_IRQHandler(void) {
  89. if (timer_interrupt_flag_get(TIMER0, TIMER_INT_FLAG_BRK)) {
  90. timer_interrupt_flag_clear(TIMER0, TIMER_INT_FLAG_BRK);
  91. mc_brake_handler();
  92. }
  93. }
  94. void TIMER5_IRQHandler(void) {
  95. if (timer_interrupt_flag_get(TIMER5, TIMER_INT_FLAG_UP)) {
  96. timer_interrupt_flag_clear(TIMER5, TIMER_INT_FLAG_UP);
  97. }
  98. }
  99. #ifdef GD32_FOC_DEMO
  100. void EXTI0_IRQHandler(void)
  101. {
  102. if(RESET != exti_interrupt_flag_get(EXTI_0)){
  103. exti_interrupt_flag_clear(EXTI_0);
  104. hall_sensor_handler();
  105. }
  106. }
  107. #endif
  108. void EXTI2_IRQHandler(void)
  109. {
  110. if(RESET != exti_interrupt_flag_get(EXTI_2)){
  111. exti_interrupt_flag_clear(EXTI_2);
  112. }
  113. }
  114. void EXTI3_IRQHandler(void)
  115. {
  116. if(RESET != exti_interrupt_flag_get(EXTI_3)){
  117. exti_interrupt_flag_clear(EXTI_3);
  118. }
  119. }
  120. void EXTI4_IRQHandler(void)
  121. {
  122. if(RESET != exti_interrupt_flag_get(EXTI_4)){
  123. exti_interrupt_flag_clear(EXTI_4);
  124. mc_brake_handler();
  125. }
  126. }
  127. void EXTI5_9_IRQHandler(void){
  128. if(RESET != exti_interrupt_flag_get(EXTI_5)){
  129. exti_interrupt_flag_clear(EXTI_5);
  130. mc_brake_handler();
  131. }
  132. if(RESET != exti_interrupt_flag_get(EXTI_6)){
  133. exti_interrupt_flag_clear(EXTI_6);
  134. hall_sensor_handler();
  135. }
  136. if(RESET != exti_interrupt_flag_get(EXTI_7)){
  137. exti_interrupt_flag_clear(EXTI_7);
  138. hall_sensor_handler();
  139. }
  140. if(RESET != exti_interrupt_flag_get(EXTI_8)){
  141. exti_interrupt_flag_clear(EXTI_8);
  142. #ifndef GD32_FOC_DEMO
  143. hall_sensor_handler();
  144. #endif
  145. }
  146. if(RESET != exti_interrupt_flag_get(EXTI_9)){
  147. exti_interrupt_flag_clear(EXTI_9);
  148. }
  149. }
  150. void EXTI10_15_IRQHandler(void){
  151. if(RESET != exti_interrupt_flag_get(EXTI_10)){
  152. exti_interrupt_flag_clear(EXTI_10);
  153. }
  154. if(RESET != exti_interrupt_flag_get(EXTI_11)){
  155. exti_interrupt_flag_clear(EXTI_11);
  156. }
  157. if(RESET != exti_interrupt_flag_get(EXTI_12)){
  158. exti_interrupt_flag_clear(EXTI_12);
  159. }
  160. if(RESET != exti_interrupt_flag_get(EXTI_13)){
  161. exti_interrupt_flag_clear(EXTI_13);
  162. }
  163. if(RESET != exti_interrupt_flag_get(EXTI_14)){
  164. exti_interrupt_flag_clear(EXTI_14);
  165. }
  166. if(RESET != exti_interrupt_flag_get(EXTI_15)){
  167. exti_interrupt_flag_clear(EXTI_15);
  168. }
  169. }