在wakelock.c中声明了一个工作队列suspend_work_queue
struct workqueue_struct *suspend_work_queue;
然后创建它,这个工作队列是earlysuspend的核心
suspend_work_queue = create_singlethread_workqueue("suspend");
在earlysuspend.c中声明了两个工作early_suspend_work和late_resume_work,
static DECLARE_WORK(early_suspend_work, early_suspend);
static DECLARE_WORK(late_resume_work, late_resume);
然后在request_suspend_state函数中,根据之前的电源状态和请求状态,分别将它们插入到上面的工作队列中
if (!old_sleep && new_state != PM_SUSPEND_ON) {
state |= SUSPEND_REQUESTED;
queue_work(suspend_work_queue, &early_suspend_work);
} else if (old_sleep && new_state == PM_SUSPEND_ON) {
state &= ~SUSPEND_REQUESTED;
wake_lock(&main_wake_lock);
queue_work(suspend_work_queue, &late_resume_work);
}
插入到工作队列后,工作队列会安排执行工作,也就是执行early_suspend或late_resume函数。
list_for_each_entry(pos, &early_suspend_handlers, link) {
if (pos->suspend != NULL) {
if (debug_mask & DEBUG_VERBOSE)
pr_info("early_suspend: calling %pf\n", pos->suspend);
pos->suspend(pos);
}
}
在early_suspend函数里,历遍early_suspend_handlers链表。在earlysuspend.c的一开始就声明了一个全局静态的early_suspend_handlers链表
static LIST_HEAD(early_suspend_handlers);