gd32f30x_it.c 12 KB

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