diff options
author | Zheng Da <zhengda1936@gmail.com> | 2009-12-06 05:26:23 +0100 |
---|---|---|
committer | Zheng Da <zhengda1936@gmail.com> | 2009-12-06 05:26:23 +0100 |
commit | 8a6d48c0542876eb3acfc0970c0ab7872db08d5f (patch) | |
tree | 496e78bc728317ea779781b92f897d16936ee231 /libdde_linux26/contrib/include/linux/kthread.h | |
parent | b4bffcfcdf3ab7a55d664e9aa5907f88da503f38 (diff) |
check in the original version of dde linux26.
Diffstat (limited to 'libdde_linux26/contrib/include/linux/kthread.h')
-rw-r--r-- | libdde_linux26/contrib/include/linux/kthread.h | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/libdde_linux26/contrib/include/linux/kthread.h b/libdde_linux26/contrib/include/linux/kthread.h new file mode 100644 index 00000000..aabc8a13 --- /dev/null +++ b/libdde_linux26/contrib/include/linux/kthread.h @@ -0,0 +1,37 @@ +#ifndef _LINUX_KTHREAD_H +#define _LINUX_KTHREAD_H +/* Simple interface for creating and stopping kernel threads without mess. */ +#include <linux/err.h> +#include <linux/sched.h> + +struct task_struct *kthread_create(int (*threadfn)(void *data), + void *data, + const char namefmt[], ...) + __attribute__((format(printf, 3, 4))); + +/** + * kthread_run - create and wake a thread. + * @threadfn: the function to run until signal_pending(current). + * @data: data ptr for @threadfn. + * @namefmt: printf-style name for the thread. + * + * Description: Convenient wrapper for kthread_create() followed by + * wake_up_process(). Returns the kthread or ERR_PTR(-ENOMEM). + */ +#define kthread_run(threadfn, data, namefmt, ...) \ +({ \ + struct task_struct *__k \ + = kthread_create(threadfn, data, namefmt, ## __VA_ARGS__); \ + if (!IS_ERR(__k)) \ + wake_up_process(__k); \ + __k; \ +}) + +void kthread_bind(struct task_struct *k, unsigned int cpu); +int kthread_stop(struct task_struct *k); +int kthread_should_stop(void); + +int kthreadd(void *unused); +extern struct task_struct *kthreadd_task; + +#endif /* _LINUX_KTHREAD_H */ |