diff --git a/.clang-format b/.clang-format index ecc57c4..408ff24 100644 --- a/.clang-format +++ b/.clang-format @@ -7,8 +7,8 @@ Language: Cpp ################################### UseTab: Never -IndentWidth: 4 -TabWidth: 4 +IndentWidth: 2 +TabWidth: 2 ColumnLimit: 0 AccessModifierOffset: -4 NamespaceIndentation: All diff --git a/BC1C.ATWP b/BC1C.ATWP index 8136544..0dee0d4 100644 --- a/BC1C.ATWP +++ b/BC1C.ATWP @@ -94,6 +94,11 @@ + + + + + @@ -124,7 +129,7 @@ 0;0;0 0;0;0 0;0;0 - 0;0;0 + 1;0;0 0;0;0 0;0;0 0;0;0 @@ -141,7 +146,7 @@ 0;0;0 1;0;0 0;0;0 - 0;0;0 + 1;0;0 0;0;0 0;0;0 diff --git a/BC1C.code-workspace b/BC1C.code-workspace index 54eca7c..0475ef8 100644 --- a/BC1C.code-workspace +++ b/BC1C.code-workspace @@ -33,18 +33,5 @@ } }, "extensions": { - "recommendations": [ - "cl.eide", - "keroc.hex-fmt", - "xiaoyongdong.srecord", - "hars.cppsnippets", - "zixuanwang.linkerscript", - "redhat.vscode-yaml", - "IBM.output-colorizer", - "cschlosser.doxdocgen", - "ms-vscode.vscode-serial-monitor", - "dan-c-underwood.arm", - "marus25.cortex-debug" - ] } } \ No newline at end of file diff --git a/project/inc/at32f403a_407_int.h b/project/inc/at32f403a_407_int.h index 58c0d6c..c6394e0 100644 --- a/project/inc/at32f403a_407_int.h +++ b/project/inc/at32f403a_407_int.h @@ -65,10 +65,12 @@ void SVC_Handler(void); void DebugMon_Handler(void); void PendSV_Handler(void); +void USBFS_L_CAN1_RX0_IRQHandler(void); void USART1_IRQHandler(void); void USART2_IRQHandler(void); void USART3_IRQHandler(void); void TMR6_GLOBAL_IRQHandler(void); +void CAN2_RX0_IRQHandler(void); /* add user code begin exported functions */ /* add user code end exported functions */ diff --git a/project/src/at32f403a_407_int.c b/project/src/at32f403a_407_int.c index e1d17ff..f7348c4 100644 --- a/project/src/at32f403a_407_int.c +++ b/project/src/at32f403a_407_int.c @@ -74,13 +74,13 @@ */ void NMI_Handler(void) { - /* add user code begin NonMaskableInt_IRQ 0 */ + /* add user code begin NonMaskableInt_IRQ 0 */ - /* add user code end NonMaskableInt_IRQ 0 */ + /* add user code end NonMaskableInt_IRQ 0 */ - /* add user code begin NonMaskableInt_IRQ 1 */ + /* add user code begin NonMaskableInt_IRQ 1 */ - /* add user code end NonMaskableInt_IRQ 1 */ + /* add user code end NonMaskableInt_IRQ 1 */ } /** @@ -90,15 +90,15 @@ void NMI_Handler(void) */ void HardFault_Handler(void) { - /* add user code begin HardFault_IRQ 0 */ + /* add user code begin HardFault_IRQ 0 */ - /* add user code end HardFault_IRQ 0 */ - /* go to infinite loop when hard fault exception occurs */ - while (1) { - /* add user code begin W1_HardFault_IRQ 0 */ + /* add user code end HardFault_IRQ 0 */ + /* go to infinite loop when hard fault exception occurs */ + while (1) { + /* add user code begin W1_HardFault_IRQ 0 */ - /* add user code end W1_HardFault_IRQ 0 */ - } + /* add user code end W1_HardFault_IRQ 0 */ + } } /** @@ -108,15 +108,15 @@ void HardFault_Handler(void) */ void MemManage_Handler(void) { - /* add user code begin MemoryManagement_IRQ 0 */ + /* add user code begin MemoryManagement_IRQ 0 */ - /* add user code end MemoryManagement_IRQ 0 */ - /* go to infinite loop when memory manage exception occurs */ - while (1) { - /* add user code begin W1_MemoryManagement_IRQ 0 */ + /* add user code end MemoryManagement_IRQ 0 */ + /* go to infinite loop when memory manage exception occurs */ + while (1) { + /* add user code begin W1_MemoryManagement_IRQ 0 */ - /* add user code end W1_MemoryManagement_IRQ 0 */ - } + /* add user code end W1_MemoryManagement_IRQ 0 */ + } } /** @@ -126,15 +126,15 @@ void MemManage_Handler(void) */ void BusFault_Handler(void) { - /* add user code begin BusFault_IRQ 0 */ + /* add user code begin BusFault_IRQ 0 */ - /* add user code end BusFault_IRQ 0 */ - /* go to infinite loop when bus fault exception occurs */ - while (1) { - /* add user code begin W1_BusFault_IRQ 0 */ + /* add user code end BusFault_IRQ 0 */ + /* go to infinite loop when bus fault exception occurs */ + while (1) { + /* add user code begin W1_BusFault_IRQ 0 */ - /* add user code end W1_BusFault_IRQ 0 */ - } + /* add user code end W1_BusFault_IRQ 0 */ + } } /** @@ -144,15 +144,15 @@ void BusFault_Handler(void) */ void UsageFault_Handler(void) { - /* add user code begin UsageFault_IRQ 0 */ + /* add user code begin UsageFault_IRQ 0 */ - /* add user code end UsageFault_IRQ 0 */ - /* go to infinite loop when usage fault exception occurs */ - while (1) { - /* add user code begin W1_UsageFault_IRQ 0 */ + /* add user code end UsageFault_IRQ 0 */ + /* go to infinite loop when usage fault exception occurs */ + while (1) { + /* add user code begin W1_UsageFault_IRQ 0 */ - /* add user code end W1_UsageFault_IRQ 0 */ - } + /* add user code end W1_UsageFault_IRQ 0 */ + } } /** @@ -162,12 +162,12 @@ void UsageFault_Handler(void) */ void SVC_Handler(void) { - /* add user code begin SVCall_IRQ 0 */ + /* add user code begin SVCall_IRQ 0 */ - /* add user code end SVCall_IRQ 0 */ - /* add user code begin SVCall_IRQ 1 */ + /* add user code end SVCall_IRQ 0 */ + /* add user code begin SVCall_IRQ 1 */ - /* add user code end SVCall_IRQ 1 */ + /* add user code end SVCall_IRQ 1 */ } /** @@ -177,12 +177,12 @@ void SVC_Handler(void) */ void DebugMon_Handler(void) { - /* add user code begin DebugMonitor_IRQ 0 */ + /* add user code begin DebugMonitor_IRQ 0 */ - /* add user code end DebugMonitor_IRQ 0 */ - /* add user code begin DebugMonitor_IRQ 1 */ + /* add user code end DebugMonitor_IRQ 0 */ + /* add user code begin DebugMonitor_IRQ 1 */ - /* add user code end DebugMonitor_IRQ 1 */ + /* add user code end DebugMonitor_IRQ 1 */ } /** @@ -192,12 +192,32 @@ void DebugMon_Handler(void) */ void PendSV_Handler(void) { - /* add user code begin PendSV_IRQ 0 */ + /* add user code begin PendSV_IRQ 0 */ - /* add user code end PendSV_IRQ 0 */ - /* add user code begin PendSV_IRQ 1 */ + /* add user code end PendSV_IRQ 0 */ + /* add user code begin PendSV_IRQ 1 */ - /* add user code end PendSV_IRQ 1 */ + /* add user code end PendSV_IRQ 1 */ +} + +/** + * @brief this function handles USB Low Priority or CAN1 RX0 handler. + * @param none + * @retval none + */ +void USBFS_L_CAN1_RX0_IRQHandler(void) +{ + /* add user code begin USBFS_L_CAN1_RX0_IRQ 0 */ + if (SET == can_flag_get(CAN1, CAN_RF0MN_FLAG)) { + can_rx_message_type rx_message_struct; + can_message_receive(CAN1, CAN_RX_FIFO0, &rx_message_struct); + lwprintf("CAN1 RECV: ID = 0x%X\r\n", rx_message_struct.standard_id); + can_flag_clear(CAN1, CAN_RF0MN_FLAG); + } + /* add user code end USBFS_L_CAN1_RX0_IRQ 0 */ + /* add user code begin USBFS_L_CAN1_RX0_IRQ 1 */ + + /* add user code end USBFS_L_CAN1_RX0_IRQ 1 */ } /** @@ -207,12 +227,12 @@ void PendSV_Handler(void) */ void USART1_IRQHandler(void) { - /* add user code begin USART1_IRQ 0 */ + /* add user code begin USART1_IRQ 0 */ - /* add user code end USART1_IRQ 0 */ - /* add user code begin USART1_IRQ 1 */ + /* add user code end USART1_IRQ 0 */ + /* add user code begin USART1_IRQ 1 */ - /* add user code end USART1_IRQ 1 */ + /* add user code end USART1_IRQ 1 */ } /** @@ -222,15 +242,15 @@ void USART1_IRQHandler(void) */ void USART2_IRQHandler(void) { - /* add user code begin USART2_IRQ 0 */ - if (SET == usart_flag_get(USART2, USART_RDBF_FLAG)) { - usart_data_receive(USART2); - usart_flag_clear(USART2, USART_RDBF_FLAG); - } - /* add user code end USART2_IRQ 0 */ - /* add user code begin USART2_IRQ 1 */ + /* add user code begin USART2_IRQ 0 */ + if (SET == usart_flag_get(USART2, USART_RDBF_FLAG)) { + usart_data_receive(USART2); + usart_flag_clear(USART2, USART_RDBF_FLAG); + } + /* add user code end USART2_IRQ 0 */ + /* add user code begin USART2_IRQ 1 */ - /* add user code end USART2_IRQ 1 */ + /* add user code end USART2_IRQ 1 */ } /** @@ -240,12 +260,12 @@ void USART2_IRQHandler(void) */ void USART3_IRQHandler(void) { - /* add user code begin USART3_IRQ 0 */ + /* add user code begin USART3_IRQ 0 */ - /* add user code end USART3_IRQ 0 */ - /* add user code begin USART3_IRQ 1 */ + /* add user code end USART3_IRQ 0 */ + /* add user code begin USART3_IRQ 1 */ - /* add user code end USART3_IRQ 1 */ + /* add user code end USART3_IRQ 1 */ } /** @@ -255,15 +275,39 @@ void USART3_IRQHandler(void) */ void TMR6_GLOBAL_IRQHandler(void) { - /* add user code begin TMR6_GLOBAL_IRQ 0 */ - static uint64_t i = 0; - if (SET == tmr_flag_get(TMR6, TMR_OVF_FLAG)) { - tmr_flag_clear(TMR6, TMR_OVF_FLAG); - } - /* add user code end TMR6_GLOBAL_IRQ 0 */ - /* add user code begin TMR6_GLOBAL_IRQ 1 */ + /* add user code begin TMR6_GLOBAL_IRQ 0 */ + if (SET == tmr_flag_get(TMR6, TMR_OVF_FLAG)) { + tmr_flag_clear(TMR6, TMR_OVF_FLAG); + } + /* add user code end TMR6_GLOBAL_IRQ 0 */ + /* add user code begin TMR6_GLOBAL_IRQ 1 */ - /* add user code end TMR6_GLOBAL_IRQ 1 */ + /* add user code end TMR6_GLOBAL_IRQ 1 */ +} + +/** + * @brief this function handles CAN2 RX0 handler. + * @param none + * @retval none + */ +void CAN2_RX0_IRQHandler(void) +{ + /* add user code begin CAN2_RX0_IRQ 0 */ + if (SET == can_flag_get(CAN2, CAN_RF0MN_FLAG)) { + can_rx_message_type rx_message_struct; + can_message_receive(CAN2, CAN_RX_FIFO0, &rx_message_struct); + lwprintf("CAN2 RECV: ID = 0x%X\r\n", rx_message_struct.standard_id); + lwprintf("---------------------\r\n| "); + for (uint8_t i = 0; i < 8; i++) { + lwprintf("0x%02X |", rx_message_struct.data[i]); + } + lwprintf("\r\n---------------------\r\n"); + can_flag_clear(CAN2, CAN_RF0MN_FLAG); + } + /* add user code end CAN2_RX0_IRQ 0 */ + /* add user code begin CAN2_RX0_IRQ 1 */ + + /* add user code end CAN2_RX0_IRQ 1 */ } /* add user code begin 1 */ diff --git a/project/src/at32f403a_407_wk_config.c b/project/src/at32f403a_407_wk_config.c index 5701f96..d33b4eb 100644 --- a/project/src/at32f403a_407_wk_config.c +++ b/project/src/at32f403a_407_wk_config.c @@ -220,10 +220,12 @@ void wk_nvic_config(void) { nvic_priority_group_config(NVIC_PRIORITY_GROUP_4); + nvic_irq_enable(USBFS_L_CAN1_RX0_IRQn, 0, 0); nvic_irq_enable(USART1_IRQn, 1, 0); nvic_irq_enable(USART2_IRQn, 1, 0); nvic_irq_enable(USART3_IRQn, 1, 0); nvic_irq_enable(TMR6_GLOBAL_IRQn, 0, 0); + nvic_irq_enable(CAN2_RX0_IRQn, 0, 0); } /** @@ -741,13 +743,13 @@ void wk_tmr11_init(void) gpio_init(GPIOB, &gpio_init_struct); /* configure counter settings */ - tmr_base_init(TMR11, 65535, 0); + tmr_base_init(TMR11, 2399, 99); tmr_cnt_dir_set(TMR11, TMR_COUNT_UP); tmr_clock_source_div_set(TMR11, TMR_CLOCK_DIV1); tmr_period_buffer_enable(TMR11, FALSE); /* configure channel 1 output settings */ - tmr_output_struct.oc_mode = TMR_OUTPUT_CONTROL_OFF; + tmr_output_struct.oc_mode = TMR_OUTPUT_CONTROL_PWM_MODE_A; tmr_output_struct.oc_output_state = TRUE; tmr_output_struct.occ_output_state = FALSE; tmr_output_struct.oc_polarity = TMR_OUTPUT_ACTIVE_HIGH; @@ -758,6 +760,8 @@ void wk_tmr11_init(void) tmr_channel_value_set(TMR11, TMR_SELECT_CHANNEL_1, 0); tmr_output_channel_buffer_enable(TMR11, TMR_SELECT_CHANNEL_1, FALSE); + tmr_output_channel_immediately_set(TMR11, TMR_SELECT_CHANNEL_1, FALSE); + tmr_counter_enable(TMR11, TRUE); /* add user code begin tmr11_init 2 */ @@ -910,8 +914,19 @@ void wk_can1_init(void) can_filter_init(CAN1, &can_filter_init_struct); - /* add user code begin can1_init 2 */ + /** + * Users need to configure CAN1 interrupt functions according to the actual application. + * 1. Call the below function to enable the corresponding CAN1 interrupt. + * --can_interrupt_enable(...) + * 2. Add the user's interrupt handler code into the below function in the at32f403a_407_int.c file. + * --void USBFS_L_CAN1_RX0_IRQHandler(void) + */ + /*can1 rx0 interrupt config--------------------------------------------------------*/ + // can_interrupt_enable(CAN1, CAN_RF0MIEN_INT, TRUE); + + /* add user code begin can1_init 2 */ + can_interrupt_enable(CAN1, CAN_RF0MIEN_INT, TRUE); /* add user code end can1_init 2 */ } @@ -988,8 +1003,19 @@ void wk_can2_init(void) can_filter_init(CAN2, &can_filter_init_struct); - /* add user code begin can2_init 2 */ + /** + * Users need to configure CAN2 interrupt functions according to the actual application. + * 1. Call the below function to enable the corresponding CAN2 interrupt. + * --can_interrupt_enable(...) + * 2. Add the user's interrupt handler code into the below function in the at32f403a_407_int.c file. + * --void CAN2_RX0_IRQHandler(void) + */ + /*can2 rx0 interrupt config--------------------------------------------------------*/ + // can_interrupt_enable(CAN2, CAN_RF0MIEN_INT, TRUE); + + /* add user code begin can2_init 2 */ + can_interrupt_enable(CAN2, CAN_RF0MIEN_INT, TRUE); /* add user code end can2_init 2 */ } diff --git a/project/src/main.c b/project/src/main.c index 26975d4..c0c8793 100644 --- a/project/src/main.c +++ b/project/src/main.c @@ -71,70 +71,70 @@ */ int main(void) { - /* add user code begin 1 */ - by_debug_init(); - /* add user code end 1 */ + /* add user code begin 1 */ + by_debug_init(); + /* add user code end 1 */ - /* system clock config. */ - wk_system_clock_config(); + /* system clock config. */ + wk_system_clock_config(); - /* config periph clock. */ - wk_periph_clock_config(); + /* config periph clock. */ + wk_periph_clock_config(); - /* init debug function. */ - wk_debug_config(); + /* init debug function. */ + wk_debug_config(); - /* nvic config. */ - wk_nvic_config(); + /* nvic config. */ + wk_nvic_config(); - /* init usart1 function. */ - wk_usart1_init(); + /* init usart1 function. */ + wk_usart1_init(); - /* init usart2 function. */ - wk_usart2_init(); + /* init usart2 function. */ + wk_usart2_init(); - /* init usart3 function. */ - wk_usart3_init(); + /* init usart3 function. */ + wk_usart3_init(); - /* init i2c1 function. */ - wk_i2c1_init(); + /* init i2c1 function. */ + wk_i2c1_init(); - /* init i2c2 function. */ - wk_i2c2_init(); + /* init i2c2 function. */ + wk_i2c2_init(); - /* init adc1 function. */ - wk_adc1_init(); + /* init adc1 function. */ + wk_adc1_init(); - /* init tmr6 function. */ - wk_tmr6_init(); + /* init tmr6 function. */ + wk_tmr6_init(); - /* init tmr8 function. */ - wk_tmr8_init(); + /* init tmr8 function. */ + wk_tmr8_init(); - /* init tmr11 function. */ - wk_tmr11_init(); + /* init tmr11 function. */ + wk_tmr11_init(); - /* init tmr12 function. */ - wk_tmr12_init(); + /* init tmr12 function. */ + wk_tmr12_init(); - /* init can1 function. */ - wk_can1_init(); + /* init can1 function. */ + wk_can1_init(); - /* init can2 function. */ - wk_can2_init(); + /* init can2 function. */ + wk_can2_init(); - /* init gpio function. */ - wk_gpio_config(); + /* init gpio function. */ + wk_gpio_config(); - /* add user code begin 2 */ - DWT_Init(); + /* add user code begin 2 */ + DWT_Init(); - lwprintf("init done!\r\n"); - /* add user code end 2 */ + lwprintf("init done!\r\n"); + /* add user code end 2 */ - while (1) { - /* add user code begin 3 */ - // DWT_Delay(1000000); - /* add user code end 3 */ - } + while (1) { + /* add user code begin 3 */ + // DWT_Delay(1000000); + /* add user code end 3 */ + } }