Skip to content

Commit

Permalink
kthread: implement kthread_data()
Browse files Browse the repository at this point in the history
Implement kthread_data() which takes @task pointing to a kthread and
returns @DaTa specified when creating the kthread.  The caller is
responsible for ensuring the validity of @task when calling this
function.

Signed-off-by: Tejun Heo <[email protected]>
  • Loading branch information
htejun committed Jun 29, 2010
1 parent 7bc4656 commit 82805ab
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 0 deletions.
1 change: 1 addition & 0 deletions include/linux/kthread.h
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@ struct task_struct *kthread_create(int (*threadfn)(void *data),
void kthread_bind(struct task_struct *k, unsigned int cpu);
int kthread_stop(struct task_struct *k);
int kthread_should_stop(void);
void *kthread_data(struct task_struct *k);

int kthreadd(void *unused);
extern struct task_struct *kthreadd_task;
Expand Down
15 changes: 15 additions & 0 deletions kernel/kthread.c
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,7 @@ struct kthread_create_info

struct kthread {
int should_stop;
void *data;
struct completion exited;
};

Expand All @@ -56,6 +57,19 @@ int kthread_should_stop(void)
}
EXPORT_SYMBOL(kthread_should_stop);

/**
* kthread_data - return data value specified on kthread creation
* @task: kthread task in question
*
* Return the data value specified when kthread @task was created.
* The caller is responsible for ensuring the validity of @task when
* calling this function.
*/
void *kthread_data(struct task_struct *task)
{
return to_kthread(task)->data;
}

static int kthread(void *_create)
{
/* Copy data: it's on kthread's stack */
Expand All @@ -66,6 +80,7 @@ static int kthread(void *_create)
int ret;

self.should_stop = 0;
self.data = data;
init_completion(&self.exited);
current->vfork_done = &self.exited;

Expand Down

0 comments on commit 82805ab

Please sign in to comment.