提交 e3c916a4 编写于 作者: T Tejun Heo

workqueue: drop 'H' from kworker names of unbound worker pools

Currently, all workqueue workers which have negative nice value has
'H' postfixed to their names.  This is necessary for per-cpu workers
as they use the CPU number instead of pool->id to identify the pool
and the 'H' postfix is the only thing distinguishing normal and
highpri workers.

As workers for unbound pools use pool->id, the 'H' postfix is purely
informational.  TASK_COMM_LEN is 16 and after the static part and
delimiters, there are only five characters left for the pool and
worker IDs.  We're expecting to have more unbound pools with the
scheduled NUMA awareness support.  Let's drop the non-essential 'H'
postfix from unbound kworker name.

While at it, restructure kthread_create*() invocation to help future
NUMA related changes.
Signed-off-by: NTejun Heo <tj@kernel.org>
Reviewed-by: NLai Jiangshan <laijs@cn.fujitsu.com>
上级 bce90380
...@@ -1644,9 +1644,10 @@ static struct worker *alloc_worker(void) ...@@ -1644,9 +1644,10 @@ static struct worker *alloc_worker(void)
*/ */
static struct worker *create_worker(struct worker_pool *pool) static struct worker *create_worker(struct worker_pool *pool)
{ {
const char *pri = pool->attrs->nice < 0 ? "H" : "";
struct worker *worker = NULL; struct worker *worker = NULL;
int node = pool->cpu >= 0 ? cpu_to_node(pool->cpu) : NUMA_NO_NODE;
int id = -1; int id = -1;
char id_buf[16];
lockdep_assert_held(&pool->manager_mutex); lockdep_assert_held(&pool->manager_mutex);
...@@ -1672,13 +1673,13 @@ static struct worker *create_worker(struct worker_pool *pool) ...@@ -1672,13 +1673,13 @@ static struct worker *create_worker(struct worker_pool *pool)
worker->id = id; worker->id = id;
if (pool->cpu >= 0) if (pool->cpu >= 0)
worker->task = kthread_create_on_node(worker_thread, snprintf(id_buf, sizeof(id_buf), "%d:%d%s", pool->cpu, id,
worker, cpu_to_node(pool->cpu), pool->attrs->nice < 0 ? "H" : "");
"kworker/%d:%d%s", pool->cpu, id, pri);
else else
worker->task = kthread_create(worker_thread, worker, snprintf(id_buf, sizeof(id_buf), "u%d:%d", pool->id, id);
"kworker/u%d:%d%s",
pool->id, id, pri); worker->task = kthread_create_on_node(worker_thread, worker, node,
"kworker/%s", id_buf);
if (IS_ERR(worker->task)) if (IS_ERR(worker->task))
goto fail; goto fail;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册