aboutsummaryrefslogtreecommitdiffstats
path: root/include/linux
diff options
context:
space:
mode:
authorTejun Heo <tj@kernel.org>2012-08-20 17:51:23 -0400
committerTejun Heo <tj@kernel.org>2012-08-20 17:51:23 -0400
commitae930e0f4e66fd540c6fbad9f1e2a7743d8b9afe (patch)
tree88853ec727834081a79d56bb9829191ca6e243ec /include/linux
parent606a5020b9bdceb20b4f43e11db0054afa349028 (diff)
workqueue: gut system_nrt[_freezable]_wq()
Now that all workqueues are non-reentrant, system[_freezable]_wq() are equivalent to system_nrt[_freezable]_wq(). Replace the latter with wrappers around system[_freezable]_wq(). The wrapping goes through inline functions so that __deprecated can be added easily. Signed-off-by: Tejun Heo <tj@kernel.org>
Diffstat (limited to 'include/linux')
-rw-r--r--include/linux/workqueue.h23
1 files changed, 14 insertions, 9 deletions
diff --git a/include/linux/workqueue.h b/include/linux/workqueue.h
index 4f9d3bc161a2..855fcdaa2d72 100644
--- a/include/linux/workqueue.h
+++ b/include/linux/workqueue.h
@@ -297,10 +297,6 @@ enum {
297 * system_long_wq is similar to system_wq but may host long running 297 * system_long_wq is similar to system_wq but may host long running
298 * works. Queue flushing might take relatively long. 298 * works. Queue flushing might take relatively long.
299 * 299 *
300 * system_nrt_wq is non-reentrant and guarantees that any given work
301 * item is never executed in parallel by multiple CPUs. Queue
302 * flushing might take relatively long.
303 *
304 * system_unbound_wq is unbound workqueue. Workers are not bound to 300 * system_unbound_wq is unbound workqueue. Workers are not bound to
305 * any specific CPU, not concurrency managed, and all queued works are 301 * any specific CPU, not concurrency managed, and all queued works are
306 * executed immediately as long as max_active limit is not reached and 302 * executed immediately as long as max_active limit is not reached and
@@ -308,16 +304,25 @@ enum {
308 * 304 *
309 * system_freezable_wq is equivalent to system_wq except that it's 305 * system_freezable_wq is equivalent to system_wq except that it's
310 * freezable. 306 * freezable.
311 *
312 * system_nrt_freezable_wq is equivalent to system_nrt_wq except that
313 * it's freezable.
314 */ 307 */
315extern struct workqueue_struct *system_wq; 308extern struct workqueue_struct *system_wq;
316extern struct workqueue_struct *system_long_wq; 309extern struct workqueue_struct *system_long_wq;
317extern struct workqueue_struct *system_nrt_wq;
318extern struct workqueue_struct *system_unbound_wq; 310extern struct workqueue_struct *system_unbound_wq;
319extern struct workqueue_struct *system_freezable_wq; 311extern struct workqueue_struct *system_freezable_wq;
320extern struct workqueue_struct *system_nrt_freezable_wq; 312
313static inline struct workqueue_struct *__system_nrt_wq(void)
314{
315 return system_wq;
316}
317
318static inline struct workqueue_struct *__system_nrt_freezable_wq(void)
319{
320 return system_freezable_wq;
321}
322
323/* equivlalent to system_wq and system_freezable_wq, deprecated */
324#define system_nrt_wq __system_nrt_wq()
325#define system_nrt_freezable_wq __system_nrt_freezable_wq()
321 326
322extern struct workqueue_struct * 327extern struct workqueue_struct *
323__alloc_workqueue_key(const char *fmt, unsigned int flags, int max_active, 328__alloc_workqueue_key(const char *fmt, unsigned int flags, int max_active,