| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242 |
- /*!
- \file gd32f3x0_it.c
- \brief interrupt service routines
- */
- /*
- Copyright (C) 2017 GigaDevice
- 2017-06-06, V1.0.0, firmware for GD32F3x0
- */
- #include "gd32f3x0_it.h"
- #include "systick.h"
- __IO uint32_t step = 1;
- /*!
- \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)
- {
- /* 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)
- {
- timer_event_software_generate(TIMER0,TIMER_EVENT_SRC_CMTG);
- }
- /*!
- \brief this function handles TIMER0 interrupt request
- \param[in] none
- \param[out] none
- \retval none
- */
- void TIMER0_BRK_UP_TRG_COM_IRQHandler(void)
- {
- timer_interrupt_flag_clear(TIMER0, TIMER_INT_FLAG_CMT);
- switch(step){
- /* next step: step 2 configuration .A-C` breakover---------------------------- */
- case 1:
- /* channel0 configuration */
- timer_channel_output_mode_config(TIMER0,TIMER_CH_0,TIMER_OC_MODE_PWM1);
- timer_channel_output_state_config(TIMER0,TIMER_CH_0,TIMER_CCX_ENABLE);
- timer_channel_complementary_output_state_config(TIMER0,TIMER_CH_0,TIMER_CCXN_DISABLE);
- /* channel1 configuration */
- timer_channel_output_state_config(TIMER0,TIMER_CH_1,TIMER_CCX_DISABLE);
- timer_channel_complementary_output_state_config(TIMER0,TIMER_CH_1,TIMER_CCXN_DISABLE);
- /* channel2 configuration */
- timer_channel_output_mode_config(TIMER0,TIMER_CH_2,TIMER_OC_MODE_PWM1);
- timer_channel_output_state_config(TIMER0,TIMER_CH_2,TIMER_CCX_DISABLE);
- timer_channel_complementary_output_state_config(TIMER0,TIMER_CH_2,TIMER_CCXN_ENABLE);
- step++;
- break;
- /* next step: step 3 configuration .B-C` breakover---------------------------- */
- case 2:
- /* channel0 configuration */
- timer_channel_output_state_config(TIMER0,TIMER_CH_0,TIMER_CCX_DISABLE);
- timer_channel_complementary_output_state_config(TIMER0,TIMER_CH_0,TIMER_CCXN_DISABLE);
- /* channel1 configuration */
- timer_channel_output_mode_config(TIMER0,TIMER_CH_1,TIMER_OC_MODE_PWM1);
- timer_channel_output_state_config(TIMER0,TIMER_CH_1,TIMER_CCX_ENABLE);
- timer_channel_complementary_output_state_config(TIMER0,TIMER_CH_1,TIMER_CCXN_DISABLE);
- /* channel2 configuration */
- timer_channel_output_mode_config(TIMER0,TIMER_CH_2,TIMER_OC_MODE_PWM1);
- timer_channel_output_state_config(TIMER0,TIMER_CH_2,TIMER_CCX_DISABLE);
- timer_channel_complementary_output_state_config(TIMER0,TIMER_CH_2,TIMER_CCXN_ENABLE);
- step++;
- break;
- /* next step: step 4 configuration .B-A` breakover---------------------------- */
- case 3:
- /* channel0 configuration */
- timer_channel_output_mode_config(TIMER0,TIMER_CH_0,TIMER_OC_MODE_PWM1);
- timer_channel_output_state_config(TIMER0,TIMER_CH_0,TIMER_CCX_DISABLE);
- timer_channel_complementary_output_state_config(TIMER0,TIMER_CH_0,TIMER_CCXN_ENABLE);
- /* channel1 configuration */
- timer_channel_output_mode_config(TIMER0,TIMER_CH_1,TIMER_OC_MODE_PWM1);
- timer_channel_output_state_config(TIMER0,TIMER_CH_1,TIMER_CCX_ENABLE);
- timer_channel_complementary_output_state_config(TIMER0,TIMER_CH_1,TIMER_CCXN_DISABLE);
- /* channel2 configuration */
- timer_channel_output_state_config(TIMER0,TIMER_CH_2,TIMER_CCX_DISABLE);
- timer_channel_complementary_output_state_config(TIMER0,TIMER_CH_2,TIMER_CCXN_DISABLE);
- step++;
- break;
- /* next step: step 5 configuration .C-A` breakover---------------------------- */
- case 4:
- /* channel0 configuration */
- timer_channel_output_mode_config(TIMER0,TIMER_CH_0,TIMER_OC_MODE_PWM1);
- timer_channel_output_state_config(TIMER0,TIMER_CH_0,TIMER_CCX_DISABLE);
- timer_channel_complementary_output_state_config(TIMER0,TIMER_CH_0,TIMER_CCXN_ENABLE);
- /* channel1 configuration */
- timer_channel_output_state_config(TIMER0,TIMER_CH_1,TIMER_CCX_DISABLE);
- timer_channel_complementary_output_state_config(TIMER0,TIMER_CH_1,TIMER_CCXN_DISABLE);
- /* channel2 configuration */
- timer_channel_output_mode_config(TIMER0,TIMER_CH_2,TIMER_OC_MODE_PWM1);
- timer_channel_output_state_config(TIMER0,TIMER_CH_2,TIMER_CCX_ENABLE);
- timer_channel_complementary_output_state_config(TIMER0,TIMER_CH_2,TIMER_CCXN_DISABLE);
- step++;
- break;
- /* next step: step 6 configuration .C-B` breakover---------------------------- */
- case 5:
- /* channel0 configuration */
- timer_channel_output_state_config(TIMER0,TIMER_CH_0,TIMER_CCX_DISABLE);
- timer_channel_complementary_output_state_config(TIMER0,TIMER_CH_0,TIMER_CCXN_DISABLE);
- /* channel1 configuration */
- timer_channel_output_mode_config(TIMER0,TIMER_CH_1,TIMER_OC_MODE_PWM1);
- timer_channel_output_state_config(TIMER0,TIMER_CH_1,TIMER_CCX_DISABLE);
- timer_channel_complementary_output_state_config(TIMER0,TIMER_CH_1,TIMER_CCXN_ENABLE);
- /* channel2 configuration */
- timer_channel_output_mode_config(TIMER0,TIMER_CH_2,TIMER_OC_MODE_PWM1);
- timer_channel_output_state_config(TIMER0,TIMER_CH_2,TIMER_CCX_ENABLE);
- timer_channel_complementary_output_state_config(TIMER0,TIMER_CH_2,TIMER_CCXN_DISABLE);
- step++;
- break;
-
- /* next step: step 1 configuration .A-B` breakover---------------------------- */
- case 6:
- /* channel0 configuration */
- timer_channel_output_mode_config(TIMER0,TIMER_CH_0,TIMER_OC_MODE_PWM1);
- timer_channel_output_state_config(TIMER0,TIMER_CH_0,TIMER_CCX_ENABLE);
- timer_channel_complementary_output_state_config(TIMER0,TIMER_CH_0,TIMER_CCXN_DISABLE);
- /* channel1 configuration */
- timer_channel_output_mode_config(TIMER0,TIMER_CH_1,TIMER_OC_MODE_PWM1);
- timer_channel_output_state_config(TIMER0,TIMER_CH_1,TIMER_CCX_DISABLE);
- timer_channel_complementary_output_state_config(TIMER0,TIMER_CH_1,TIMER_CCXN_ENABLE);
- /* channel2 configuration */
- timer_channel_output_state_config(TIMER0,TIMER_CH_2,TIMER_CCX_DISABLE);
- timer_channel_complementary_output_state_config(TIMER0,TIMER_CH_2,TIMER_CCXN_DISABLE);
- step = 1;
- break;
- }
- }
|