STM32L431在STOP2模式下能否將串口的RX配置成EXTI喚醒呢?為什么我的喚醒不了呢?并且空閑中斷也不能用,手冊中說在硬件上已經將EXTI與RX引腳連到一塊了,但是呢STOP2模式不能將串口喚醒,所以它的那種方式好像不能使用,只能用最原始的將RX配置成EXTI的方式了,但是也還是喚醒不了 進入STOP2模式, - void EnterStop2ModeRTC(void) // 自定義的Enter函數
- {
- __HAL_RCC_PWR_CLK_ENABLE();
- __HAL_PWR_CLEAR_FLAG(PWR_FLAG_WU);
- __HAL_RTC_WAKEUPTIMER_CLEAR_FLAG(&hrtc, RTC_FLAG_WUTF);
- __HAL_RTC_WAKEUPTIMER_EXTI_CLEAR_FLAG();
- __HAL_RTC_TIMESTAMP_CLEAR_FLAG(&hrtc, RTC_FLAG_TSF);
- __HAL_RTC_TAMPER_TIMESTAMP_EXTI_CLEAR_FLAG();
- while (__HAL_UART_GET_FLAG(&huart3, USART_ISR_BUSY) == SET)
- ;
- while (__HAL_UART_GET_FLAG(&huart3, USART_ISR_REACK) == RESET)
- ;
- setUca3RxToExti();//配置串口3的RX為EXTI
- HAL_SuspendTick();
- //HAL_DBGMCU_EnableDBGStopMode();
- __HAL_RCC_PWR_CLK_ENABLE();
- HAL_PWREx_EnterSTOP2Mode(PWR_STOPENTRY_WFI); // 進入STOP2模式
- }
復制代碼退出STOP2 - void ExitStop2ModeRTC(void)
- {
- SystemClock_Config();
- HAL_ResumeTick();
- SCB->SCR &= ~SCB_SCR_SLEEPONEXIT_Msk;
- }
復制代碼主函數 - while (1)
- {
- while (getExitLPM3())
- {
- saveData();
- lcdActionPro(); // lcd進程
- keyActPro();
- // if (uart[_COM3].active)
- // {
- // }
- }
- }
- EnterStop2ModeRTC();
- }
復制代碼在函數getExitLPM3()中,判斷了一個標志位是否被置位,如果置位了就進入里面的while EXTI回調函數: - void HAL_GPIO_EXTI_Callback(uint16_t GPIO_Pin)
- {
- if ((GPIO_Pin == GPIO_PIN_5))
- {
- ExitStop2ModeRTC();
- HAL_NVIC_DisableIRQ(EXTI9_5_IRQn);
- setUca3RxToRx();
- // uart[_COM3].active = true;
- }
- }
復制代碼在EXTI的回調函數中退出了STOP2模式并重新將串口RX引腳配置為接收引腳 - void setUca3RxToExti(void)
- {
- GPIO_InitTypeDef GPIO_InitStruct;
- GPIO_InitStruct.Pin = GPIO_PIN_5;
- GPIO_InitStruct.Mode = GPIO_MODE_IT_FALLING;
- GPIO_InitStruct.Pull = GPIO_NOPULL;
- HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
- HAL_NVIC_SetPriority(EXTI9_5_IRQn, 0, 0);
- HAL_NVIC_EnableIRQ(EXTI9_5_IRQn);
- uart[_COM3].active = false;
- }
- void setUca3RxToRx(void)
- {
- GPIO_InitTypeDef GPIO_InitStruct;
- GPIO_InitStruct.Pin = GPIO_PIN_5;
- GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
- GPIO_InitStruct.Pull = GPIO_NOPULL;
- GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
- GPIO_InitStruct.Alternate = GPIO_AF7_USART3;
- HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
- // // HAL_NVIC_SetPriority(USART3_IRQn, 0, 0);
- // // HAL_NVIC_EnableIRQ(USART3_IRQn);
- __HAL_UART_ENABLE_IT(&huart3, UART_IT_RXNE);
- // __HAL_UART_ENABLE_IT(&huart3, UART_IT_RXNE | UART_IT_IDLE);
- }
復制代碼串口中斷 - void USER_USART3_IRQHandler(void)
- {
- uint8_t data = 0;
- if (__HAL_UART_GET_FLAG(&huart3, UART_FLAG_RXNE) != RESET)
- {
- data = (uint8_t)huart3.Instance->RDR;
- wrEleQueue(&uart[_COM3].Rx, data);
- // uart[_COM3].active = true;
- // bleAppConfig.rxAct = 1;
- // bleAppConfig.tmrResp = bleAppConfig.tmrRxHold = HAL_LPTIM_ReadCounter(&hlptim1);
- // __HAL_UART_CLEAR_FLAG(&huart3, UART_FLAG_RXNE);
- }
- // if (__HAL_UART_GET_FLAG(&huart3, UART_FLAG_IDLE))
- // {
- // // uart[_COM3].flag = 1;
- // uart[_COM3].active = false;
- // __HAL_UART_CLEAR_IDLEFLAG(&huart3);
- // }
- }
復制代碼中間好像邏輯有點問題,但是我想不明白了哈哈,就是那個標志位被置位true后就會一直在內層的while中循環,出不來了,就進不去STOP2了,但是不知道在哪將它給置為false,本來想使用IDLE空閑中斷的,但是空閑中斷使用后收不到數據,現在不使用的時候第一包數據永遠都是錯誤的,有沒有大佬能幫忙看一下,謝謝大家
|