最近在看CORTEX-R52文档时,了解了一下该处理器功耗管理相关的内容,这里记录一下power gating的部分,并加上一些自己的理解。

1.概述

power gating是一种直接关闭芯片上某一部分电路电源,以彻底节省该电路功耗(包括静态功耗和动态功耗)的方法。虽然ARM在发布处理器IP时,会给出推荐的power domain划分和电源管理方式,但具体的实现还是取决于芯片设计者实际确定的power domain划分及PMU(电源管理单元)的设计。
大多数情况下,关闭处理器的电源这一操作是由软件和硬件共同完成的(即由软件发出指令,硬件完成具体的关电动作),软件在决定关闭处理器电源前,应当保证处理器处于所预期的状态,这可能需要先执行一系列其他的准备工作,比如将某些不希望丢失的寄存器值或TCM(tightly coupled memory, 用于在R系列处理器中执行一些对延时要求很低的任务,内嵌于处理器中)中的某些内容存放到芯片中不会掉电的存储器中。完成准备工作后,软件应执行WFI(wait for interrupt)指令以停止处理器的指令执行和对外的数据访问,随后处理器会通过对外的LPI(Low-Power Interface, 低功耗接口)告知PMU,处理器已经处于静态(quiescent)并且不会被中断唤醒,此时PMU才可以关闭处理器的电源(通常是通过关闭相应的power switch)。

2.power domain划分

ARM推荐的R52 power domain划分,主要包括两个层次,PDCPU domain包括单个CPU core以及它的cache(包括L1 I-cache和D-cache),TCM,debug逻辑,ETM等,PDTOP覆盖了整个cluster,包括1-4个CPU core,以及外围的GIC,debug,AXI slave(用于从外部访问TCM),debug等逻辑。这样的划分方式可以使用户控制整个cluster的电源,或单独控制某个core的电源。下图给出了一个由4个core组成的cluster中,power domain的划分示意图。

3.R25 LPI

每个CPU core都有自己的P-channel LPI(low power interface),且各个core的LPI相互独立。PMU可以通过LPI的COREPSTATEx使CPU进入可以安全断电的状态,CPU也可以通过LPI的COREPACTIVEx信号来告知PMU是否可以进行断电操作或者CPU是否需要上电。
每个P-channel支持两种CPU的power状态:
1)RUN(COREPSTATEx=0)
core可以执行通常的操作。同时core可以通过WFI,WFE等指令进入并推出低功耗状态。
2)SHUTDOWN (COREPSTATEx=1)
CPU没有在执行指令,处理中断,或进行AXIS访问(用来访问core内部的TCM)及APB接口发出的debug寄存器访问。对AXIS的访问将返回error response;通过APB访问debug寄存器将会返回error response,除非开启了模拟断电(稍后会介绍)的特性。

COREPACTIVEx是一个2bit信号,
bit[1]
在RUN state下,如果core满足以下任意条件,这个bit的值即为1:
• 正在执行指令
• 有该core发出的未完成的数据传输(outstanding transactions)
• 可以处理中断(中断使能没有被关闭)
• 正在处理AXIS或APB的传输
在SHUTDOWN状态下,如果core收到了外部中断或debug power up request,这一bit会变成1.

bit[0]
在 debug no powerdown(DBGPRCR.CORENPDRQ) 或debug powerup request (EDPRCR.COREPURQ, TRCPDCR.PU) 被设为1时,这一bit将变为1,在这种情况下,PMU只能对该core进行模拟断电,而不能真正切断其电源。

4.断电流程

1.将需要保存的处理器状态或数据保存到不会断电的存储器中
2.关闭ICC_IGRPEN0和ICC_IGRPEN1的中断使能,设置GIC
distributor中对该core的wake-up request(通过GICR_WAKER 寄存器.
3.执行ISB指令,保证前两步的操作均完成
4.配置SOC中关于本core的power control寄存器
5.执行WFI指令

在上述步骤4中的寄存器被在配置后,PMU将执行以下操作:
1.等待COREPACTIVEx[1]变为0.
2.通过LPI发出使core进入SHUTDOWN状态的request.
3. 如果LPI的request成功(具体协议参照reference 1),则可以将该core断电

5.上电流程

如果COREPACTIVEx[1]变为1,或者SOC中有其他上电事件,则PMU需要通过以下流程将core上电:
1.将复位信号nCPUPORESETx ,nCORERESETx置0
2.打开core对应power domain的power switch,将其上电
3.通过LPI发出使core进入RUN状态的request
4.将复位信号nCPUPORESETx ,nCORERESETx置1(释放),步骤3中的request将被接受,处理器从reset handler开始执行指令。

6.模拟断电

当CPU正常断电时,内部的debug寄存器也会断电被丢失原有信息,包括已经设置的断点(breakpoint)和监视点(watchpoint),软件在重新上电后读取EDPRSR.SPD的值将为1,表示debug寄存器内容已丢失。为了debug power control相关的软件,引入了模拟断电的概念。

模拟断电中的软件流程和正常断电的软件流程相同,但PMU的行为会有所不同。调试器(debugger)可以通过配置DBGPRCR.CORENPDRQ来使能模拟断电,配置后COREPACTIVEx[0]会变为1,PMU检测到该bit后,在第四和第五节流程的基础上,将不再操作power switch,cpu也就不会真正被断电,debug寄存器的内容将被保留。在执行模拟上电流程,core进入run state后,读取EDPRSR.SPD的值将为0,表示debug 寄存器的内容没有丢失。

reference

1)Low Power Interface Specification Arm Q-Channel and P-Channel Interfaces
2)Arm Cortex-R52 Processor Technical Reference Manual

cortex-R52 CPU的功耗管理之power gating(电源门控)相关推荐

  1. clock gating 和 power gating的区别

        clock gating 时钟门控:门控时钟:时脉闸控     power gating 电源门控:功率门控:功率门限     门控时钟(英语:Clockgating),"门控&qu ...

  2. SylixOS电源管理之外设功耗管理

    1.前言 在这个世界中,任何系统的运转都需要能量.如树木依靠光能生长,如马儿依靠食物奔跑,如计算机系统依靠电能运行.而能量的获取是有成本的,因此如果能在保证系统运转的基础上,尽量节省对能量的消耗,就会 ...

  3. S32K144功耗管理与系统模式控制

    S32K144功耗管理与系统模式控制 1.引言 S32K144是一款NXP以Cortex M4为内核的32位汽车通用芯片,本文主要介绍该芯片的功耗管理与系统模式控制相关内容,如低功耗等运行模式.参考文 ...

  4. 如何查看电脑CPU实时功耗

    原文链接: CPU官方TDP数据只是逗你玩?教你看CPU真实功耗 1. 下载HWINFO软件 HWINFO:点此进入官网 HWINFO其实在玩家圈子也算颇有名气了,这是一款来自国外的专业硬件监控软件, ...

  5. 指南-Luat二次开发教程指南-功能开发教程-功耗管理

    目录 功耗管理 简介 常用模块功耗指标 API说明 3种工作模式: 1. 全功能模式 2. 休眠模式 3. 最少功能模式 实现流程 全功能模式 休眠模式 最少功能模式 示例 全功能模式 休眠模式 最少 ...

  6. OSAL 之功耗管理

    尊重原创,转载请注明: 基于蓝牙4.0,协议栈版本是1.3.2 在OSAL中的OSAL_PwrMgr.c与OSAL_PwrMgr.h两个文件实现对功耗的控制. 首先是功耗管理的结构体定义 typede ...

  7. CPU运行功耗和什么相关?消耗的电能都去哪了?

    以下内容转载自 https://www.toutiao.com/i6651662936500601352/ 原创老狼zhihu2019-01-31 16:36:07 很久很久以前,在邀请下,有人问我一 ...

  8. STM8S---电源功耗管理之停机模式(halt)实现

    官方资料   可以去网络搜索中文版,或者到官方网站上去下载英文版.   英文:   译文: 主要内容简介 影响功耗的主要因素 电源系统 时钟管理 运行模式和低功耗模式 运行模式 等待模式 活跃停机模式 ...

  9. a76比a73强多少_ARM发布Cortex A76 CPU和Mali-G76 GPU(性能、参数规格)

    ­ 6月1日早间消息,ARM发布新的高性能CPU和GPU设计,分别是Cortex A76和Mali G76. ­ A76由Austin团队设计,和A57/A72一脉相承.作为比较,A73/A75是So ...

最新文章

  1. first day
  2. 【深度学习】基于Torch的Python开源机器学习库PyTorch卷积神经网络
  3. 图像理解之物体检测object detection,模型rcnn/fastrcnn/fasterrcnn原理及概念
  4. MySQL索引底层原理理解以及常见问题总结
  5. python的安装包下载_科学网—[转载]python常用的安装包下载 - 林清莹的博文
  6. php会不会被人工智能取代,为什么这9种工作不会被人工智能取代?
  7. 虚拟机系列 | JVM运行时数据区
  8. 20非常有用的Java程序片段(11-15)
  9. 无线网和网吧服务器,吧也无线?网吧无线网解决方案
  10. [转] Noise Contrastive Estimation 噪声对比估计 资料
  11. 好用的桌面搜索引擎(如果你的快捷方式很多,可能会需要它)
  12. 华为云IoT提出万物互联新范式,从万物感知到万物生长
  13. buck电路上下管_BUCK/BOOST电路原理
  14. 3岁女儿被骑摩托车男子一把抱走警方贴出寻人启事
  15. html 限制每行字数,毕业论文每行字数的设置
  16. 一个简单又诡异的互联网变现思维(抖音赚钱)
  17. java list控件_java Swing中对于JList控件的使用(一)
  18. 华为IoT生态品牌扩大朋友圈,方舟实验室首度亮相...
  19. freemodbus多从机支持
  20. 国家开放大学《国际经济法》第八章 国际货币金融法 边学边练

热门文章

  1. 在jetson nano上安装ROS melodic
  2. Echarts中对地图的指定区域文字展示指定的颜色
  3. 全球及中国电动破壁机行业产销模式及投资盈利分析报告2021-2027年
  4. Java之 Spring Cloud 微服务的 SpringCloud Config 配置中心(第四个阶段)【二】【SpringBoot项目实现商品服务器端调用】
  5. 轻松理解kotlin中标准函数let、run、with、apply、also的区别
  6. 使用Markdown语法编写数学公式(详细版)
  7. FreeRTOS 解析
  8. LoadRunner提问求助 失败: “[10054] 对等端已重置连接” [MsgId: MERR-27780] 是什么
  9. 晓夏 c语言,【最爱李霄云】今早二妹我翘课了……
  10. dell服务器r730老自动重启_戴尔R730 R720服务器故障维修