pthread_mutex_lock
和pthread_cond_wait
在Linux内核中的等效操作是什么,如何使用它们?能否提供简单的(hello world)示例。
pthread_mutex_lock
和pthread_cond_wait
在Linux内核中的等效操作是什么,如何使用它们?能否提供简单的(hello world)示例。
使用mutex_lock()
和mutex_unlock()
,在使用之前应使用mutex_init()
初始化互斥量(来自#include <linux/mutex.h>
)
pthread_cond_wait
的等效操作使用wait_event_interruptible()
和wake_up_interruptible()
,在使用之前应使用init_waitqueue_head()
初始化wait_queue_head(来自#include <linux/wait.h>
)
/**
* Atomically give up the mutex and wait on the condition variable.
* Wake up if the specified timeout elapses, or if a signal is delivered.
* Additionally, also wait on the specified file descriptors to become
* ready, combining condition waiting with poll().
* KCOND_WAIT_SUCCESS means the condition was signaled, or one or more
* file descriptors are ready.
* Also, a negative value can be returned indicating an error!
* (The poll needs to dynamically allocate some memory for the wait table).
* The timeout is relative to the current time, specifying how long to sleep in
* jiffies (CPU clock ticks).
*/
int kcond_timed_wait_rel_poll(kcond_t *, kmutex_t *, long,
kcond_poll_t *, unsigned int);
kcond_poll_t
结构体数组是需要您自己创建和填充的,该结构体如下所示。它有一个类型字段,因此您可以等待套接字(struct socket *
)或文件(struct file *
):
/**
* Structure for file-descriptor polling condition waits.
* This resembles struct pollfd, but uses a direct file descriptor
* pointer rather than a file descriptor number. Also,
* it contains the wait queue by which the process is enqueued
* to wait on that descriptor. Thus our poll function doesn't
* have to dynamically allocate wait queue tables. It gets
* them from this array! (But this means that the array cannot
* be used by multiple threads at the same time to do polling!)
*/
typedef struct {
kcond_poll_type_t type; /* Must set this. */
union { /* Must set union field according to type. */
struct file *file;
struct socket *sock;
} obj;
short events; /* And this. */
short revents; /* Check response in this. */
wait_queue_t wait; /* Internal, don't set. */
wait_queue_head_t *queue; /* Internal, don't set */
} kcond_poll_t;