diff options
| author | Tejun Heo <tj@kernel.org> | 2026-03-10 07:03:57 -1000 |
|---|---|---|
| committer | Tejun Heo <tj@kernel.org> | 2026-03-10 07:03:57 -1000 |
| commit | b39bf7f0fae98c03e5ba6061e2251eeb36ec0b39 (patch) | |
| tree | 7ea9c05e8a9b7537930985c0a9a19c9ba6773909 /kernel/workqueue.c | |
| parent | c116737e972ea74f4468a1bd0703d623a3c0ee4a (diff) | |
| parent | 1dfc9d60a69ec148e1cb709256617d86e5f0e8f8 (diff) | |
Merge branch 'for-7.1-devm-alloc-wq' into for-7.1
Diffstat (limited to 'kernel/workqueue.c')
| -rw-r--r-- | kernel/workqueue.c | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/kernel/workqueue.c b/kernel/workqueue.c index 2d8ff903f113..715a23d5348f 100644 --- a/kernel/workqueue.c +++ b/kernel/workqueue.c @@ -41,6 +41,7 @@ #include <linux/mempolicy.h> #include <linux/freezer.h> #include <linux/debug_locks.h> +#include <linux/device/devres.h> #include <linux/lockdep.h> #include <linux/idr.h> #include <linux/jhash.h> @@ -5893,6 +5894,33 @@ struct workqueue_struct *alloc_workqueue_noprof(const char *fmt, } EXPORT_SYMBOL_GPL(alloc_workqueue_noprof); +static void devm_workqueue_release(void *res) +{ + destroy_workqueue(res); +} + +__printf(2, 5) struct workqueue_struct * +devm_alloc_workqueue(struct device *dev, const char *fmt, unsigned int flags, + int max_active, ...) +{ + struct workqueue_struct *wq; + va_list args; + int ret; + + va_start(args, max_active); + wq = alloc_workqueue(fmt, flags, max_active, args); + va_end(args); + if (!wq) + return NULL; + + ret = devm_add_action_or_reset(dev, devm_workqueue_release, wq); + if (ret) + return NULL; + + return wq; +} +EXPORT_SYMBOL_GPL(devm_alloc_workqueue); + #ifdef CONFIG_LOCKDEP __printf(1, 5) struct workqueue_struct * |
