打印

一起学习rtt的pm组件,实现功耗管理

[复制链接]
3165|13
手机看帖
扫描二维码
随时随地手机跟帖
沙发
keer_zu|  楼主 | 2022-3-17 09:19 | 只看该作者
嵌入式系统低功耗管理的目的在于满足用户对性能需求的前提下,尽可能降低系统能耗以延长设备待机时间。高性能与有限的电池能量在嵌入式系统中矛盾最为突出,硬件低功耗设计与软件低功耗管理的联合应用成为解决矛盾的有效手段。现在的各种 MCU 都或多或少的在低功耗方面提供了管理接口。比如对主控时钟频率的调整、工作电压的改变、总线频率的调整甚至关闭、外围设备工作时钟的关闭等。有了硬件上的支持,合理的软件设计就成为节能的关键,一般可以把低功耗管理分为三个类别:
  • 处理器电源管理 主要实现方式:对 CPU 频率的动态管理,以及系统空闲时对工作模式的调整。
  • 设备电源管理 主要实现方式:关闭个别闲置设备
  • 系统平台电源管理 主要实现方式:针对特定系统平台的非常见设备具体定制。


使用特权

评论回复
板凳
keer_zu|  楼主 | 2022-3-17 09:25 | 只看该作者
rtt电源组件的初衷和定位是什么呢?

随着物联网 (IoT) 的兴起,产品对功耗的需求越来越强烈。作为数据采集的传感器节点通常需要在电池供电时长期工作,而作为联网的 SOC 也需要有快速的响应功能和较低的功耗。

在产品开发的起始阶段,首先考虑是尽快完成产品的功能开发。在产品功能逐步完善之后,就需要加入电源管理 (Power Management,以下简称 PM) 功能。为了适应 IoT 的这种需求,RT-Thread 提供了电源管理组件。电源管理组件的理念是尽量透明,使得产品加入低功耗功能更加轻松。

使用特权

评论回复
地板
keer_zu|  楼主 | 2022-3-17 09:26 | 只看该作者
我们来看一下rtt的PM组件

RT-Thread 的 PM 组件采用分层设计思想,分离架构和芯片相关的部分,提取公共部分作为核心。在对上层提供通用的接口同时,也让底层驱动对组件的适配变得更加简单。

使用特权

评论回复
5
keer_zu|  楼主 | 2022-3-17 09:33 | 只看该作者

分层框架和运行模式:


使用特权

评论回复
6
keer_zu|  楼主 | 2022-3-17 09:38 | 只看该作者
RT-Thread PM 组件主要特点:

  • 基于模式来管理功耗,空闲时动态调整工作模式,支持多个等级的休眠。
  • 对应用透明,组件在底层自动完成电源管理。
  • 支持运行模式下动态变频,根据模式自动更新设备的频率配置,确保在不同的运行模式都可以正常工作。
  • 支持设备电源管理,根据模式自动管理设备的挂起和恢复,确保在不同的休眠模式下可以正确的挂起和恢复。
  • 支持可选的休眠时间补偿,让依赖 OS Tick 的应用可以透明使用。
  • 向上层提供设备接口,如果打开了 devfs 组件,那么也可以通过文件系统接口访问。

使用特权

评论回复
7
keer_zu|  楼主 | 2022-3-17 09:41 | 只看该作者


低功耗的本质是系统空闲时 CPU 停止工作,中断或事件唤醒后继续工作。在 RTOS 中,通常包含一个 IDLE 任务,该任务的优先级最低且一直保持就绪状态,当高优先级任务未就绪时,OS 执行 IDLE 任务。一般地,未进行低功耗处理时,CPU 在 IDLE 任务中循环执行空指令。RT-Thread 的电源管理组件在 IDLE 任务中,通过对 CPU 、时钟和设备等进行管理,从而有效降低系统的功耗



使用特权

评论回复
8
keer_zu|  楼主 | 2022-3-17 09:46 | 只看该作者
在上图所示,当高优先级任务运行结束或被挂起时,系统将进入 IDLE 任务中。在 IDLE 任务执行后,它将判断系统是否可以进入到休眠状态(以节省功耗)。如果可以进入休眠, 将根据芯片情况关闭部分硬件模块,OS Tick 也非常有可能进入暂停状态。此时电源管理框架会根据系统定时器情况,计算出下一个超时时间点,并设置低功耗定时器,让设备能够在这个时刻点唤醒,并进行后续的工作。当系统被(低功耗定时器中断或其他唤醒中断源)唤醒后,系统也需要知道睡眠时间长度是多少,并对OS Tick 进行补偿,让系统的OS tick值调整为一个正确的值。

使用特权

评论回复
9
keer_zu|  楼主 | 2022-3-17 10:12 | 只看该作者





