Android suspend-to-mem 流程分析

2023-10-05 02:59

本文主要是介绍Android suspend-to-mem 流程分析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 实验平台

cpu: omap4460 blaze tablet

memory: 1-GB DRAM

OS: android 4.0.3, kernel 3.0.31


2.流程分析

1). echo "mem" > /sys/power/state
2). state_store() kernel/power/main.c  
3). request_suspend_states(PM_SUSPEND_MEM)  kernel/power/earlysuspend.c
4). queue_work(suspend_work_queue, &early_suspend_work)  kernel/power/earlysuspend.c 
early_suspend() 
// call device driver's early-suspend function to turn off multi-touch, LCM, frame buffer,sensors,release "main" wakelock
5). wake_unlock(&main_wake_lock)  kernel/power/wakelock.c  
          // if system has no activate wakelock,call kernel/power/wakelock.c suspend() start suspend progress.
6). queue_work(suspend_work_queue, &suspend_work);
7). suspend()
sys_sync()
pm_suspend()  
// here enter suspend
// return from this function means exit suspend(resume)

8). pm_suspend(PM_SUSPEND_MEM)
enter_state()
sys_sync()
suspend_prepare()
pm_notifier_call_chain(PM_SUSPEND_PREPARE)        
suspend_freeze_processes()
freeze_processes() kernel/power/process.c
//  the same as hibernation process to freeze user space process and task in kernel
pm_restrict_gfp_mask()
//  avoid i/o and fs to allocate memory during suspend progress
//  clear bit GFP_IOFS of gfp_allowed_mask
suspend_devices_and_enter()
omap4_pm_begin()  arch/arm/mach-omap2/pm44xx.c 
suspend_prepare() drivers/regulator/core.c
// regulator linked with regulator_list     
suspend_console()
dpm_suspend_start(PMSG_SUSPEND)
dpm_prepare(PMSG_SUSPEND)  drivers/base/power/main.c
// execute ->prepare() callback for all non-sysdev devices, device list movement dpm_list-->dpm_prepared_list
dpm_suspend(PMSG_SUSPEND)
// execute ->suspend() callback for all non-sysdev devices, device list movement dpm_prepared_list-->dpm_suspended_list                
suspend_enter()
dpm_suspend_noirq(PMSG_SUSPEND)
// execute "late suspend"
suspend_device_irqs() kernel/irq/pm.c
// disable all currently enabled interrupt lines
// after this function, device will can't receive interrupt
device_suspend_noirq()   
// execute -->suspend_noirq callback for all non-sysdev devices, device list movement dpm_suspended_list-->dpm_noirq_list                       
disable_nonboot_cpus()
arch_suspend_disable_irqs() kernel/power/suspend.c
local_irq_disable()
// disable local cpu interrupt,so there will no interrtup from now on
syscore_suspend()  driver/base/syscore.c
// Execute all the registered system core suspend callbacks
check_wakeup_irqs() kernel/irq/pm.c
// check if any wakeup interrupts are pending, if ture, exit suspend
// then to execute sysdev's suspend callback, all sysdev are linked with syscore_ops_list      
omap4_pm_enter() arch/arm/mach-omap2/pm4xx.c
omap2_pm_wakeup_on_timer() arch/arm/mach-omap2/pm-debug.c
//  setup a hareware timer if debug enabled
omap4_configure_pwrst(off_mode_enabled)
// Program all powerdomain(except cpu0_pwrdm and cpu1_pwrdm) to required power domain state
// powerdomain linked with pwrst_list
// off_mode_enabled = 1
omap4_device_set_state_off(1)
// setup device off state   
omap4_enter_sleep()
pwrdm_clear_all_prev_pwrst() 
//Clear the powerdomain's previous power state
omap4_device_clear_prev_off_state()   
pwrdm_read_next_pwrst()
//get next powerdomain power state
omap2_gpio_prepare_for_idle()
omap2_gpio_set_wakeupenables()
// enable wakeup gpio in the list omap_gpio_list
omap4_print_wakeirq()
// resuming. 
// Print wakeup interrupt for debug
xxxxxxx     


这篇关于Android suspend-to-mem 流程分析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/3252

相关文章

Nginx分布式部署流程分析

