【Driver】----woke_lock

wakelock是一种锁的机制, 只要有task拿着这个锁, 系统就无法进入休眠, 可以被用户态进程和内核线程获得。这个锁可以是有超时的或者是没有超时的, 超时的锁会在时间过去以后自动解锁。如果没有锁了或者超时了, 内核就会启动标准linux的那套休眠机制机制来进入休眠。

wakelock在android的休眠唤醒机制中扮演着及其重要的角色,主要源码位于文件:kernel/kernel/power/wakelock.c,kernel/include/linux/wakelock.h中。

enum {
WAKE_LOCK_SUSPEND, /* Prevent suspend */
WAKE_LOCK_TYPE_COUNT
};

struct wake_lock {
struct wakeup_source ws;
};

static inline void wake_lock_init(struct wake_lock *lock, int type,
const char *name)
{
wakeup_source_init(&lock->ws, name);
}

static inline void wake_lock_destroy(struct wake_lock *lock)
{
wakeup_source_trash(&lock->ws);
}

static inline void wake_lock(struct wake_lock *lock)
{
__pm_stay_awake(&lock->ws);
}

static inline void wake_lock_timeout(struct wake_lock *lock, long timeout)
{
__pm_wakeup_event(&lock->ws, jiffies_to_msecs(timeout));
}

static inline void wake_unlock(struct wake_lock *lock)
{
__pm_relax(&lock->ws);
}

static inline int wake_lock_active(struct wake_lock *lock)
{
return lock->ws.active;
}

WAKE_LOCK_SUSPEND – 这种锁如果被某个task持有,那么系统将无法进入休眠。

wakelock有两种形式的锁:超时锁和非超时锁,这两种形式的锁都是使用函数wake_lock_init()来初始化,只是在上锁的时候会有一点点差别,超时锁使用函数wake_lock_timeout(),而非超时锁使用函数wake_lock(), 这个两个函数会最终调用到同一个函数wake_lock_internal(),该函数依靠传入的不同参数来选择不同的路径来工作。值得注意的是,非超时锁必须手工解锁,否则系统永远不能进入睡眠。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是一个使用 pthread_cond_timedwait 的简单示例: ```c #include <stdio.h> #include <stdlib.h> #include <pthread.h> #include <time.h> pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER; pthread_cond_t cond = PTHREAD_COND_INITIALIZER; void* thread_func(void* arg) { struct timespec ts; clock_gettime(CLOCK_REALTIME, &ts); ts.tv_sec += 5; // 设置等待时间为5秒 pthread_mutex_lock(&mutex); int ret = pthread_cond_timedwait(&cond, &mutex, &ts); if (ret == 0) { printf("Thread woke up before timeout.\n"); } else if (ret == ETIMEDOUT) { printf("Thread timed out.\n"); } else { printf("Error waiting on condition variable.\n"); } pthread_mutex_unlock(&mutex); return NULL; } int main() { pthread_t thread; pthread_create(&thread, NULL, thread_func, NULL); // 做一些其他的工作 pthread_cond_signal(&cond); // 唤醒等待线程 pthread_join(thread, NULL); return 0; } ``` 在上面的示例中,主线程创建了一个新线程,然后做一些其他的工作。在等待线程函数中,它使用 clock_gettime 来获取当前时间,并在当前时间的基础上增加5秒,表示等待的超时时间。然后调用 pthread_cond_timedwait 函数等待条件变量的信号,如果在超时之前收到信号,则会打印 "Thread woke up before timeout.",如果超时,则会打印 "Thread timed out."。 在主线程中,我们调用 pthread_cond_signal 函数来唤醒等待线程。最后,我们使用 pthread_join 等待子线程结束。 请注意,这只是一个简单的示例,实际使用时需要根据具体的需求进行适当的修改和错误处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值