gd32f30x_it.c 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476
  1. /*!
  2. \file gd32f3x0_it.c
  3. \brief interrupt service routines
  4. */
  5. /*
  6. Copyright (C) 2022 GigaDevice
  7. 2022-12-01, V1.0.0, firmware for GD32F3x0
  8. */
  9. /******************************
  10. * Include File
  11. ******************************/
  12. #include "gd32f30x_it.h"
  13. #include "user.h"
  14. #include "TimeTask_Event.h"
  15. #include "syspar.h"
  16. #include "can.h"
  17. #include "FSM_1st.h"
  18. /******************************
  19. * Parameter
  20. ******************************/
  21. extern uint8_t data;
  22. /******************************
  23. * Function
  24. ******************************/
  25. /*!
  26. \brief this function handles NMI exception
  27. \param[in] none
  28. \param[out] none
  29. \retval none
  30. */
  31. void NMI_Handler(void)
  32. {
  33. }
  34. /*!
  35. \brief this function handles HardFault exception
  36. \param[in] none
  37. \param[out] none
  38. \retval none
  39. */
  40. void HardFault_Handler(void)
  41. {
  42. hw_blPWMOnFlg = TRUE;/* HardFault_Handler无法被屏蔽,hw_blPWMOnFlg可能被RAMtest修改 */
  43. hw_voPWMOff();
  44. /* if Hard Fault exception occurs, go to infinite loop */
  45. while (1);
  46. }
  47. /*!
  48. \brief this function handles MemManage exception
  49. \param[in] none
  50. \param[out] none
  51. \retval none
  52. */
  53. void MemManage_Handler(void)
  54. {
  55. /* if Memory Manage exception occurs, go to infinite loop */
  56. while (1);
  57. }
  58. /*!
  59. \brief this function handles BusFault exception
  60. \param[in] none
  61. \param[out] none
  62. \retval none
  63. */
  64. void BusFault_Handler(void)
  65. {
  66. /* if Bus Fault exception occurs, go to infinite loop */
  67. while (1);
  68. }
  69. /*!
  70. \brief this function handles UsageFault exception
  71. \param[in] none
  72. \param[out] none
  73. \retval none
  74. */
  75. void UsageFault_Handler(void)
  76. {
  77. /* if Usage Fault exception occurs, go to infinite loop */
  78. while (1);
  79. }
  80. /*!
  81. \brief this function handles SVC exception
  82. \param[in] none
  83. \param[out] none
  84. \retval none
  85. */
  86. void SVC_Handler(void)
  87. {
  88. }
  89. /*!
  90. \brief this function handles DebugMon exception
  91. \param[in] none
  92. \param[out] none
  93. \retval none
  94. */
  95. void DebugMon_Handler(void)
  96. {
  97. }
  98. /*!
  99. \brief this function handles PendSV exception
  100. \param[in] none
  101. \param[out] none
  102. \retval none
  103. */
  104. void PendSV_Handler(void)
  105. {
  106. }
  107. /*!
  108. \brief this function handles SysTick exception
  109. \param[in] none
  110. \param[out] none
  111. \retval none
  112. */
  113. void SysTick_Handler(void)
  114. {
  115. cp_ulSystickCnt ++;
  116. /* MCU Self Check*/
  117. clas_ubSystickFlg = 1;
  118. stl_voSystickProc();
  119. /* UART Timeout */
  120. UART_voApplTimer();
  121. /* TBT interrupt */
  122. //tbt_voIsr();
  123. }
  124. /*!
  125. \brief
  126. \param[in] none
  127. \param[out] none
  128. \retval none
  129. */
  130. void ADC0_1_IRQHandler(void)
  131. {
  132. clasB_uwADCCnt++;
  133. //GPIO_OCTL(GPIOC) |= 0x0800; //TEST PC11
  134. if (cp_stFlg.CurrentSampleModelSelect == COMBINATION)
  135. {
  136. if (ADC_STAT(ADC0) & ADC_INT_FLAG_EOIC)
  137. {
  138. adc_uwRdsonUReg = ADC_IDATA0(ADC0);
  139. adc_uwRdsonVReg = ADC_IDATA1(ADC0);
  140. adc_uwRdsonWReg = ADC_IDATA2(ADC0);
  141. // adc_disable(ADC0);
  142. // timer_channel_output_pulse_value_config(TIMER0, TIMER_CH_3, pwm_stGenOut.uwSigRTrig);
  143. // adc_interrupt_flag_clear(ADC0 , ADC_INT_FLAG_EOIC);
  144. /* ADC0 disable */
  145. ADC_CTL1(ADC0) &= ~((uint32_t)ADC_CTL1_ADCON);
  146. /* ADC1 trigger set */
  147. TIMER_CH3CV(TIMER0) = (uint32_t) pwm_stGenOut.uwSigRTrig;
  148. /* ADC1 enable */
  149. ADC_CTL1(ADC1) |= (uint32_t)ADC_CTL1_ADCON;
  150. /* ADC0 interrupt flag clear */
  151. ADC_STAT(ADC0) &= ~((uint32_t)ADC_INT_FLAG_EOIC);
  152. }
  153. else if (ADC_STAT(ADC1) & ADC_INT_FLAG_EOIC)
  154. {
  155. if (pwm_stGenOut.blSampleCalibFlag == TRUE)
  156. {
  157. adc_uwADDMAPhase1 = ADC_IDATA0(ADC1);
  158. }
  159. // adc_disable(ADC1);
  160. // adc_interrupt_flag_clear(ADC1 , ADC_INT_FLAG_EOIC);
  161. /* ADC1 disable */
  162. ADC_CTL1(ADC1) &= ~((uint32_t)ADC_CTL1_ADCON);
  163. /* ADC1 interrupt flag clear */
  164. ADC_STAT(ADC1) &= ~((uint32_t)ADC_INT_FLAG_EOIC);
  165. }
  166. else
  167. {
  168. }
  169. }
  170. else
  171. {
  172. }
  173. //GPIO_OCTL(GPIOC) &= ~0x0800; //TEST PC11
  174. }
  175. /*!
  176. \brief
  177. \param[in] none
  178. \param[out] none
  179. \retval none
  180. */
  181. void TIMER0_UP_TIMER9_IRQHandler(void)
  182. {
  183. ULONG OVtimeCnt = 0;
  184. clasB_uwTIM0Cnt ++;
  185. if(cp_stFlg.CurrentSampleModelSelect == COMBINATION)
  186. {
  187. if(TIMER_INTF(TIMER0) & TIMER_INT_FLAG_UP)
  188. {
  189. if((TIMER_CTL0(TIMER0) & TIMER_CTL0_DIR) == 0) // When Counting Up
  190. {
  191. /* TBC Up interrupt */
  192. tbc_voUpIsr();
  193. }
  194. else
  195. {
  196. TIMER_CNT(TIMER6) = 0;
  197. /* TBC Down interrupt */
  198. tbc_voDownIsr();
  199. while ((TIMER_CNT(TIMER6) < HW_PWM_PERIOD) && (OVtimeCnt < 10000))
  200. {
  201. OVtimeCnt++;
  202. };
  203. /* ADC0 trigger set */
  204. TIMER_CH3CV(TIMER0) = (uint32_t) pwm_stGenOut.uwRDSONTrig;
  205. adc_enable(ADC0);
  206. // adc_interrupt_enable(ADC0 , ADC_INT_EOIC);
  207. //adc_external_trigger_config(ADC0, ADC_INSERTED_CHANNEL, ENABLE);
  208. /* Software trigger for regular sampling*/
  209. adc_software_trigger_enable(ADC0, ADC_REGULAR_CHANNEL);
  210. /* Compara value load */
  211. hw_uwPWMCmpr[0] = pwm_stGenOut.uwNewTIM1COMPR[0];
  212. hw_uwPWMCmpr[1] = pwm_stGenOut.uwNewTIM1COMPR[1];
  213. hw_uwPWMCmpr[2] = pwm_stGenOut.uwNewTIM1COMPR[2];
  214. hw_uwPWMCmpr[3] = pwm_stGenOut.uwNewTIM1COMPR[3];
  215. hw_uwPWMCmpr[4] = pwm_stGenOut.uwNewTIM1COMPR[4];
  216. hw_uwPWMCmpr[5] = pwm_stGenOut.uwNewTIM1COMPR[5];
  217. timer_dma_enable(TIMER0,TIMER_DMA_UPD);
  218. dma_channel_enable(DMA0,DMA_CH4);
  219. }
  220. }
  221. //timer_interrupt_flag_clear(TIMER0, TIMER_INT_FLAG_UP);
  222. TIMER_INTF(TIMER0) = (~(uint32_t)TIMER_INT_FLAG_UP);
  223. }
  224. else
  225. {
  226. }
  227. }
  228. /*!
  229. \brief
  230. \param[in] none
  231. \param[out] none
  232. \retval none
  233. */
  234. void TIMER1_IRQHandler(void)
  235. {
  236. UWORD uwIntSource = 0;
  237. clasB_uwTIM1Cnt++;
  238. if (timer_interrupt_flag_get(TIMER1, TIMER_INT_FLAG_UP))
  239. {
  240. if(switch_flg.SysCoef_Flag == TRUE)
  241. {
  242. uwIntSource = 1;
  243. cadence_voCadenceCal(uwIntSource);
  244. bikespeed_voBikeSpeedCal(uwIntSource);
  245. }
  246. timer_interrupt_flag_clear(TIMER1, TIMER_INT_FLAG_UP);
  247. }
  248. else if (timer_interrupt_flag_get(TIMER1, TIMER_INT_FLAG_CH2))
  249. {
  250. if(switch_flg.SysCoef_Flag == TRUE)
  251. {
  252. uwIntSource = 2;
  253. cadence_voCadenceCal(uwIntSource);
  254. if(gpio_input_bit_get(GPIOB, GPIO_PIN_10))
  255. {
  256. /* reset the CH2P and CH2NP bits */
  257. TIMER_CHCTL2(TIMER1) &= (~(uint32_t)(TIMER_CHCTL2_CH2P|TIMER_CHCTL2_CH2NP));
  258. TIMER_CHCTL2(TIMER1) |= (uint32_t)((uint32_t)(TIMER_IC_POLARITY_FALLING) << 8U);
  259. }
  260. else
  261. {
  262. /* reset the CH2P and CH2NP bits */
  263. TIMER_CHCTL2(TIMER1) &= (~(uint32_t)(TIMER_CHCTL2_CH2P|TIMER_CHCTL2_CH2NP));
  264. TIMER_CHCTL2(TIMER1) |= (uint32_t)((uint32_t)(TIMER_IC_POLARITY_RISING) << 8U);
  265. }
  266. }
  267. timer_interrupt_flag_clear(TIMER1, TIMER_INT_FLAG_CH2);
  268. }
  269. else if (timer_interrupt_flag_get(TIMER1, TIMER_INT_FLAG_CH3))
  270. {
  271. if(switch_flg.SysCoef_Flag == TRUE)
  272. {
  273. uwIntSource = 3;
  274. bikespeed_voBikeSpeedCal(uwIntSource);
  275. }
  276. timer_interrupt_flag_clear(TIMER1, TIMER_INT_FLAG_CH3);
  277. }
  278. }
  279. /*!
  280. \brief
  281. \param[in] none
  282. \param[out] none
  283. \retval none
  284. */
  285. void TIMER3_IRQHandler(void)
  286. {
  287. if(timer_interrupt_flag_get(TIMER3, TIMER_INT_FLAG_UP))
  288. {
  289. clasB_uwTIM3Cnt++;
  290. /* TBS interrupt */
  291. tbs_voIsr();
  292. timer_interrupt_flag_clear(TIMER3, TIMER_INT_FLAG_UP);
  293. }
  294. }
  295. /*!
  296. \brief
  297. \param[in] none
  298. \param[out] none
  299. \retval none
  300. */
  301. void TIMER5_IRQHandler(void)
  302. {
  303. if(timer_interrupt_flag_get(TIMER5, TIMER_INT_FLAG_UP))
  304. {
  305. clasB_uwTIM5Cnt++;
  306. TimingTaskTimerServer();
  307. /* Event_1ms interrupt */
  308. Event_1ms();
  309. timer_interrupt_flag_clear(TIMER5, TIMER_INT_FLAG_UP);
  310. }
  311. }
  312. /*!
  313. \brief
  314. \param[in] none
  315. \param[out] none
  316. \retval none
  317. */
  318. void USART0_IRQHandler(void)
  319. {
  320. }
  321. /*!
  322. \brief
  323. \param[in] none
  324. \param[out] none
  325. \retval none
  326. */
  327. void DMA1_Channel2_IRQHandler(void)
  328. {
  329. static UWORD uwTempCount = 0;
  330. /* Read PC Conmand */
  331. if (dma_flag_get(DMA1, DMA_CH2, DMA_INT_FLAG_FTF))
  332. {
  333. UART_voCBDoneRead(UART_ERR_OK, 22);
  334. DMA_CH2CTL(DMA1) &= ~DMA_CHXCTL_CHEN;
  335. //dma_flag_clear(DMA1, DMA_CH2, DMA_INT_FLAG_FTF);
  336. DMA_INTC(DMA1) |= DMA_FLAG_ADD(DMA_INT_FLAG_FTF, DMA_CH2);
  337. uwTempCount = 22 - DMA_CH2CNT(DMA1);
  338. DMA_CH2CNT(DMA1) = uwTempCount;
  339. DMA_CH2CTL(DMA1) |= DMA_CHXCTL_CHEN;
  340. }
  341. /* RX error */
  342. if (dma_flag_get(DMA1, DMA_CH2, DMA_FLAG_ERR))
  343. {
  344. DMA_CH2CTL(DMA1) &= ~DMA_CHXCTL_CHEN;
  345. //dma_flag_clear(DMA1, DMA_CH2, DMA_FLAG_ERR);
  346. DMA_INTC(DMA1) |= DMA_FLAG_ADD(DMA_FLAG_ERR, DMA_CH2);
  347. DMA_CH2CNT(DMA1) = 22;
  348. DMA_CH2CTL(DMA1) |= DMA_CHXCTL_CHEN;
  349. }
  350. }
  351. /*!
  352. \brief
  353. \param[in] none
  354. \param[out] none
  355. \retval none
  356. */
  357. void DMA1_Channel4_IRQHandler(void)
  358. {
  359. if (dma_flag_get(DMA1, DMA_CH4, DMA_INT_FLAG_FTF))
  360. {
  361. if (UART_stParaStatus.bParaStart)
  362. {
  363. UART_bInsertPendTx = FALSE; // clear insertBuffer pending
  364. UART_stParaStatus.bParaStart = FALSE; // clear parameter status
  365. }
  366. else
  367. {
  368. // do nothing
  369. }
  370. DMA_CH4CTL(DMA1) &= ~DMA_CHXCTL_CHEN;
  371. //dma_flag_clear(DMA1, DMA_CH4, DMA_INT_FLAG_FTF);
  372. DMA_INTC(DMA1) |= DMA_FLAG_ADD(DMA_INT_FLAG_FTF, DMA_CH4);
  373. UART_stParaStatus.bWriteBusy = FALSE;
  374. }
  375. /* TX error */
  376. if (dma_flag_get(DMA1, DMA_CH4, DMA_FLAG_ERR))
  377. {
  378. if (UART_stParaStatus.bParaStart)
  379. {
  380. UART_bInsertPendTx = FALSE; // clear insertBuffer pending
  381. UART_stParaStatus.bParaStart = FALSE; // clear parameter status
  382. }
  383. DMA_CH4CTL(DMA1) &= ~DMA_CHXCTL_CHEN;
  384. //dma_flag_clear(DMA1, DMA_CH4, DMA_FLAG_ERR);
  385. DMA_INTC(DMA1) |= DMA_FLAG_ADD(DMA_FLAG_ERR, DMA_CH4);
  386. UART_stParaStatus.bWriteBusy = FALSE;
  387. }
  388. }
  389. /*!
  390. \brief
  391. \param[in] none
  392. \param[out] none
  393. \retval none
  394. */
  395. void CAN0_RX0_IRQHandler(void)
  396. {
  397. can_message_receive(CAN0, CAN_FIFO0, pRxMsg);
  398. if((pRxMsg->rx_ff != CAN_FF_STANDARD) || (pRxMsg->rx_dlen == 0))
  399. {
  400. can_interrupt_enable(CAN0, CAN_INT_RFF0);
  401. return;
  402. }
  403. switch (pRxMsg->rx_sfid)
  404. {
  405. case ID_PBU_BC:
  406. case ID_PBU_TO_MC: //鎺ユ敹PBU鏁版嵁
  407. {
  408. CAN_RxBuf_Struct_PBU.ucBufID = pRxMsg->rx_sfid;
  409. CAN_Rx_ISR(&CAN_RxBuf_Struct_PBU, pRxMsg->rx_dlen);
  410. break;
  411. }
  412. case ID_BMS_BC:
  413. case ID_BMS_TO_MC: //鎺ユ敹BMS鏁版嵁
  414. {
  415. CAN_RxBuf_Struct_BMS.ucBufID = pRxMsg->rx_sfid;
  416. CAN_Rx_ISR(&CAN_RxBuf_Struct_BMS, pRxMsg->rx_dlen);
  417. break;
  418. }
  419. case ID_HMI_BC:
  420. case ID_HMI_TO_MC: //鎺ユ敹HMI鏁版嵁
  421. {
  422. CAN_RxBuf_Struct_HMI.ucBufID = pRxMsg->rx_sfid;
  423. CAN_Rx_ISR(&CAN_RxBuf_Struct_HMI, pRxMsg->rx_dlen);
  424. break;
  425. }
  426. case ID_CDL_BC:
  427. case ID_CDL_TO_MC: // case ID_CDL_TO_MC_TE://鎺ユ敹CDL鏁版嵁
  428. {
  429. CAN_RxBuf_Struct_CDL.ucBufID = pRxMsg->rx_sfid;
  430. CAN_Rx_ISR(&CAN_RxBuf_Struct_CDL, pRxMsg->rx_dlen);
  431. break;
  432. }
  433. default:
  434. break;
  435. }
  436. can_interrupt_enable(CAN0, CAN_INT_RFF0);
  437. }
  438. void CAN0_RX1_IRQHandler(void)
  439. {
  440. }