cgroup: remove css_parent()
cgroup in general is moving towards using cgroup_subsys_state as the fundamental structural component and css_parent() was introduced to convert from using cgroup->parent to css->parent. It was quite some time ago and we're moving forward with making css more prominent. This patch drops the trivial wrapper css_parent() and let the users dereference css->parent. While at it, explicitly mark fields of css which are public and immutable. v2: New usage from device_cgroup.c converted. Signed-off-by: Tejun Heo <tj@kernel.org> Acked-by: Michal Hocko <mhocko@suse.cz> Acked-by: Neil Horman <nhorman@tuxdriver.com> Acked-by: "David S. Miller" <davem@davemloft.net> Acked-by: Li Zefan <lizefan@huawei.com> Cc: Vivek Goyal <vgoyal@redhat.com> Cc: Jens Axboe <axboe@kernel.dk> Cc: Peter Zijlstra <a.p.zijlstra@chello.nl> Cc: Johannes Weiner <hannes@cmpxchg.org>
This commit is contained in:
parent
3b514d24e2
commit
5c9d535b89
@ -204,7 +204,7 @@ static inline struct blkcg *bio_blkcg(struct bio *bio)
|
|||||||
*/
|
*/
|
||||||
static inline struct blkcg *blkcg_parent(struct blkcg *blkcg)
|
static inline struct blkcg *blkcg_parent(struct blkcg *blkcg)
|
||||||
{
|
{
|
||||||
return css_to_blkcg(css_parent(&blkcg->css));
|
return css_to_blkcg(blkcg->css.parent);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -48,22 +48,28 @@ enum cgroup_subsys_id {
|
|||||||
};
|
};
|
||||||
#undef SUBSYS
|
#undef SUBSYS
|
||||||
|
|
||||||
/* Per-subsystem/per-cgroup state maintained by the system. */
|
/*
|
||||||
|
* Per-subsystem/per-cgroup state maintained by the system. This is the
|
||||||
|
* fundamental structural building block that controllers deal with.
|
||||||
|
*
|
||||||
|
* Fields marked with "PI:" are public and immutable and may be accessed
|
||||||
|
* directly without synchronization.
|
||||||
|
*/
|
||||||
struct cgroup_subsys_state {
|
struct cgroup_subsys_state {
|
||||||
/* the cgroup that this css is attached to */
|
/* PI: the cgroup that this css is attached to */
|
||||||
struct cgroup *cgroup;
|
struct cgroup *cgroup;
|
||||||
|
|
||||||
/* the cgroup subsystem that this css is attached to */
|
/* PI: the cgroup subsystem that this css is attached to */
|
||||||
struct cgroup_subsys *ss;
|
struct cgroup_subsys *ss;
|
||||||
|
|
||||||
/* reference count - access via css_[try]get() and css_put() */
|
/* reference count - access via css_[try]get() and css_put() */
|
||||||
struct percpu_ref refcnt;
|
struct percpu_ref refcnt;
|
||||||
|
|
||||||
/* the parent css */
|
/* PI: the parent css */
|
||||||
struct cgroup_subsys_state *parent;
|
struct cgroup_subsys_state *parent;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Subsys-unique ID. 0 is unused and root is always 1. The
|
* PI: Subsys-unique ID. 0 is unused and root is always 1. The
|
||||||
* matching css can be looked up using css_from_id().
|
* matching css can be looked up using css_from_id().
|
||||||
*/
|
*/
|
||||||
int id;
|
int id;
|
||||||
@ -669,19 +675,6 @@ struct cgroup_subsys {
|
|||||||
#include <linux/cgroup_subsys.h>
|
#include <linux/cgroup_subsys.h>
|
||||||
#undef SUBSYS
|
#undef SUBSYS
|
||||||
|
|
||||||
/**
|
|
||||||
* css_parent - find the parent css
|
|
||||||
* @css: the target cgroup_subsys_state
|
|
||||||
*
|
|
||||||
* Return the parent css of @css. This function is guaranteed to return
|
|
||||||
* non-NULL parent as long as @css isn't the root.
|
|
||||||
*/
|
|
||||||
static inline
|
|
||||||
struct cgroup_subsys_state *css_parent(struct cgroup_subsys_state *css)
|
|
||||||
{
|
|
||||||
return css->parent;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* task_css_set_check - obtain a task's css_set with extra access conditions
|
* task_css_set_check - obtain a task's css_set with extra access conditions
|
||||||
* @task: the task to obtain css_set for
|
* @task: the task to obtain css_set for
|
||||||
|
@ -3176,10 +3176,10 @@ css_next_descendant_pre(struct cgroup_subsys_state *pos,
|
|||||||
|
|
||||||
/* no child, visit my or the closest ancestor's next sibling */
|
/* no child, visit my or the closest ancestor's next sibling */
|
||||||
while (pos != root) {
|
while (pos != root) {
|
||||||
next = css_next_child(pos, css_parent(pos));
|
next = css_next_child(pos, pos->parent);
|
||||||
if (next)
|
if (next)
|
||||||
return next;
|
return next;
|
||||||
pos = css_parent(pos);
|
pos = pos->parent;
|
||||||
}
|
}
|
||||||
|
|
||||||
return NULL;
|
return NULL;
|
||||||
@ -3261,12 +3261,12 @@ css_next_descendant_post(struct cgroup_subsys_state *pos,
|
|||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
/* if there's an unvisited sibling, visit its leftmost descendant */
|
/* if there's an unvisited sibling, visit its leftmost descendant */
|
||||||
next = css_next_child(pos, css_parent(pos));
|
next = css_next_child(pos, pos->parent);
|
||||||
if (next)
|
if (next)
|
||||||
return css_leftmost_descendant(next);
|
return css_leftmost_descendant(next);
|
||||||
|
|
||||||
/* no sibling left, visit parent */
|
/* no sibling left, visit parent */
|
||||||
return css_parent(pos);
|
return pos->parent;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool cgroup_has_live_children(struct cgroup *cgrp)
|
static bool cgroup_has_live_children(struct cgroup *cgrp)
|
||||||
|
@ -59,7 +59,7 @@ static inline struct freezer *task_freezer(struct task_struct *task)
|
|||||||
|
|
||||||
static struct freezer *parent_freezer(struct freezer *freezer)
|
static struct freezer *parent_freezer(struct freezer *freezer)
|
||||||
{
|
{
|
||||||
return css_freezer(css_parent(&freezer->css));
|
return css_freezer(freezer->css.parent);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool cgroup_freezing(struct task_struct *task)
|
bool cgroup_freezing(struct task_struct *task)
|
||||||
|
@ -124,7 +124,7 @@ static inline struct cpuset *task_cs(struct task_struct *task)
|
|||||||
|
|
||||||
static inline struct cpuset *parent_cs(struct cpuset *cs)
|
static inline struct cpuset *parent_cs(struct cpuset *cs)
|
||||||
{
|
{
|
||||||
return css_cs(css_parent(&cs->css));
|
return css_cs(cs->css.parent);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef CONFIG_NUMA
|
#ifdef CONFIG_NUMA
|
||||||
|
@ -7586,7 +7586,7 @@ cpu_cgroup_css_alloc(struct cgroup_subsys_state *parent_css)
|
|||||||
static int cpu_cgroup_css_online(struct cgroup_subsys_state *css)
|
static int cpu_cgroup_css_online(struct cgroup_subsys_state *css)
|
||||||
{
|
{
|
||||||
struct task_group *tg = css_tg(css);
|
struct task_group *tg = css_tg(css);
|
||||||
struct task_group *parent = css_tg(css_parent(css));
|
struct task_group *parent = css_tg(css->parent);
|
||||||
|
|
||||||
if (parent)
|
if (parent)
|
||||||
sched_online_group(tg, parent);
|
sched_online_group(tg, parent);
|
||||||
|
@ -46,7 +46,7 @@ static inline struct cpuacct *task_ca(struct task_struct *tsk)
|
|||||||
|
|
||||||
static inline struct cpuacct *parent_ca(struct cpuacct *ca)
|
static inline struct cpuacct *parent_ca(struct cpuacct *ca)
|
||||||
{
|
{
|
||||||
return css_ca(css_parent(&ca->css));
|
return css_ca(ca->css.parent);
|
||||||
}
|
}
|
||||||
|
|
||||||
static DEFINE_PER_CPU(u64, root_cpuacct_cpuusage);
|
static DEFINE_PER_CPU(u64, root_cpuacct_cpuusage);
|
||||||
|
@ -52,7 +52,7 @@ static inline bool hugetlb_cgroup_is_root(struct hugetlb_cgroup *h_cg)
|
|||||||
static inline struct hugetlb_cgroup *
|
static inline struct hugetlb_cgroup *
|
||||||
parent_hugetlb_cgroup(struct hugetlb_cgroup *h_cg)
|
parent_hugetlb_cgroup(struct hugetlb_cgroup *h_cg)
|
||||||
{
|
{
|
||||||
return hugetlb_cgroup_from_css(css_parent(&h_cg->css));
|
return hugetlb_cgroup_from_css(h_cg->css.parent);
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline bool hugetlb_cgroup_have_usage(struct hugetlb_cgroup *h_cg)
|
static inline bool hugetlb_cgroup_have_usage(struct hugetlb_cgroup *h_cg)
|
||||||
|
@ -1540,7 +1540,7 @@ static unsigned long mem_cgroup_margin(struct mem_cgroup *memcg)
|
|||||||
int mem_cgroup_swappiness(struct mem_cgroup *memcg)
|
int mem_cgroup_swappiness(struct mem_cgroup *memcg)
|
||||||
{
|
{
|
||||||
/* root ? */
|
/* root ? */
|
||||||
if (!css_parent(&memcg->css))
|
if (!memcg->css.parent)
|
||||||
return vm_swappiness;
|
return vm_swappiness;
|
||||||
|
|
||||||
return memcg->swappiness;
|
return memcg->swappiness;
|
||||||
@ -4909,7 +4909,7 @@ static int mem_cgroup_hierarchy_write(struct cgroup_subsys_state *css,
|
|||||||
{
|
{
|
||||||
int retval = 0;
|
int retval = 0;
|
||||||
struct mem_cgroup *memcg = mem_cgroup_from_css(css);
|
struct mem_cgroup *memcg = mem_cgroup_from_css(css);
|
||||||
struct mem_cgroup *parent_memcg = mem_cgroup_from_css(css_parent(&memcg->css));
|
struct mem_cgroup *parent_memcg = mem_cgroup_from_css(memcg->css.parent);
|
||||||
|
|
||||||
mutex_lock(&memcg_create_mutex);
|
mutex_lock(&memcg_create_mutex);
|
||||||
|
|
||||||
@ -5207,8 +5207,8 @@ static void memcg_get_hierarchical_limit(struct mem_cgroup *memcg,
|
|||||||
if (!memcg->use_hierarchy)
|
if (!memcg->use_hierarchy)
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
while (css_parent(&memcg->css)) {
|
while (memcg->css.parent) {
|
||||||
memcg = mem_cgroup_from_css(css_parent(&memcg->css));
|
memcg = mem_cgroup_from_css(memcg->css.parent);
|
||||||
if (!memcg->use_hierarchy)
|
if (!memcg->use_hierarchy)
|
||||||
break;
|
break;
|
||||||
tmp = res_counter_read_u64(&memcg->res, RES_LIMIT);
|
tmp = res_counter_read_u64(&memcg->res, RES_LIMIT);
|
||||||
@ -5443,7 +5443,7 @@ static int mem_cgroup_swappiness_write(struct cgroup_subsys_state *css,
|
|||||||
struct cftype *cft, u64 val)
|
struct cftype *cft, u64 val)
|
||||||
{
|
{
|
||||||
struct mem_cgroup *memcg = mem_cgroup_from_css(css);
|
struct mem_cgroup *memcg = mem_cgroup_from_css(css);
|
||||||
struct mem_cgroup *parent = mem_cgroup_from_css(css_parent(&memcg->css));
|
struct mem_cgroup *parent = mem_cgroup_from_css(memcg->css.parent);
|
||||||
|
|
||||||
if (val > 100 || !parent)
|
if (val > 100 || !parent)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
@ -5790,7 +5790,7 @@ static int mem_cgroup_oom_control_write(struct cgroup_subsys_state *css,
|
|||||||
struct cftype *cft, u64 val)
|
struct cftype *cft, u64 val)
|
||||||
{
|
{
|
||||||
struct mem_cgroup *memcg = mem_cgroup_from_css(css);
|
struct mem_cgroup *memcg = mem_cgroup_from_css(css);
|
||||||
struct mem_cgroup *parent = mem_cgroup_from_css(css_parent(&memcg->css));
|
struct mem_cgroup *parent = mem_cgroup_from_css(memcg->css.parent);
|
||||||
|
|
||||||
/* cannot set to root cgroup and only 0 and 1 are allowed */
|
/* cannot set to root cgroup and only 0 and 1 are allowed */
|
||||||
if (!parent || !((val == 0) || (val == 1)))
|
if (!parent || !((val == 0) || (val == 1)))
|
||||||
@ -6407,7 +6407,7 @@ static int
|
|||||||
mem_cgroup_css_online(struct cgroup_subsys_state *css)
|
mem_cgroup_css_online(struct cgroup_subsys_state *css)
|
||||||
{
|
{
|
||||||
struct mem_cgroup *memcg = mem_cgroup_from_css(css);
|
struct mem_cgroup *memcg = mem_cgroup_from_css(css);
|
||||||
struct mem_cgroup *parent = mem_cgroup_from_css(css_parent(css));
|
struct mem_cgroup *parent = mem_cgroup_from_css(css->parent);
|
||||||
|
|
||||||
if (css->id > MEM_CGROUP_ID_MAX)
|
if (css->id > MEM_CGROUP_ID_MAX)
|
||||||
return -ENOSPC;
|
return -ENOSPC;
|
||||||
|
@ -42,7 +42,7 @@ cgrp_css_alloc(struct cgroup_subsys_state *parent_css)
|
|||||||
static int cgrp_css_online(struct cgroup_subsys_state *css)
|
static int cgrp_css_online(struct cgroup_subsys_state *css)
|
||||||
{
|
{
|
||||||
struct cgroup_cls_state *cs = css_cls_state(css);
|
struct cgroup_cls_state *cs = css_cls_state(css);
|
||||||
struct cgroup_cls_state *parent = css_cls_state(css_parent(css));
|
struct cgroup_cls_state *parent = css_cls_state(css->parent);
|
||||||
|
|
||||||
if (parent)
|
if (parent)
|
||||||
cs->classid = parent->classid;
|
cs->classid = parent->classid;
|
||||||
|
@ -140,7 +140,7 @@ cgrp_css_alloc(struct cgroup_subsys_state *parent_css)
|
|||||||
|
|
||||||
static int cgrp_css_online(struct cgroup_subsys_state *css)
|
static int cgrp_css_online(struct cgroup_subsys_state *css)
|
||||||
{
|
{
|
||||||
struct cgroup_subsys_state *parent_css = css_parent(css);
|
struct cgroup_subsys_state *parent_css = css->parent;
|
||||||
struct net_device *dev;
|
struct net_device *dev;
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
|
||||||
|
@ -182,7 +182,7 @@ static inline bool is_devcg_online(const struct dev_cgroup *devcg)
|
|||||||
static int devcgroup_online(struct cgroup_subsys_state *css)
|
static int devcgroup_online(struct cgroup_subsys_state *css)
|
||||||
{
|
{
|
||||||
struct dev_cgroup *dev_cgroup = css_to_devcgroup(css);
|
struct dev_cgroup *dev_cgroup = css_to_devcgroup(css);
|
||||||
struct dev_cgroup *parent_dev_cgroup = css_to_devcgroup(css_parent(css));
|
struct dev_cgroup *parent_dev_cgroup = css_to_devcgroup(css->parent);
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
|
||||||
mutex_lock(&devcgroup_mutex);
|
mutex_lock(&devcgroup_mutex);
|
||||||
@ -455,7 +455,7 @@ static bool verify_new_ex(struct dev_cgroup *dev_cgroup,
|
|||||||
static int parent_has_perm(struct dev_cgroup *childcg,
|
static int parent_has_perm(struct dev_cgroup *childcg,
|
||||||
struct dev_exception_item *ex)
|
struct dev_exception_item *ex)
|
||||||
{
|
{
|
||||||
struct dev_cgroup *parent = css_to_devcgroup(css_parent(&childcg->css));
|
struct dev_cgroup *parent = css_to_devcgroup(childcg->css.parent);
|
||||||
|
|
||||||
if (!parent)
|
if (!parent)
|
||||||
return 1;
|
return 1;
|
||||||
@ -476,7 +476,7 @@ static int parent_has_perm(struct dev_cgroup *childcg,
|
|||||||
static bool parent_allows_removal(struct dev_cgroup *childcg,
|
static bool parent_allows_removal(struct dev_cgroup *childcg,
|
||||||
struct dev_exception_item *ex)
|
struct dev_exception_item *ex)
|
||||||
{
|
{
|
||||||
struct dev_cgroup *parent = css_to_devcgroup(css_parent(&childcg->css));
|
struct dev_cgroup *parent = css_to_devcgroup(childcg->css.parent);
|
||||||
|
|
||||||
if (!parent)
|
if (!parent)
|
||||||
return true;
|
return true;
|
||||||
@ -614,7 +614,7 @@ static int devcgroup_update_access(struct dev_cgroup *devcgroup,
|
|||||||
char temp[12]; /* 11 + 1 characters needed for a u32 */
|
char temp[12]; /* 11 + 1 characters needed for a u32 */
|
||||||
int count, rc = 0;
|
int count, rc = 0;
|
||||||
struct dev_exception_item ex;
|
struct dev_exception_item ex;
|
||||||
struct dev_cgroup *parent = css_to_devcgroup(css_parent(&devcgroup->css));
|
struct dev_cgroup *parent = css_to_devcgroup(devcgroup->css.parent);
|
||||||
|
|
||||||
if (!capable(CAP_SYS_ADMIN))
|
if (!capable(CAP_SYS_ADMIN))
|
||||||
return -EPERM;
|
return -EPERM;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user