diff options
| author | Tejun Heo <tj@kernel.org> | 2013-01-18 17:05:55 -0500 |
|---|---|---|
| committer | Tejun Heo <tj@kernel.org> | 2013-01-18 17:05:55 -0500 |
| commit | 2eaebdb33e1911c0cf3d44fd3596c42c6f502fab (patch) | |
| tree | 240924aae7c1ce31dc850a290ef53e268f071ebd /kernel/workqueue.c | |
| parent | ea138446e51f7bfe55cdeffa3f1dd9cafc786bd8 (diff) | |
workqueue: move struct worker definition to workqueue_internal.h
This will be used to implement an inline function to query whether
%current is a workqueue worker and, if so, allow determining which
work item it's executing.
Signed-off-by: Tejun Heo <tj@kernel.org>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'kernel/workqueue.c')
| -rw-r--r-- | kernel/workqueue.c | 32 |
1 files changed, 1 insertions, 31 deletions
diff --git a/kernel/workqueue.c b/kernel/workqueue.c index b4e92061a934..2ffa240052fa 100644 --- a/kernel/workqueue.c +++ b/kernel/workqueue.c | |||
| @@ -122,37 +122,7 @@ enum { | |||
| 122 | * W: workqueue_lock protected. | 122 | * W: workqueue_lock protected. |
| 123 | */ | 123 | */ |
| 124 | 124 | ||
| 125 | struct global_cwq; | 125 | /* struct worker is defined in workqueue_internal.h */ |
| 126 | struct worker_pool; | ||
| 127 | |||
| 128 | /* | ||
| 129 | * The poor guys doing the actual heavy lifting. All on-duty workers | ||
| 130 | * are either serving the manager role, on idle list or on busy hash. | ||
| 131 | */ | ||
| 132 | struct worker { | ||
| 133 | /* on idle list while idle, on busy hash table while busy */ | ||
| 134 | union { | ||
| 135 | struct list_head entry; /* L: while idle */ | ||
| 136 | struct hlist_node hentry; /* L: while busy */ | ||
| 137 | }; | ||
| 138 | |||
| 139 | struct work_struct *current_work; /* L: work being processed */ | ||
| 140 | work_func_t current_func; /* L: current_work's fn */ | ||
| 141 | struct cpu_workqueue_struct *current_cwq; /* L: current_work's cwq */ | ||
| 142 | struct list_head scheduled; /* L: scheduled works */ | ||
| 143 | struct task_struct *task; /* I: worker task */ | ||
| 144 | struct worker_pool *pool; /* I: the associated pool */ | ||
| 145 | /* 64 bytes boundary on 64bit, 32 on 32bit */ | ||
| 146 | unsigned long last_active; /* L: last active timestamp */ | ||
| 147 | unsigned int flags; /* X: flags */ | ||
| 148 | int id; /* I: worker id */ | ||
| 149 | |||
| 150 | /* for rebinding worker to CPU */ | ||
| 151 | struct work_struct rebind_work; /* L: for busy worker */ | ||
| 152 | |||
| 153 | /* used only by rescuers to point to the target workqueue */ | ||
| 154 | struct workqueue_struct *rescue_wq; /* I: the workqueue to rescue */ | ||
| 155 | }; | ||
| 156 | 126 | ||
| 157 | struct worker_pool { | 127 | struct worker_pool { |
| 158 | struct global_cwq *gcwq; /* I: the owning gcwq */ | 128 | struct global_cwq *gcwq; /* I: the owning gcwq */ |