《Nginx分布式部署流程分析》文章介绍Nginx在分布式部署中的反向代理和负载均衡作用,用于分发请求、减轻服务器压力及解决session共享问题,涵盖配置方法、策略及Java项目应用,并提及分布式事... 目录分布式部署NginxJava中的代理代理分为正向代理和反向代理正向代理反向代理Nginx应用场景

Redis中的有序集合zset从使用到原理分析

《Redis中的有序集合zset从使用到原理分析》Redis有序集合(zset)是字符串与分值的有序映射,通过跳跃表和哈希表结合实现高效有序性管理,适用于排行榜、延迟队列等场景,其时间复杂度低,内存占... 目录开篇:排行榜背后的秘密一、zset的基本使用1.1 常用命令1.2 Java客户端示例二、zse

Redis中的AOF原理及分析

《Redis中的AOF原理及分析》Redis的AOF通过记录所有写操作命令实现持久化,支持always/everysec/no三种同步策略,重写机制优化文件体积,与RDB结合可平衡数据安全与恢复效率... 目录开篇:从日记本到AOF一、AOF的基本执行流程1. 命令执行与记录2. AOF重写机制二、AOF的

Spring Boot分层架构详解之从Controller到Service再到Mapper的完整流程(用户管理系统为例)

《SpringBoot分层架构详解之从Controller到Service再到Mapper的完整流程(用户管理系统为例)》本文将以一个实际案例(用户管理系统)为例,详细解析SpringBoot中Co... 目录引言:为什么学习Spring Boot分层架构?第一部分:Spring Boot的整体架构1.1

nodejs打包作为公共包使用的完整流程

《nodejs打包作为公共包使用的完整流程》在Node.js项目中,打包和部署是发布应用的关键步骤,:本文主要介绍nodejs打包作为公共包使用的相关资料,文中通过代码介绍的非常详细,需要的朋友可... 目录前言一、前置准备二、创建与编码三、一键构建四、本地“白嫖”测试(可选)五、发布公共包六、常见踩坑提醒

MyBatis Plus大数据量查询慢原因分析及解决

《MyBatisPlus大数据量查询慢原因分析及解决》大数据量查询慢常因全表扫描、分页不当、索引缺失、内存占用高及ORM开销,优化措施包括分页查询、流式读取、SQL优化、批处理、多数据源、结果集二次... 目录大数据量查询慢的常见原因优化方案高级方案配置调优监控与诊断总结大数据量查询慢的常见原因MyBAT

分析 Java Stream 的 peek使用实践与副作用处理方案

《分析JavaStream的peek使用实践与副作用处理方案》StreamAPI的peek操作是中间操作,用于观察元素但不终止流,其副作用风险包括线程安全、顺序混乱及性能问题,合理使用场景有限... 目录一、peek 操作的本质:有状态的中间操作二、副作用的定义与风险场景1. 并行流下的线程安全问题2. 顺

Ubuntu向多台主机批量传输文件的流程步骤

《Ubuntu向多台主机批量传输文件的流程步骤》:本文主要介绍在Ubuntu中批量传输文件到多台主机的方法,需确保主机互通、用户名密码统一及端口开放,通过安装sshpass工具,准备包含目标主机信... 目录Ubuntu 向多台主机批量传输文件1.安装 sshpass2.准备主机列表文件3.创建一个批处理脚

MyBatis/MyBatis-Plus同事务循环调用存储过程获取主键重复问题分析及解决

《MyBatis/MyBatis-Plus同事务循环调用存储过程获取主键重复问题分析及解决》MyBatis默认开启一级缓存,同一事务中循环调用查询方法时会重复使用缓存数据,导致获取的序列主键值均为1,... 目录问题原因解决办法如果是存储过程总结问题myBATis有如下代码获取序列作为主键IdMappe

一个Java的main方法在JVM中的执行流程示例详解

《一个Java的main方法在JVM中的执行流程示例详解》main方法是Java程序的入口点,程序从这里开始执行,:本文主要介绍一个Java的main方法在JVM中执行流程的相关资料,文中通过代码... 目录第一阶段:加载 (Loading)第二阶段:链接 (Linking)第三阶段:初始化 (Initia