首页
学习
活动
专区
工具
TVP
发布
您找到你想要的搜索结果了吗?
是的
没有找到

Linux 电源管理子系统

Linux 电源管理非常复杂,牵扯到系统级的待机、频率电压变换、系统空闲时的处理以及每个设备驱动对系统待机的支持和每个设备的运行时(Runtime)电源管理,可以说它和系统中的每个设备驱动都息息相关。...对于消费电子产品来说,电源管理相当重要。因此,这部分工作往往在开发周期中占据相当大的比重,下图呈现了 Linux 内核电源管理的整体架构。...7)设备的运行时动态电源管理,根据使用情况动态开关设备。 8)底层的时钟、稳压器、频率/电压表(OPP模块完成)支撑,各驱动子系统都可能用到。...6、Regulator 驱动 Regulator是Linux系统中电源管理的基础设施之一,用于稳压电源管理,是各种驱动子系统中设置电压的标准接口。...在开机的过程中,TI OMAP4芯片会注册针对CPU设备的OPP表(代码位于arch/arm/mach-omap2/中) 8、PM QoS Linux内核的PM QoS系统针对内核和应用程序提供了一套接口

2.7K20

Linux 电源管理子系统

Linux 电源管理非常复杂,牵扯到系统级的待机、频率电压变换、系统空闲时的处理以及每个设备驱动对系统待机的支持和每个设备的运行时(Runtime)电源管理,可以说它和系统中的每个设备驱动都息息相关。...对于消费电子产品来说,电源管理相当重要。因此,这部分工作往往在开发周期中占据相当大的比重,下图呈现了 Linux 内核电源管理的整体架构。...7)设备的运行时动态电源管理,根据使用情况动态开关设备。 8)底层的时钟、稳压器、频率/电压表(OPP模块完成)支撑,各驱动子系统都可能用到。...6、Regulator 驱动 Regulator是Linux系统中电源管理的基础设施之一,用于稳压电源管理,是各种驱动子系统中设置电压的标准接口。...在开机的过程中,TI OMAP4芯片会注册针对CPU设备的OPP表(代码位于arch/arm/mach-omap2/中) 8、PM QoS Linux内核的PM QoS系统针对内核和应用程序提供了一套接口

3.8K20

Linux电源管理-Linux regulator framework概述

一般电源管理芯片(Power Management IC)中会包含一个甚至多个regulator。 2. regulator有什么作用? 通常的作用是给电子设备供电。...如果一个regulator控制多个设备,而每个设备的电压或电流需求方式不同,linux regulator framework会怎么管理这些设备? 3....有些设备只需要enable/disable电源即可,而有些设备在运行的过程中需要动态的改变voltage或者current,Linux regulator Framework会如何处理这些问题?....uV_offset: consumer看到的电源和实际电源之间的偏移值,用于电源补偿。 .min_uA/max_uA: 最小/最大的输出电流。....ramp_delay: 改变电压到电源稳定后时间。因为硬件原因,改变电源后不能立刻就成功,其中需要有一定的延迟。 .enable_time: regulator的使能时间。

3.6K52

深入理解Linux电源管理

目录: 一、电源管理框架 1.1 电源状态管理 1.2 省电管理 1.3 电源管理质量 二、睡眠与休眠 2.1 冻结进程 2.2 睡眠流程...但是当硬件运行起来之后,软件就可以对硬件的电源状态进行管理了。电源管理的内容包括电源状态管理和省电管理电源状态管理是对整个系统的供电状态进行管理,内容包括睡眠、休眠、关机、重启等操作。...6.2 设备级约束 暂略 linux-src/drivers/base/power/qos.c 七、总结回顾 通过本文我们对计算机的电源管理有了一个基本的了解,下面我们再看图回忆一下: 电源管理分为电源状态管理和省电管理两个重要组成部分...电源状态管理是对计算机的电源状态进行管理,包括睡眠、休眠、关机、重启等。省电管理是内核中的一些省电机制,可以很好的帮我们节省电力。...光一味地省电也不行,还得考虑计算机的性能,所以电源管理中还有PM QoS来保证电源管理的服务质量,使得计算机的运行还要满足一定的性能需求。

5.5K50

Linux电源管理-wakeup events framework

