| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 嵌入式 -> cortex-R52 CPU的功耗管理之power gating(电源门控) -> 正文阅读 |
|
[嵌入式]cortex-R52 CPU的功耗管理之power gating(电源门控) |
最近在看CORTEX-R52文档时,了解了一下该处理器功耗管理相关的内容,这里记录一下power gating的部分,并加上一些自己的理解。 1.概述power gating是一种直接关闭芯片上某一部分电路电源,以彻底节省该电路功耗(包括静态功耗和动态功耗)的方法。虽然ARM在发布处理器IP时,会给出推荐的power domain划分和电源管理方式,但具体的实现还是取决于芯片设计者实际确定的power domain划分及PMU(电源管理单元)的设计。 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是否需要上电。 COREPACTIVEx是一个2bit信号, bit[0] 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将执行以下操作: 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 寄存器的内容没有丢失。 reference1)Low Power Interface Specification Arm Q-Channel and P-Channel Interfaces 2)Arm Cortex-R52 Processor Technical Reference Manual |
|
嵌入式 最新文章 |
基于高精度单片机开发红外测温仪方案 |
89C51单片机与DAC0832 |
基于51单片机宠物自动投料喂食器控制系统仿 |
《痞子衡嵌入式半月刊》 第 68 期 |
多思计组实验实验七 简单模型机实验 |
CSC7720 |
启明智显分享| ESP32学习笔记参考--PWM(脉冲 |
STM32初探 |
STM32 总结 |
【STM32】CubeMX例程四---定时器中断(附工 |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/26 3:49:40- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |