【Android休眠】引申之关于系统PM的思考
来源:互联网 发布:linux终端命令大全 编辑:程序博客网 时间:2024/05/17 07:46
http://blog.csdn.net/u013686019/article/details/54668873
一、开篇
对于一个完整的系统,我们在做PM(Power Manager)相关的事情时,应该(至少)其休眠涉及三个部分:
- 用户(User Space)
- CPU(Kernel)
- 外设
关系图示:
二、用户(User Space)
作为完成具体业务的角色,它产生是否允许系统进行休眠的消息。Kernel对消息做出休眠/继续工作的反应。
比如:
Android设备后台在播放音乐,那么播放器就会采取一定方式(比如休眠锁的方式)告知系统不能休眠;Kernel得到禁止休眠的消息就一直处于工作状态。
三、CPU(Kernel)
这里,CPU针对硬件,Kernel针对运行在CPU中的软件(Linux)。CPU硬件支持某几种休眠模式,由Kernel实现对这几种休眠模式的控制。
Kernel除了控制CPU外,还提供了访问各种外设的驱动程序;驱动程序中,有一部分代码就是做休眠之类的工作,比如常见的:
#ifdef CONFIG_PMstatic int xxx_suspend(struct platform_device *dev, pm_message_t state){}static int xxx_resume(struct platform_device *dev){}#else#define xxx_suspend NULL#define xxx_resume NULL#endifstatic struct platform_driver xxx_driver = { .suspend= xxx_suspend, .resume = xxx_resume,};
Kernel进入休眠时,调用驱动注册的xxx_suspend()函数,唤醒时调用xxx_resume()函数。
四、外设
这里把外设分作两类:
自带CPU类型的外设:即外设有自己的控制中心,比如4G模组。这种情况下,在休眠/唤醒动作发生时,通过通信链路告知外设执行休眠/唤醒。
被动外设:外设的行为完全由Kernel控制,典型的就是LED。这种情况下的休眠/唤醒比较简单,按照外设支持的方式操作即可,最简单的方式就是断电/上电。
0 0
- 【Android休眠】引申之关于系统PM的思考
- 【Android休眠】引申之uinput: 用户空间的输入子系统
- 关于Android系统休眠后,线程的执行情况
- 关于android不同系统样式的思考
- android 系统的休眠与唤醒+linux 系统休眠
- 【Android休眠】之休眠锁的获取和释放
- Android系统休眠导致的严重问题
- Android系统休眠---踩坑的路
- Android 关于休眠的几个坑点
- Android 关于休眠的几个坑点
- Android 关于休眠的几个坑点
- Android 关于休眠的几个坑点
- Android 关于休眠的几个坑点
- Android 关于休眠的几个坑点
- Android系统移植与调试之------->如何修改Android设备的默认休眠时间
- 防止Android系统休眠
- Android 系统永不休眠
- 关于系统的一点思考
- 算法入门经典学习1——数据统计
- day3
- P1089 津津的储蓄计划
- NFS的安装配置
- 删除windows服务
- 【Android休眠】引申之关于系统PM的思考
- RedisDesktopManager连接不上redis
- iOS即时通讯进阶 - CoacoaAsyncSocket源码解析(Connect篇)
- 页面提交时弹出确认窗口
- mac中修改npm的默认安装来源
- 弱类型和部分类
- 时间格式进行加减运算,偷懒必备(60进制转10进制)
- 数据结构(C++)——队列
- retrofit2.0缓存设置