在 RT-Thread PM 组件中,外设或应用通过投票机制对所需的功耗模式进行投票,当系统空闲时,根据投票数决策出合适的功耗模式,调用抽象接口,控制芯片进入低功耗状态,从而降低系统功耗。当未进行进行任何投票时,会以默认模式进入(通常为空闲模式)。与应用不同,某些外设可能在进入低功耗状态时执行特定操作,退出低功耗时采取措施恢复,此时可以通过注册PM设备来实现。通过注册 PM 设备,在进入低功耗状态之前,会触发注册设备的 suspend 回调,开发者可在回调里执行自己的操作;类似地,从低功耗状态退出时,也会触发 resume 回调。

使用特权

评论回复
10
keer_zu|  楼主 | 2022-3-17 10:14 | 只看该作者
rtthread的pm有两种状态
  • 运行状态
  • 休眠状态




每种状态又分若干个模式。

RT-Thread PM 组件将系统划分为两种状态:运行状态(RUN)和休眠状态(Sleep)。 运行状态控制 CPU 的频率,适用于变频场景;休眠状态根据 SOC 特性实现休眠 CPU,以降低功耗。两种状态分别使用不同的 API 接口,独立控制。


使用特权

评论回复
11
keer_zu|  楼主 | 2022-3-17 10:18 | 只看该作者
本帖最后由 keer_zu 于 2022-3-17 10:26 编辑

休眠状态


休眠状态也就是通常意义上的低功耗状态,通过关闭外设、执行 SOC 电源管理接口,降低系统功耗。 休眠状态又分为六个模式,呈现为金字塔的形式。随着模式增加,功耗逐级递减的特点。下面是休眠状态下模式的定义,开发者可根据具体的 SOC 实现相应的模式,但需要遵循功耗逐级降低的特点。


[td]
模式级别描述
PM_SLEEP_MODE_NONE0系统处于活跃状态,未采取任何的降低功耗状态
PM_SLEEP_MODE_IDLE1空闲模式,该模式在系统空闲时停止 CPU 和部分时钟,任意事件或中断均可以唤醒
PM_SLEEP_MODE_LIGHT2轻度睡眠模式,CPU 停止,多数时钟和外设停止,唤醒后需要进行时间补偿
PM_SLEEP_MODE_DEEP3深度睡眠模式,CPU 停止,仅少数低功耗外设工作,可被特殊中断唤醒
PM_SLEEP_MODE_STANDBY4待机模式,CPU 停止,设备上下文丢失(可保存至特殊外设),唤醒后通常复位
PM_SLEEP_MODE_SHUTDOWN5关断模式,比 Standby 模式功耗更低, 上下文通常不可恢复, 唤醒后复位
注意: 因各家芯片差异,功耗管理的实现也不尽相同,上述的描述仅给出一些推荐的场景,并非一定需要实现所有。开发者可根据自身情况选择其中的几种进行实现,但是需要遵循级别越高,功耗越低的原则!

使用特权

评论回复
12
keer_zu|  楼主 | 2022-3-17 10:42 | 只看该作者
运行状态

运行状态通常用于改变 CPU 的运行频率,独立于休眠模式。当前运行状态划分了四个等级:高速、正常、中速、低速,如下:
[td]
模式描述
PM_RUN_MODE_HIGH_SPEED高速模式,适用于一些超频的场景
PM_RUN_MODE_NORMAL_SPEED正常模式,该模式作为默认的运行状态
PM_RUN_MODE_MEDIUM_SPEED中速模式,降低 CPU 运行速度,从而降低运行功耗
PM_RUN_MODE_LOW_SPEED低速模式,CPU 频率进一步降低


使用特权

评论回复
13
keer_zu|  楼主 | 2022-3-17 11:38 | 只看该作者

模式的请求和释放

在 PM 组件里,上层应用可以通过请求和释放休眠模式主动参与功耗管理。应用可以根据场景请求不同的休眠模式,并在处理完毕后释放,只要有任意一个应用或设备请求高等级的功耗模式,就不会切换到比它更低的模式。因此,休眠模式的请求和释放的操作通常成对出现,可用于对某个阶段进行保护,如外设的 DMA 传输过程。


使用特权

评论回复
14
keer_zu|  楼主 | 2022-3-17 11:55 | 只看该作者
敏感设备

在 PM 组件里,切换到新的运行模式可能会导致 CPU 频率发生变化,如果外设和 CPU 共用一部分时钟,那外设的时钟就会受到影响;在进入新的休眠模式,大部分时钟源会被停止,如果外设不支持休眠的冻结功能,那么从休眠唤醒的时候,外设的时钟就需要重新配置外设。所以 PM 组件里支持了 PM 模式敏感的 PM 设备。使得设备在切换到新的运行模式或者新的休眠模式都能正常的工作。该功能需要底层驱动实现相关的接口并注册为对模式变化敏感的设备。

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

个人签名:qq群:49734243 Email:zukeqiang@gmail.com

1352

主题

12436

帖子

53

粉丝