通过GPIO唤醒睡眠状态(低功耗)下的EFR32MG系列

【情况1:EM1~EM3模式】

通过函数:
void GPIO_IntConfig(GPIO_Port_TypeDef port,
                                    unsigned int pin,
                                    bool risingEdge,
                                    bool fallingEdge,
                                    bool enable);

配置中断唤醒IO口,中断触发时机,中断使能与否。

通过函数:

void GPIOINT_CallbackRegister(uint8_t intNo, GPIOINT_IrqCallbackPtr_t callbackPtr);

配置中断服务函数;(说明:intNo默认对应GPIO_IntConfig中的pin.)

【情况2:EM4模式】

通过函数:

void GPIO_EM4EnablePinWakeup(uint32_t pinmask, uint32_t polaritymask);

配置中断唤醒主芯片;

特别说明:EM4模式唤醒后,芯片几乎等同于重新上电执行。

配置EM4 Wakeup引脚(QFN48封装)大约只有PA3/PB13/PC10/PD14/PF2/PF7。

 

================================================================================================================================

如下好文《基于EmberZNet 6.0的Zigbee先进睡眠机制浅析》,转自:https://www.sekorm.com/news/9339.html

Zigbee是很多智能家居系统采用的无线协议,主要依靠他的低速率、自组网、低功耗的特点。很多厂家都有Zigbee方案,但是Silicon Labs的Zigbee方案具有快速开发、网络稳定、功耗更低、集成微功耗PA等优势,在市场上面很受青睐,目前,全球范围内至少有1亿颗基于EmberZNet的Zigbee节点,足以证明它的优秀。

本文讨论EmberZNet的先进的睡眠机制,以帮助开发者能够对它的机制有更深刻的认识,从而能够对它有更好的利用。

EmberZNet

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个通过GPIO唤醒STM32L431的休眠代码示例: ``` #include "stm32l4xx.h" #include "stm32l4xx_hal_gpio.h" #include "stm32l4xx_hal_pwr.h" #include "stm32l4xx_hal_rcc.h" void SystemClock_Config(void); static void MX_GPIO_Init(void); int main(void) { HAL_Init(); SystemClock_Config(); MX_GPIO_Init(); // 配置唤醒引脚 HAL_PWR_EnableWakeUpPin(PWR_WAKEUP_PIN1_GPIOA); // 进入休眠模式 HAL_PWR_EnterSTOPMode(PWR_LOWPOWERREGULATOR_ON, PWR_STOPENTRY_WFI); // 唤醒后执行的代码 while (1) { // do something } } void SystemClock_Config(void) { RCC_OscInitTypeDef RCC_OscInitStruct = {0}; RCC_ClkInitTypeDef RCC_ClkInitStruct = {0}; /** Configure the main internal regulator output voltage */ __HAL_PWR_VOLTAGESCALING_CONFIG(PWR_REGULATOR_VOLTAGE_SCALE1); while(!__HAL_PWR_GET_FLAG(PWR_FLAG_VOSRDY)){} /** Initializes the RCC Oscillators according to the specified parameters * in the RCC_OscInitTypeDef structure. */ RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSI; RCC_OscInitStruct.HSIState = RCC_HSI_ON; RCC_OscInitStruct.HSICalibrationValue = RCC_HSICALIBRATION_DEFAULT; RCC_OscInitStruct.PLL.PLLState = RCC_PLL_NONE; if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK) { Error_Handler(); } /** Initializes the CPU, AHB and APB buses clocks */ RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK |RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2; RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_HSI; RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1; RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV1; RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1; if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_1) != HAL_OK) { Error_Handler(); } } static void MX_GPIO_Init(void) { GPIO_InitTypeDef GPIO_InitStruct = {0}; /* GPIO Ports Clock Enable */ __HAL_RCC_GPIOA_CLK_ENABLE(); /*Configure GPIO pin : PA0 */ GPIO_InitStruct.Pin = GPIO_PIN_0; GPIO_InitStruct.Mode = GPIO_MODE_IT_RISING; GPIO_InitStruct.Pull = GPIO_NOPULL; HAL_GPIO_Init(GPIOA, &GPIO_InitStruct); /* EXTI interrupt init*/ HAL_NVIC_SetPriority(EXTI0_IRQn, 0, 0); HAL_NVIC_EnableIRQ(EXTI0_IRQn); } void EXTI0_IRQHandler(void) { HAL_GPIO_EXTI_IRQHandler(GPIO_PIN_0); } void HAL_GPIO_EXTI_Callback(uint16_t GPIO_Pin) { // 唤醒后执行的代码 } ``` 希望这个代码示例能对您有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值