Linux系统中的电源管理一般是冷睡眠,而Android系统却将linux系统中的睡眠作为通常待机使用,显然Linux中的电源管理不符合Android系统。...Android说既然不符合,我就给你改到符合,早期Android就提出了"wakelocks"机制,这种机制将Linux原生的睡眠唤醒流程改变,增加Android自己的处理函数,在一段时间这种机制可以解决...所以Linux在2.6.36中引入了wakeup events framework机制,用来解决suspend和wakeup events之间的同步问题。....entry: 用来将唤醒源挂到链表上,用于管理。 .lock: 同步机制,用于访问链表时使用。 .timer: 定时器,用于设置该唤醒源的超时时间。...在linux系统中,只有具有唤醒系统的设备才叫做“wakeup source”。 既然只有设备才能唤醒系统,那设备结构体struce device中就应该有某种标志代表此设备是否具有唤醒的能力。

3.4K32

Linux 电源管理及实例分析

1、Linux 电源管理的组成 电源管理(Power Management)在 Linux Kernel 中,是一个比较庞大的子系统,涉及到供电(Power Supply)、充电(Charger)、时钟...注3:Runtime PM 是 Linux Kernel 亲生的运行时电源管理机制,Wakelock 是由 Android 提出的机制。这两种机制的目的是一样的,因此只需要支持一种即可。...通过 QOS 参数,可以分析、改善系统的性能 2、电源管理源码目录 kernel/power/ drivers/power/ drivers/base/power/ drivers/cpuidle/ drivers.../xxx.txt 电源管理的东西很多,大家没必要每个都学一遍,用到的时候去研究即可。...研究了一下 Linux 电源管理子系统,发现 Qos 有接口可以使用:在某一段时间内拉 Qos,可以让 CPU 在这段时间不进入 idle,使用完毕再去掉 Qos,让 CPU 可以进入 idle,这样满足了性能需求

3.9K21

Linux电源管理(9)_wakelocks【转】

同时,该补丁集更改了Linux kernel原生的电源管理执行过程(kernel/power/main.c中的state_show和state_store),转而执行自定义的state_show、state_store...就像国内很多的Linux开发团队,要实现某个功能,都不去弄清楚kernel现有的机制、框架,牛逼哄哄的猛干一番。最后功能是实现了,可都不知道重复造了多少轮子,浪费了多少资源。...以阻止睡眠、注销wakelock以允许睡眠:已经由“Linux电源管理(7)_Wakeup events framework”所描述的wakeup source取代。...3.2 Kernel wakelocks在电源管理中的位置 相比Android wakelocks,Kernel wakelocks的实现非常简单(简单的才是最好的),就是在PM core中增加一个wakelock...注1:上面有关wakeup source的操作接口,可参考“Linux电源管理(7)_Wakeup events framework”。

1.6K10

Linux电源管理(7)_Wakeup events framework

前言 本文继续“Linux电源管理(6)_Generic PM之Suspend功能”中有关suspend同步以及PM wakeup的话题。...这个话题,是近几年Linux kernel最具争议的话题之一,在国外Linux开发论坛,经常可以看到围绕该话题的辩论。辩论的时间跨度和空间跨度可以持续很长,且无法达成一致。...但事实上,该同步问题牵涉到了另外一个比较有争议的话题:日常的电源管理机制。是否要基于suspend实现?系统何时进入低功耗状态,应该由谁决定?kernel还是用户空间程序?...而在运行时的电源管理过程中,系统何时进入低功耗状态,也不是用户空间程序能决定的(auto sleep中枪了)。...这表现在suspend过程中频繁调用pm_wakeup_pending接口上(可参考“Linux电源管理(6)_Generic PM之Suspend功能”)。

2.8K21

Linux电源管理(11)_Runtime PM之功能描述

因为从个人的角度讲,我很推崇使用RPM进行日常的动态电源管理,而不是suspend机制。 软件工程的基本思想就是模块化:高内聚和低耦合。...而RPM正体现了这一思想:每个设备(包括CPU)都处理好自身的电源管理工作,尽量以最低的能耗完成交代的任务,尽量在不需要工作的时候进入低功耗状态,尽量不和其它模块有过多耦合。...很不幸,到目前为止,linux kernel的runtime PM还是很复杂。这里的复杂,不是从实现的角度,而是从对外的角度。...这就是当前Linux kernel电源管理中“Opportunistic suspend”和RPM两种机制并存的原因。...但是,就算现状不理想,也不能否认RPM的先进性,在当前以及未来很长的一段时间内,它会是kernel电源管理更新比较活跃的部分,因为可以做的还很多。

2.2K20
领券