123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614 |
- /*!
- \file gd32f3x0_it.c
- \brief interrupt service routines
- */
- /*
- Copyright (C) 2017 GigaDevice
- 2017-06-06, V1.0.0, firmware for GD32F3x0
- */
- #include "gd32f30x_it.h"
- #include "user.h"
- #include "TimeTask_Event.h"
- #include "syspar.h"
- #include "can.h"
- extern uint8_t data;
- /*!
- \brief this function handles NMI exception
- \param[in] none
- \param[out] none
- \retval none
- */
- void NMI_Handler(void)
- {
- }
- /*!
- \brief this function handles HardFault exception
- \param[in] none
- \param[out] none
- \retval none
- */
- void HardFault_Handler(void)
- {
- hw_blPWMOnFlg = TRUE;/* HardFault_Handler无法被屏蔽,hw_blPWMOnFlg可能被RAMtest修改 */
- hw_voPWMOff();
- /* if Hard Fault exception occurs, go to infinite loop */
- while (1);
- }
- /*!
- \brief this function handles MemManage exception
- \param[in] none
- \param[out] none
- \retval none
- */
- void MemManage_Handler(void)
- {
- /* if Memory Manage exception occurs, go to infinite loop */
- while (1);
- }
- /*!
- \brief this function handles BusFault exception
- \param[in] none
- \param[out] none
- \retval none
- */
- void BusFault_Handler(void)
- {
- /* if Bus Fault exception occurs, go to infinite loop */
- while (1);
- }
- /*!
- \brief this function handles UsageFault exception
- \param[in] none
- \param[out] none
- \retval none
- */
- void UsageFault_Handler(void)
- {
- /* if Usage Fault exception occurs, go to infinite loop */
- while (1);
- }
- /*!
- \brief this function handles SVC exception
- \param[in] none
- \param[out] none
- \retval none
- */
- void SVC_Handler(void)
- {
- }
- /*!
- \brief this function handles DebugMon exception
- \param[in] none
- \param[out] none
- \retval none
- */
- void DebugMon_Handler(void)
- {
- }
- /*!
- \brief this function handles PendSV exception
- \param[in] none
- \param[out] none
- \retval none
- */
- void PendSV_Handler(void)
- {
- }
- /*!
- \brief this function handles SysTick exception
- \param[in] none
- \param[out] none
- \retval none
- */
- void SysTick_Handler(void)
- {
- /* Add your code below */
-
- clas_ubSystickFlg = 1; // for TUV
- cp_ulSystickCnt ++;
- stl_voSystickProc();
- /* TBT interrupt */
- tbt_voIsr();
- /* UART Timeout */
- UART_voApplTimer();
- }
- /*!
- \brief
- \param[in] none
- \param[out] none
- \retval none
- */
- void ADC0_1_IRQHandler(void)
- {
- clasB_uwADCCnt++;
-
- if(cp_stFlg.CurrentSampleModelSelect == SINGLERESISITANCE)
- {
- static UWORD SampleTrigCount = 0;
-
- if (adc_flag_get(ADC1 , ADC_INT_FLAG_EOIC))
- {
- switch (SampleTrigCount)
- {
- /* Get the first current sample and set the sencond Trig time*/
- case 0:
- SampleTrigCount = 1;
- adc_uwADDMAPhase1 = ADC_IDATA0(ADC1);
- timer_channel_output_pulse_value_config(TIMER0, TIMER_CH_3, pwm_stGenOut.uwSecondTrigCOMPR);
- break;
- /* Get the second current sample and set the first Trig time*/
- case 1:
- SampleTrigCount = 0;
- adc_uwADDMAPhase2 = ADC_IDATA0(ADC1);
-
- adc_disable(ADC1);
- //ADC_StopInjectedConversion(ADC2);
- break;
- default:
- SampleTrigCount = 0;
- break;
- }
- /* Clear the ADC interrupt flag */
- adc_interrupt_flag_clear(ADC1 , ADC_INT_FLAG_EOIC);
- }
- }
- else if(cp_stFlg.CurrentSampleModelSelect == RDSON)
- {
- if (adc_flag_get(ADC0, ADC_INT_FLAG_EOIC))
- {
- if ((TIMER_CTL0(TIMER0) & TIMER_CTL0_DIR) == 0)
- {
- adc_uwRdsonUReg = ADC_IDATA0(ADC0);
- adc_uwRdsonVReg = ADC_IDATA1(ADC0);
- adc_uwRdsonWReg = ADC_IDATA2(ADC0);
- timer_channel_output_pulse_value_config(TIMER0, TIMER_CH_3, pwm_stGenOut.uwRDSONTrig);
- }
- adc_interrupt_flag_clear(ADC0 , ADC_INT_FLAG_EOIC);
- }
- }
- else if(cp_stFlg.CurrentSampleModelSelect == COMBINATION)
- {
- if (adc_flag_get(ADC0, ADC_INT_FLAG_EOIC))
- {
- //GPIO_OCTL(GPIOC) |= 0x0800; //TEST PC10
-
- if ((TIMER_CTL0(TIMER0) & TIMER_CTL0_DIR) == 0)
- {
- adc_uwRdsonUReg = ADC_IDATA0(ADC0);
- adc_uwRdsonVReg = ADC_IDATA1(ADC0);
- adc_uwRdsonWReg = ADC_IDATA2(ADC0);
- /* CH3 set to Frozen */
- TIMER_CHCTL1(TIMER0) &= ~0x7000;
- /* CH3 set to PWMMODE0 */
- TIMER_CHCTL1(TIMER0) |= 0x6000;
-
-
- }
-
- adc_interrupt_flag_clear(ADC0 , ADC_INT_FLAG_EOIC);
-
- //GPIO_OCTL(GPIOC) &= ~0x0800; //TEST PC10
- }
- if (adc_flag_get(ADC1, ADC_INT_FLAG_EOIC))
- {
- //GPIO_OCTL(GPIOC) |= 0x0400; //TEST PC11
-
- if ((TIMER_CTL0(TIMER0) & TIMER_CTL0_DIR) != 0)
- {
- if (pwm_stGenOut.blSampleCalibFlag == TRUE)
- {
- adc_uwADDMAPhase1 = ADC_IDATA0(ADC1);
- }
- /* CH3 set to Frozen */
- TIMER_CHCTL1(TIMER0) &= ~0x7000;
- /* CH3 set to PWMMODE0 */
- TIMER_CHCTL1(TIMER0) |= 0x7000;
-
- adc_disable(ADC1);
-
- }
-
- adc_interrupt_flag_clear(ADC1 , ADC_INT_FLAG_EOIC);
-
- //GPIO_OCTL(GPIOC) &= ~0x0400; //TEST PC11
- }
- }
- else
- {}
- }
- /*!
- \brief
- \param[in] none
- \param[out] none
- \retval none
- */
- UWORD tst_DMAStartCt = 0;
- UWORD tst_DMAStartFlag = 0;
- UWORD tmpSigTrigZ1 = 500;
- void TIMER0_UP_TIMER9_IRQHandler(void)
- {
- ///////////////
- clasB_uwTIM0Cnt ++;
-
- if(cp_stFlg.CurrentSampleModelSelect == SINGLERESISITANCE)
- {
- ULONG OVtimeCnt = 0;
- if(timer_interrupt_flag_get(TIMER0, TIMER_INT_FLAG_UP))
- {
- if((TIMER_CTL0(TIMER0) & TIMER_CTL0_DIR) == 0) // When Counting Up
- {
- /*Resolver lock data*/
- spi_voResolverLock();
- timer_channel_output_pulse_value_config(TIMER0, TIMER_CH_3, pwm_stGenOut.uwFirstTrigCOMPR);
- /* TBC Up interrupt */
- tbc_voUpIsr();
- }
- else
- {
- TIMER_CNT(TIMER6) = 0;
- /* TBC Down interrupt */
- tbc_voDownIsr();
- while ((TIMER_CNT(TIMER6) < HW_PWM_PERIOD) && (OVtimeCnt < HW_HHPWM_PERIOD * FPWM_HZ))
- {
- OVtimeCnt++;
- };
-
- // ADC_StartInjectedConversion(ADC2);
- // ADC_StartConversion(ADC1);
- // ADC_StartConversion(ADC2);
- adc_enable(ADC1);
- adc_software_trigger_enable(ADC0, ADC_REGULAR_CHANNEL);
-
- /* Compara value load */
- hw_uwPWMCmpr[0] = pwm_stGenOut.uwNewTIM1COMPR[0];
- hw_uwPWMCmpr[1] = pwm_stGenOut.uwNewTIM1COMPR[1];
- hw_uwPWMCmpr[2] = pwm_stGenOut.uwNewTIM1COMPR[2];
- hw_uwPWMCmpr[3] = pwm_stGenOut.uwNewTIM1COMPR[3];
- hw_uwPWMCmpr[4] = pwm_stGenOut.uwNewTIM1COMPR[4];
- hw_uwPWMCmpr[5] = pwm_stGenOut.uwNewTIM1COMPR[5];
-
- timer_dma_enable(TIMER0,TIMER_DMA_UPD);
- dma_channel_enable(DMA0,DMA_CH4);
-
- }
- timer_interrupt_flag_clear(TIMER0, TIMER_INT_FLAG_UP);
- }
- }
- if(cp_stFlg.CurrentSampleModelSelect == RDSON)
- {
- ULONG OVtimeCnt = 0;
- if(timer_interrupt_flag_get(TIMER0, TIMER_INT_FLAG_UP))
- {
- if((TIMER_CTL0(TIMER0) & TIMER_CTL0_DIR) == 0) // When Counting Up
- {
- /*Resolver lock data*/
- spi_voResolverLock();
- adc_software_trigger_enable(ADC0, ADC_REGULAR_CHANNEL);
- tbc_voUpIsr();
-
- }
- else
- {
- TIMER_CNT(TIMER6) = 0;
- /* TBC Down interrupt */
- tbc_voDownIsr();
- while ((TIMER_CNT(TIMER6) < HW_PWM_PERIOD) && (OVtimeCnt < HW_HHPWM_PERIOD * FPWM_HZ))
- {
- OVtimeCnt++;
- };
- timer_channel_output_pulse_value_config(TIMER0, TIMER_CH_3, pwm_stGenOut.uwRDSONTrig);
-
-
- /* Compara value load */
- hw_uwPWMCmpr[0] = pwm_stGenOut.uwNewTIM1COMPR[0];
- hw_uwPWMCmpr[1] = pwm_stGenOut.uwNewTIM1COMPR[1];
- hw_uwPWMCmpr[2] = pwm_stGenOut.uwNewTIM1COMPR[2];
- hw_uwPWMCmpr[3] = pwm_stGenOut.uwNewTIM1COMPR[3];
- hw_uwPWMCmpr[4] = pwm_stGenOut.uwNewTIM1COMPR[4];
- hw_uwPWMCmpr[5] = pwm_stGenOut.uwNewTIM1COMPR[5];
-
- timer_dma_enable(TIMER0,TIMER_DMA_UPD);
- dma_channel_enable(DMA0,DMA_CH4);
- }
- }
- timer_interrupt_flag_clear(TIMER0, TIMER_INT_FLAG_UP);
- }
- if(cp_stFlg.CurrentSampleModelSelect == COMBINATION)
- {
- ULONG OVtimeCnt = 0;
- if(timer_interrupt_flag_get(TIMER0, TIMER_INT_FLAG_UP))
- {
-
- if((TIMER_CTL0(TIMER0) & TIMER_CTL0_DIR) == 0) // When Counting Up
- {
- adc_enable(ADC0);
- // adc_interrupt_enable(ADC0 , ADC_INT_EOIC);
- //adc_external_trigger_config(ADC0, ADC_INSERTED_CHANNEL, ENABLE);
-
- /* Software trigger for regular sampling*/
- adc_software_trigger_enable(ADC0, ADC_REGULAR_CHANNEL);
-
- timer_channel_output_pulse_value_config(TIMER0, TIMER_CH_3, pwm_stGenOut.uwRDSONTrig);
- /* TBC Up interrupt */
- tbc_voUpIsr();
- }
- else
- {
- adc_disable(ADC0);
- //adc_interrupt_disable(ADC0 , ADC_INT_EOIC);
- //adc_external_trigger_config(ADC0, ADC_INSERTED_CHANNEL, DISABLE);
-
-
-
-
- TIMER_CNT(TIMER6) = 0;
-
- /* TBC Down interrupt */
- tbc_voDownIsr();
-
- while ((TIMER_CNT(TIMER6) < HW_PWM_PERIOD) && (OVtimeCnt < HW_HHPWM_PERIOD * FPWM_HZ))
- {
- OVtimeCnt++;
- };
-
- /* ADC1 trigger for Ibus sampling*/
- adc_enable(ADC1);
- timer_channel_output_pulse_value_config(TIMER0, TIMER_CH_3, tmpSigTrigZ1);
- tmpSigTrigZ1 = pwm_stGenOut.uwSigRTrig;
- /* Compara value load */
- hw_uwPWMCmpr[0] = pwm_stGenOut.uwNewTIM1COMPR[0];
- hw_uwPWMCmpr[1] = pwm_stGenOut.uwNewTIM1COMPR[1];
- hw_uwPWMCmpr[2] = pwm_stGenOut.uwNewTIM1COMPR[2];
- hw_uwPWMCmpr[3] = pwm_stGenOut.uwNewTIM1COMPR[3];
- hw_uwPWMCmpr[4] = pwm_stGenOut.uwNewTIM1COMPR[4];
- hw_uwPWMCmpr[5] = pwm_stGenOut.uwNewTIM1COMPR[5];
- timer_dma_enable(TIMER0,TIMER_DMA_UPD);
- dma_channel_enable(DMA0,DMA_CH4);
- }
- }
- timer_interrupt_flag_clear(TIMER0, TIMER_INT_FLAG_UP);
- }
- else
- {
- }
-
- }
- /*!
- \brief
- \param[in] none
- \param[out] none
- \retval none
- */
- void TIMER1_IRQHandler(void)
- {
- UWORD uwIntSource = 0;
- clasB_uwTIM1Cnt++;
- if (timer_interrupt_flag_get(TIMER1, TIMER_INT_FLAG_UP))
- {
- uwIntSource = 1;
- cadence_voCadenceCal(uwIntSource);
- bikespeed_voBikeSpeedCal(uwIntSource);
- timer_interrupt_flag_clear(TIMER1, TIMER_INT_FLAG_UP);
- }
- else if (timer_interrupt_flag_get(TIMER1, TIMER_INT_FLAG_CH2))
- {
- uwIntSource = 2;
- cadence_voCadenceCal(uwIntSource);
- if(gpio_input_bit_get(GPIOB, GPIO_PIN_10))
- {
- /* reset the CH2P and CH2NP bits */
- TIMER_CHCTL2(TIMER1) &= (~(uint32_t)(TIMER_CHCTL2_CH2P|TIMER_CHCTL2_CH2NP));
- TIMER_CHCTL2(TIMER1) |= (uint32_t)((uint32_t)(TIMER_IC_POLARITY_FALLING) << 8U);
- }
- else
- {
- /* reset the CH2P and CH2NP bits */
- TIMER_CHCTL2(TIMER1) &= (~(uint32_t)(TIMER_CHCTL2_CH2P|TIMER_CHCTL2_CH2NP));
- TIMER_CHCTL2(TIMER1) |= (uint32_t)((uint32_t)(TIMER_IC_POLARITY_RISING) << 8U);
- }
-
- timer_interrupt_flag_clear(TIMER1, TIMER_INT_FLAG_CH2);
- }
- else if (timer_interrupt_flag_get(TIMER1, TIMER_INT_FLAG_CH3))
- {
- uwIntSource = 3;
- bikespeed_voBikeSpeedCal(uwIntSource);
- timer_interrupt_flag_clear(TIMER1, TIMER_INT_FLAG_CH3);
- }
- }
- /*!
- \brief
- \param[in] none
- \param[out] none
- \retval none
- */
- void TIMER3_IRQHandler(void)
- {
-
- if(timer_interrupt_flag_get(TIMER3, TIMER_INT_FLAG_UP))
- {
- clasB_uwTIM3Cnt++;
- /* TBS interrupt */
- tbs_voIsr();
- timer_interrupt_flag_clear(TIMER3, TIMER_INT_FLAG_UP);
- }
- }
- /*!
- \brief
- \param[in] none
- \param[out] none
- \retval none
- */
- void TIMER5_IRQHandler(void)
- {
- if(timer_interrupt_flag_get(TIMER5, TIMER_INT_FLAG_UP))
- {
- clasB_uwTIM5Cnt++;
- TimingTaskTimerServer();
- /* Event_1ms interrupt */
- Event_1ms();
- timer_interrupt_flag_clear(TIMER5, TIMER_INT_FLAG_UP);
- }
- }
- /*!
- \brief
- \param[in] none
- \param[out] none
- \retval none
- */
- void USART0_IRQHandler(void)
- {
- }
- /*!
- \brief
- \param[in] none
- \param[out] none
- \retval none
- */
- void DMA1_Channel2_IRQHandler(void)
- {
- static UWORD uwTempCount = 0;
- // Read PC Conmand
- if (dma_flag_get(DMA1, DMA_CH2, DMA_INT_FLAG_FTF))
- {
- UART_voCBDoneRead(UART_ERR_OK, 22);
- DMA_CH2CTL(DMA1) &= ~DMA_CHXCTL_CHEN;
- //dma_flag_clear(DMA1, DMA_CH2, DMA_INT_FLAG_FTF);
- DMA_INTC(DMA1) |= DMA_FLAG_ADD(DMA_INT_FLAG_FTF, DMA_CH2);
- uwTempCount = 22 - DMA_CH2CNT(DMA1);
- DMA_CH2CNT(DMA1) = uwTempCount;
- DMA_CH2CTL(DMA1) |= DMA_CHXCTL_CHEN;
- }
- // RX error
- if (dma_flag_get(DMA1, DMA_CH2, DMA_FLAG_ERR))
- {
- DMA_CH2CTL(DMA1) &= ~DMA_CHXCTL_CHEN;
- //dma_flag_clear(DMA1, DMA_CH2, DMA_FLAG_ERR);
- DMA_INTC(DMA1) |= DMA_FLAG_ADD(DMA_FLAG_ERR, DMA_CH2);
- DMA_CH2CNT(DMA1) = 22;
- DMA_CH2CTL(DMA1) |= DMA_CHXCTL_CHEN;
- }
- }
- /*!
- \brief
- \param[in] none
- \param[out] none
- \retval none
- */
- void DMA1_Channel4_IRQHandler(void)
- {
- if (dma_flag_get(DMA1, DMA_CH4, DMA_INT_FLAG_FTF))
- {
- if (UART_stParaStatus.bParaStart)
- {
- UART_bInsertPendTx = FALSE; // clear insertBuffer pending
- UART_stParaStatus.bParaStart = FALSE; // clear parameter status
- }
- else
- {
- // do nothing
- }
- DMA_CH4CTL(DMA1) &= ~DMA_CHXCTL_CHEN;
- //dma_flag_clear(DMA1, DMA_CH4, DMA_INT_FLAG_FTF);
- DMA_INTC(DMA1) |= DMA_FLAG_ADD(DMA_INT_FLAG_FTF, DMA_CH4);
- UART_stParaStatus.bWriteBusy = FALSE;
- }
- // TX error
- if (dma_flag_get(DMA1, DMA_CH4, DMA_FLAG_ERR))
- {
- if (UART_stParaStatus.bParaStart)
- {
- UART_bInsertPendTx = FALSE; // clear insertBuffer pending
- UART_stParaStatus.bParaStart = FALSE; // clear parameter status
- }
- DMA_CH4CTL(DMA1) &= ~DMA_CHXCTL_CHEN;
- //dma_flag_clear(DMA1, DMA_CH4, DMA_FLAG_ERR);
- DMA_INTC(DMA1) |= DMA_FLAG_ADD(DMA_FLAG_ERR, DMA_CH4);
- UART_stParaStatus.bWriteBusy = FALSE;
- }
- }
- /*!
- \brief
- \param[in] none
- \param[out] none
- \retval none
- */
- UWORD uwCnts = 0;
- void CAN0_RX0_IRQHandler(void)
- {
- can_message_receive(CAN0, CAN_FIFO0, pRxMsg);
- if((pRxMsg->rx_ff != CAN_FF_STANDARD) || (pRxMsg->rx_dlen == 0))
- {
- can_interrupt_enable(CAN0, CAN_INT_RFF0);
- return;
- }
-
- switch (pRxMsg->rx_sfid)
- {
- case ID_PBU_BC:
- case ID_PBU_TO_MC: //鎺ユ敹PBU鏁版嵁
- {
- CAN_RxBuf_Struct_PBU.ucBufID = pRxMsg->rx_sfid;
- CAN_Rx_ISR(&CAN_RxBuf_Struct_PBU, pRxMsg->rx_dlen);
- break;
- }
- case ID_BMS_BC:
- case ID_BMS_TO_MC: //鎺ユ敹BMS鏁版嵁
- {
- CAN_RxBuf_Struct_BMS.ucBufID = pRxMsg->rx_sfid;
- CAN_Rx_ISR(&CAN_RxBuf_Struct_BMS, pRxMsg->rx_dlen);
- break;
- }
- case ID_HMI_BC:
- case ID_HMI_TO_MC: //鎺ユ敹HMI鏁版嵁
- {
- CAN_RxBuf_Struct_HMI.ucBufID = pRxMsg->rx_sfid;
- CAN_Rx_ISR(&CAN_RxBuf_Struct_HMI, pRxMsg->rx_dlen);
- break;
- }
- case ID_CDL_BC:
- case ID_CDL_TO_MC: // case ID_CDL_TO_MC_TE://鎺ユ敹CDL鏁版嵁
- {
- CAN_RxBuf_Struct_CDL.ucBufID = pRxMsg->rx_sfid;
- CAN_Rx_ISR(&CAN_RxBuf_Struct_CDL, pRxMsg->rx_dlen);
- break;
- }
- default:
- break;
- }
-
- can_interrupt_enable(CAN0, CAN_INT_RFF0);
- }
- void CAN0_RX1_IRQHandler(void)
- {
- }
|