wakelock可以被内核空间 申请和释放。如果申请的是非超时锁wake_lock,需要相应的调用wake_unlock来释放,而超时锁则不需要手工释放(当然你也可以手工释放),超时后kernel系统会自动释放锁,在内核空间可以直接调用wake_lock, wake_lock_timeout 申请锁 Android kernel为用户空间提供了申请和释放wakelock的接口,实现在kernel/power/userwakelock.c中。
实例:
1:首先申明一个wake_lock
static struct wake_lock alarm_rtc_wake_lock;
2:在init函数中对wake_lock初始化
wake_lock_init(&alarm_rtc_wake_lock, WAKE_LOCK_SUSPEND, "alarm_rtc");//WAKE_LOCK_SUSPEND 为suspend lock还有一种idle lock
WAKE_LOCK_SUSPEND, /* Prevent suspend */
WAKE_LOCK_IDLE, /* Prevent low power idle*/
3:使用wake_lock()或者wake_lock_timeout()
wake_lock_timeout(&alarm_rtc_wake_lock, 1 * HZ);
wake_lock(&alarm_rtc_wake_lock);
4:使用wake_unlock()
wake_unlock(&alarm_rtc_wake_lock);
4:在exit中调用wake_lock_destroy()
wake_lock_destroy(&alarm_rtc_wake_lock);
wake_lock_init(&alarm_rtc_wake_lock, WAKE_LOCK_SUSPEND, "alarm_rtc");
if (is_wakeup && !suspended && head_removed)
wake_unlock(&alarm_rtc_wake_lock);
if (is_wakeup && suspended) {
pr_alarm(FLOW, "changed alarm while suspened\n");
wake_lock_timeout(&alarm_rtc_wake_lock, 1 * HZ);
return;
}
wake_lock(&alarm_rtc_wake_lock);
wake_unlock(&alarm_rtc_wake_lock);
wake_lock_timeout(&alarm_rtc_wake_lock, 1 * HZ);
suspended = false;
wake_lock_timeout(&alarm_rtc_wake_lock, 2 * HZ);
wake_lock_destroy(&alarm_rtc_wake_lock);