资料:
http://blog.csdn.net/bingqingsuimeng/article/category/1228414
http://os.chinaunix.net/a2006/0519/1002/000001002210.shtml
http://www.ednchina.com/ART_44010_29_0_TA_eeda337e_3.HTM?jumpto=view_welcomead_1408610592294

好文:
http://blog.csdn.net/bingqingsuimeng/article/details/7935414
http://blog.csdn.net/bingqingsuimeng/article/details/8197912
http://blog.sina.com.cn/s/blog_a6559d920101i52j.html

Linux电源管理(1)_整体架构
http://www.wowotech.net/linux_kenrel/pm_architecture.html

Linux电源管理(4)_Power Management Interface
http://www.wowotech.net/linux_kenrel/pm_interface.html

Linux电源管理(6)_Generic PM之Suspend功能
http://www.wowotech.net/linux_kenrel/suspend_and_resume.html

Linux运行时IO设备电源管理框架---PM (runtime power manager)
http://blog.sina.com.cn/s/blog_533074eb0101dnm2.html

Run-time PM 详解
http://blog.csdn.net/bingqingsuimeng/article/details/7935440

电源管理之regulator机制流程
http://blog.csdn.net/bingqingsuimeng/article/details/8216782

linux内核对S3C2410睡眠模式的支持 (讲得很好!)
http://blog.csdn.net/hongtao_liu/article/details/4208988

s3c2440 省电模式开发详解(讲得很好!)
http://blog.chinaunix.net/uid-517401-id-1641576.html

http://www.linuxforum.net/forum/showflat.php?Board=embedded&Number=725416

s3c2440 省电模式开发详解
http://blog.chinaunix.net/uid-517401-id-1641576.html

一、APP_修改数码相框以支持自动关闭LCD

2.Linux下的时间函数与定时器: https://blog.csdn.net/dsg333/article/details/4870639 (未看)
里面在用户空间使用alarm()定时时间到会向本进程发送一个SIGALARM信号!
==>TODO: 查是不是所有的信号都可以从用户空间或内核空间中调用函数发送 ?

3.alarm(seonds):若干秒后内核会发出SIGALARM给APP,APP
可以提供信号处理函数signal(SIGALRM, function)。在function()中调用system("echo 0 > /sys/xxx")
来关闭LCD。

4.实现15s内没有触摸屏幕就关闭LCD的思路:
a. 应用程序注册aignal(SIGALARM, function); function函数中echo auto > /sys/device/platform/mylcd/power/control来关闭LCD和
echo on > /sys/device/platform/mylcd/power/control 来打开LCD。
b.在读取输入事件的进程中执行alarm(15)
c.如果一直没有读取到触摸屏的数据,定时器就会超时导致function()被调用从而关闭LCD。
d.如果读取到数据就再次执行alarm(15),会更新超时时间为当前之后的15s,如果之前关闭过LCD
还需要打开LCD。

5.使用# exec 6</dev/fb0就可以打开fb0 ? TODO : 查bash: exec的使用方法

6.遇到问题与解决
a. echo auto > /sys/device/platform/mylcd/power/control无法正常起作用
查驱动control_store()
中调用的pm_runtime_allow()中判断了若dev->power.runtime_auto为true的话就直接退出了,不会去执行
atomic_dec_and_test(),而dev->power.runtime_auto的初始化值就是true。
解决:
可以先执行echo on > /sys/device/platform/mylcd/power/control让dev->power.runtime_auto为0
原因是control_store()
pm_runtime_forbid
dev->power.runtime_auto = false;
但是仍然不能满足需求,因为open(/dev/fb0)会会使LCD的引用计数加1
,在echo on到control又会使LCD的应用计数加1。执行echo auto
时只会把引用计数减1,引用计数并不为0,所以不会关闭LCD。
解决:
在驱动中的lcd_open()中将pm_runtime_get_sync()换成pm_runtime_forbid();来增加引用计数,
后者不但会增加引用计数还会使dev->power.runtime_auto = false。
在close()调用的release()函数中也对应将pm_runtime_put_sync_autosuspend()换成
pm_runtime_allow()。

7.Linux内核电源管理子系统源码:drivers\base\power

TODO:查找电源管理子系统的文档学习。

二、APP_编写支持开关机(suspend)的应用程序

1.编写支持开关机(suspend)的应用程序
思路:读按键,得到某个值就执行echo mem > /sys/power/state 让系统休眠

2.hexdump /dev/event1可以来监听事件,不过打印出来的都是16进制数而已。

三、从系统角度考虑电源管理,我们要学习更多

1.优秀博文推荐:
Linux电源管理(1)_整体架构: www.wowotech.net/pm_architecture.html (未看)

2.Linux内核menuconfig的Device Drivers栏下中有DVFS,动态地调节电压和频率,当CPU的负载
不是很高的时候可以让CPU的频率降下来。

3.PM QOS的接口学习参考内核文档pm_qos_interface.txt,它是关于cpu dma延时,网络延时等
来省电的。

4.APP可以省电的做法
a. 比如明确知道此时不使用视频编解码模块的时候可以把它关掉,因为它是非常耗电的。
b. 不要去频繁地无用地去读写文件,因为eMMC也是非常耗电的。
c. 充分利用CPU的cache来降低内存的耗电

5.硬件省电
a. 如果芯片有省电模式,尽量用起来。
b. 如果芯片能关闭,给它提供开关,比如单独供电。
c. 使用效率高的电源芯片。
d. 如果可以就使用PMU(它集成了若干个DC/DC或LDO,它可以给芯片单独供电和提供开关,甚至可以调节电流大小)
LDO: 输入电压和输出电压相差不大,外围器件比较少,干扰小,但是效率低。它的输入端和输出端的电流和功率不变Vin*Iin=Vout*Iout + 发热
DC-DC: 效率比较高,但是可能会带来干扰。DC-DC也简称为BUCK。

