Lines Matching refs:cgrp
195 void cgroup1_pidlist_destroy_all(struct cgroup *cgrp) in cgroup1_pidlist_destroy_all() argument
199 mutex_lock(&cgrp->pidlist_mutex); in cgroup1_pidlist_destroy_all()
200 list_for_each_entry_safe(l, tmp_l, &cgrp->pidlists, links) in cgroup1_pidlist_destroy_all()
202 mutex_unlock(&cgrp->pidlist_mutex); in cgroup1_pidlist_destroy_all()
205 BUG_ON(!list_empty(&cgrp->pidlists)); in cgroup1_pidlist_destroy_all()
276 static struct cgroup_pidlist *cgroup_pidlist_find(struct cgroup *cgrp, in cgroup_pidlist_find() argument
283 lockdep_assert_held(&cgrp->pidlist_mutex); in cgroup_pidlist_find()
285 list_for_each_entry(l, &cgrp->pidlists, links) in cgroup_pidlist_find()
297 static struct cgroup_pidlist *cgroup_pidlist_find_create(struct cgroup *cgrp, in cgroup_pidlist_find_create() argument
302 lockdep_assert_held(&cgrp->pidlist_mutex); in cgroup_pidlist_find_create()
304 l = cgroup_pidlist_find(cgrp, type); in cgroup_pidlist_find_create()
317 l->owner = cgrp; in cgroup_pidlist_find_create()
318 list_add(&l->links, &cgrp->pidlists); in cgroup_pidlist_find_create()
325 static int pidlist_array_load(struct cgroup *cgrp, enum cgroup_filetype type, in pidlist_array_load() argument
335 lockdep_assert_held(&cgrp->pidlist_mutex); in pidlist_array_load()
343 length = cgroup_task_count(cgrp); in pidlist_array_load()
348 css_task_iter_start(&cgrp->self, 0, &it); in pidlist_array_load()
367 l = cgroup_pidlist_find_create(cgrp, type); in pidlist_array_load()
396 struct cgroup *cgrp = seq_css(s)->cgroup; in cgroup_pidlist_start() local
402 mutex_lock(&cgrp->pidlist_mutex); in cgroup_pidlist_start()
411 of->priv = cgroup_pidlist_find(cgrp, type); in cgroup_pidlist_start()
418 ret = pidlist_array_load(cgrp, type, in cgroup_pidlist_start()
490 struct cgroup *cgrp; in __cgroup1_procs_write() local
496 cgrp = cgroup_kn_lock_live(of->kn, false); in __cgroup1_procs_write()
497 if (!cgrp) in __cgroup1_procs_write()
519 ret = cgroup_attach_task(cgrp, task, threadgroup); in __cgroup1_procs_write()
544 struct cgroup *cgrp; in cgroup_release_agent_write() local
546 BUILD_BUG_ON(sizeof(cgrp->root->release_agent_path) < PATH_MAX); in cgroup_release_agent_write()
548 cgrp = cgroup_kn_lock_live(of->kn, false); in cgroup_release_agent_write()
549 if (!cgrp) in cgroup_release_agent_write()
552 strlcpy(cgrp->root->release_agent_path, strstrip(buf), in cgroup_release_agent_write()
553 sizeof(cgrp->root->release_agent_path)); in cgroup_release_agent_write()
561 struct cgroup *cgrp = seq_css(seq)->cgroup; in cgroup_release_agent_show() local
564 seq_puts(seq, cgrp->root->release_agent_path); in cgroup_release_agent_show()
689 struct cgroup *cgrp; in cgroupstats_build() local
706 cgrp = rcu_dereference(*(void __rcu __force **)&kn->priv); in cgroupstats_build()
707 if (!cgrp || cgroup_is_dead(cgrp)) { in cgroupstats_build()
714 css_task_iter_start(&cgrp->self, 0, &it); in cgroupstats_build()
741 void cgroup1_check_for_release(struct cgroup *cgrp) in cgroup1_check_for_release() argument
743 if (notify_on_release(cgrp) && !cgroup_is_populated(cgrp) && in cgroup1_check_for_release()
744 !css_has_online_children(&cgrp->self) && !cgroup_is_dead(cgrp)) in cgroup1_check_for_release()
745 schedule_work(&cgrp->release_agent_work); in cgroup1_check_for_release()
773 struct cgroup *cgrp = in cgroup1_release_agent() local
780 if (!cgrp->root->release_agent_path[0]) in cgroup1_release_agent()
790 strlcpy(agentbuf, cgrp->root->release_agent_path, PATH_MAX); in cgroup1_release_agent()
795 ret = cgroup_path_ns(cgrp, pathbuf, PATH_MAX, &init_cgroup_ns); in cgroup1_release_agent()
820 struct cgroup *cgrp = kn->priv; in cgroup1_rename() local
840 TRACE_CGROUP_PATH(rename, cgrp); in cgroup1_rename()
871 if (test_bit(CGRP_CPUSET_CLONE_CHILDREN, &root->cgrp.flags)) in cgroup1_show_options()
1043 cgroup_lock_and_drain_offline(&cgrp_dfl_root.cgrp); in cgroup1_reconfigure()
1067 if (!list_empty(&root->cgrp.self.children)) { in cgroup1_reconfigure()
1131 if (!percpu_ref_tryget_live(&ss->root->cgrp.self.refcnt)) in cgroup1_root_to_use()
1133 cgroup_put(&ss->root->cgrp); in cgroup1_root_to_use()
1205 cgroup_lock_and_drain_offline(&cgrp_dfl_root.cgrp); in cgroup1_get_tree()
1208 if (!ret && !percpu_ref_tryget_live(&ctx->root->cgrp.self.refcnt)) in cgroup1_get_tree()
1216 if (!ret && percpu_ref_is_dying(&ctx->root->cgrp.self.refcnt)) { in cgroup1_get_tree()