Lines Matching +full:signal +full:- +full:id
1 // SPDX-License-Identifier: GPL-2.0
3 * Auto-group scheduling implementation:
17 init_task->signal->autogroup = &autogroup_default; in autogroup_init()
22 kfree(tg->autogroup); in autogroup_free()
31 ag->tg->rt_se = NULL; in autogroup_destroy()
32 ag->tg->rt_rq = NULL; in autogroup_destroy()
34 sched_offline_group(ag->tg); in autogroup_destroy()
35 sched_destroy_group(ag->tg); in autogroup_destroy()
40 kref_put(&ag->kref, autogroup_destroy); in autogroup_kref_put()
45 kref_get(&ag->kref); in autogroup_kref_get()
57 ag = autogroup_kref_get(p->signal->autogroup); in autogroup_task_get()
75 kref_init(&ag->kref); in autogroup_create()
76 init_rwsem(&ag->lock); in autogroup_create()
77 ag->id = atomic_inc_return(&autogroup_seq_nr); in autogroup_create()
78 ag->tg = tg; in autogroup_create()
88 tg->rt_se = root_task_group.rt_se; in autogroup_create()
89 tg->rt_rq = root_task_group.rt_rq; in autogroup_create()
91 tg->autogroup = ag; in autogroup_create()
113 * value of signal->autogroup but in this case sched_move_task() will in task_wants_autogroup()
117 * to avoid autogroup->tg, so we abuse PF_EXITING flag for this case. in task_wants_autogroup()
119 if (p->flags & PF_EXITING) in task_wants_autogroup()
129 * see this thread after that: we can no longer use signal->autogroup. in sched_autogroup_exit_task()
144 prev = p->signal->autogroup; in autogroup_move_group()
150 p->signal->autogroup = autogroup_kref_get(ag); in autogroup_move_group()
152 * We can't avoid sched_move_task() after we changed signal->autogroup, in autogroup_move_group()
153 * this process can already run with task_group() == prev->tg or we can in autogroup_move_group()
154 * race with cgroup code which can read autogroup = prev under rq->lock. in autogroup_move_group()
157 * can't be removed from thread list, we hold ->siglock. in autogroup_move_group()
190 sig->autogroup = autogroup_task_get(current); in sched_autogroup_fork()
195 autogroup_kref_put(sig->autogroup); in sched_autogroup_exit()
216 return -EINVAL; in proc_sched_autogroup_set_nice()
223 return -EPERM; in proc_sched_autogroup_set_nice()
227 return -EAGAIN; in proc_sched_autogroup_set_nice()
235 down_write(&ag->lock); in proc_sched_autogroup_set_nice()
236 err = sched_group_set_shares(ag->tg, shares); in proc_sched_autogroup_set_nice()
238 ag->nice = nice; in proc_sched_autogroup_set_nice()
239 up_write(&ag->lock); in proc_sched_autogroup_set_nice()
250 if (!task_group_is_autogroup(ag->tg)) in proc_sched_autogroup_show_task()
253 down_read(&ag->lock); in proc_sched_autogroup_show_task()
254 seq_printf(m, "/autogroup-%ld nice %d\n", ag->id, ag->nice); in proc_sched_autogroup_show_task()
255 up_read(&ag->lock); in proc_sched_autogroup_show_task()
267 return snprintf(buf, buflen, "%s-%ld", "/autogroup", tg->autogroup->id); in autogroup_path()