6.手机电路图大全:http://pan.baidu.com/s/1sjJgKOH (目前已经访问不到了)

7.基本在iPhone中每个硬件模块都是单独供电的。在不需要的时候就可以断电

Linux内核电源管理综述的更多相关文章

  1. Linux内核内存管理算法Buddy和Slab: /proc/meminfo、/proc/buddyinfo、/proc/slabinfo

    slabtop cat /proc/slabinfo # name <active_objs> <num_objs> <objsize> <objpersla ...

  2. linux驱动程序之电源管理之linux的电源管理架构(3)

    设备电源管理 Copyright (c) 2010 Rafael J. Wysocki<rjw@sisk.pl>, Novell Inc. Copyright (c) 2010 Alan ...

  3. Linux内核内存管理子系统分析【转】

    本文转载自:http://blog.csdn.net/coding__madman/article/details/51298718 版权声明:本文为博主原创文章,未经博主允许不得转载. 还是那张熟悉 ...

  4. Linux内核内存管理

    <Linux内核设计与实现>读书笔记(十二)- 内存管理   内核的内存使用不像用户空间那样随意,内核的内存出现错误时也只有靠自己来解决(用户空间的内存错误可以抛给内核来解决). 所有内核 ...

  5. linux内核--内存管理(二)

    一.进程与内存     所有进程(执行的程序)都必须占用一定数量的内存,它或是用来存放从磁盘载入的程序代码,或是存放取自用户输入的数据等等.不过进程对这些内存的管理方式因内存用途不一而不尽相同,有些内 ...

  6. Linux内核——进程管理与调度

    进程的管理与调度 进程管理 进程描写叙述符及任务结构 进程存放在叫做任务队列(tasklist)的双向循环链表中.链表中的每一项包括一个详细进程的全部信息,类型为task_struct,称为进程描写叙 ...

  7. linux内核内存管理(zone_dma zone_normal zone_highmem)

    Linux 操作系统和驱动程序运行在内核空间,应用程序运行在用户空间,两者不能简单地使用指针传递数据,因为Linux使用的虚拟内存机制,用户空间的数据可能被换出,当内核空间使用用户空间指针时,对应的数 ...

  8. Linux内核内存管理架构

    内存管理子系统可能是linux内核中最为复杂的一个子系统,其支持的功能需求众多,如页面映射.页面分配.页面回收.页面交换.冷热页面.紧急页面.页面碎片管理.页面缓存.页面统计等,而且对性能也有很高的要 ...

  9. Linux内核——内存管理

    内存管理 页 内核把物理页作为内存管理的基本单位.内存管理单元(MMU,管理内存并把虚拟地址转换为物理地址)通常以页为单位进行处理.MMU以页大小为单位来管理系统中的页表. 从虚拟内存的角度看,页就是 ...

随机推荐

  1. (转)理解TIME_WAIT,彻底弄清解决TCP: time wait bucket table overflow

    转载自http://blog.51cto.com/benpaozhe/1767612: 一直对这个问题知其然而不知其所以然,这些日子再次碰到,看了很多的资料,彻底解决一下,呵呵,先上个图,所有理解围绕 ...

  2. Java中HashMap的实现原理

    最近面试中被问及Java中HashMap的原理,瞬间无言以对,因此痛定思痛觉得研究一番. 一.Java中的hashCode和equals 1.关于hashCode hashCode的存在主要是用于查找 ...

  3. Java数组常用API

    java.util.Arrays Arrays.asList() 数组转换成列表 String[] strArray = {"zhang", "xue", &q ...

  4. Mysql查询用逗号分隔的字段-字符串函数FIND_IN_SET(),以及此函数与in()函数的区别

    查询用逗号分隔的字段,可以用字符串函数FIND_IN_SET(): 查询数据库表中某个字段(值分行显示),可以用函数in(). 今天工作中遇到一个问题,就是用FIND_IN_SET()函数解决的. 第 ...

  5. Servlet 与 CGI 的比较

    和CGI程序一样,Servlet可以响应用户的指令(提交一个FORM等等),也可以象CGI程序一样,收集用户表单的信息并给予动态反馈(简单的注册信息录入和检查错误).然而,Servlet的机制并不仅仅 ...

  6. Shell脚本的学习(一)

    Shell脚本的学习(一) 一)代码式shell脚本简介 1.下载 Xshell 5 建一个文件夹 mkdri home/data ; 1)查看一个在data里建一个1.sh 查看是否建立成功. 2) ...

  7. openssl 自建CA签发证书 网站https的ssl通信

    <<COMMENTX509 文件扩展名 首先我们要理解文件的扩展名代表什么.DER.PEM.CRT和CER这些扩展名经常令人困惑.很多人错误地认为这些扩展名可以互相代替.尽管的确有时候有些 ...

  8. 获取Oracle数据库awr报告方法

    --登录数据库  sqlplus username/passwd; --运行生成AWR报告脚本  SQL> @?/rdbms/admin/awrrpt.sql; --输入要生成报告的格式:htm ...

  9. $digest already in progress 解决办法

    Solution In short, instead of doing this: ... your controller code... $http.get('some/url', function ...

  10. 6.pragma pack

    下面两个结构体 struct One { double d; char c; int i; } struct Two { char c; double d; int i; } 在#pragma pac ...