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 */
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) if (is_wakeup && suspended) { 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_destroy(&alarm_rtc_wake_lock); 版权声明:本文为博主原创文章 |
|
来自: lifei_szdz > 《android_alarm》