From d3d530578cd646c83b6683439d08a80141205e46 Mon Sep 17 00:00:00 2001 From: WXK <287788329@qq.com> Date: 星期三, 29 十一月 2023 16:29:30 +0800 Subject: [PATCH] 1 --- Src/stm32l0xx_it.c | 43 +++++++++++++++++++++++++++++++------------ 1 files changed, 31 insertions(+), 12 deletions(-) diff --git a/Src/stm32l0xx_it.c b/Src/stm32l0xx_it.c index fb8ecaf..ed7ebef 100644 --- a/Src/stm32l0xx_it.c +++ b/Src/stm32l0xx_it.c @@ -42,7 +42,7 @@ /* Private variables ---------------------------------------------------------*/ /* USER CODE BEGIN PV */ - +float nomove_count=0; /* USER CODE END PV */ /* Private function prototypes -----------------------------------------------*/ @@ -65,7 +65,7 @@ /* USER CODE END EV */ /******************************************************************************/ -/* Cortex-M0+ Processor Interruption and Exception Handlers */ +/* Cortex-M0+ Processor Interruption and Exception Handlers */ /******************************************************************************/ /** * @brief This function handles Non maskable interrupt. @@ -91,6 +91,7 @@ while (1) { /* USER CODE BEGIN W1_HardFault_IRQn 0 */ + SCB->AIRCR = 0X05FA0000|(unsigned int)0x04; //软复位回到bootloader /* USER CODE END W1_HardFault_IRQn 0 */ } } @@ -148,24 +149,42 @@ void EXTI0_1_IRQHandler(void) { /* USER CODE BEGIN EXTI0_1_IRQn 0 */ - //GPIO_Toggle(MOTOR_GPIO_Port,MOTOR_Pin); + if(GET_IMUINT) + { + nomove_count = 0; + } + + if(!GET_USERKEY) + { + nomove_count = 0; + waitusart_timer = tag_frequency*USART_KEEPWAKE_TIME; + UsartInit(); + // MOTOR_ON; + } + /* USER CODE END EXTI0_1_IRQn 0 */ HAL_GPIO_EXTI_IRQHandler(GPIO_PIN_0); HAL_GPIO_EXTI_IRQHandler(GPIO_PIN_1); /* USER CODE BEGIN EXTI0_1_IRQn 1 */ -// HAL_LPTIM_DeInit(&hlptim1); -////HAL_PWR_EnterSTOPMode(PWR_LOWPOWERREGULATOR_ON, PWR_STOPENTRY_WFI); -//HAL_PWR_DisableWakeUpPin(PWR_WAKEUP_PIN1); -// /*Clear all related wakeup flags*/ -// __HAL_PWR_CLEAR_FLAG(PWR_FLAG_WU); -// /*Re-enable all used wakeup sources: Pin1(PA.0)*/ -// HAL_PWR_EnableWakeUpPin(PWR_WAKEUP_PIN1); -// /*Enter the Standby mode*/ -// HAL_PWR_EnterSTANDBYMode(); + //DW_DISABLE; /* USER CODE END EXTI0_1_IRQn 1 */ } /** + * @brief This function handles EXTI line 2 and line 3 interrupts. + */ +void EXTI2_3_IRQHandler(void) +{ + /* USER CODE BEGIN EXTI2_3_IRQn 0 */ + + /* USER CODE END EXTI2_3_IRQn 0 */ + HAL_GPIO_EXTI_IRQHandler(GPIO_PIN_3); + /* USER CODE BEGIN EXTI2_3_IRQn 1 */ + + /* USER CODE END EXTI2_3_IRQn 1 */ +} + +/** * @brief This function handles DMA1 channel 2 and channel 3 interrupts. */ void DMA1_Channel2_3_IRQHandler(void) -- Gitblit v1.9.3