netprio_cgroup: pass around @css instead of @cgroup and kill struct cgroup_netprio_state
cgroup controller API will be converted to primarily use struct cgroup_subsys_state instead of struct cgroup. In preparation, make the internal functions of netprio_cgroup pass around @css instead of @cgrp. While at it, kill struct cgroup_netprio_state which only contained struct cgroup_subsys_state without serving any purpose. All functions are converted to deal with @css directly. This patch shouldn't cause any behavior differences. Signed-off-by: Tejun Heo <tj@kernel.org> Acked-by: Li Zefan <lizefan@huawei.com> Acked-by: Neil Horman <nhorman@tuxdriver.com> Acked-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
c9710d8018
commit
6d37b97428
2 changed files with 28 additions and 32 deletions
|
@ -25,10 +25,6 @@ struct netprio_map {
|
||||||
u32 priomap[];
|
u32 priomap[];
|
||||||
};
|
};
|
||||||
|
|
||||||
struct cgroup_netprio_state {
|
|
||||||
struct cgroup_subsys_state css;
|
|
||||||
};
|
|
||||||
|
|
||||||
extern void sock_update_netprioidx(struct sock *sk);
|
extern void sock_update_netprioidx(struct sock *sk);
|
||||||
|
|
||||||
#if IS_BUILTIN(CONFIG_NETPRIO_CGROUP)
|
#if IS_BUILTIN(CONFIG_NETPRIO_CGROUP)
|
||||||
|
|
|
@ -29,12 +29,6 @@
|
||||||
|
|
||||||
#define PRIOMAP_MIN_SZ 128
|
#define PRIOMAP_MIN_SZ 128
|
||||||
|
|
||||||
static inline struct cgroup_netprio_state *cgrp_netprio_state(struct cgroup *cgrp)
|
|
||||||
{
|
|
||||||
return container_of(cgroup_css(cgrp, net_prio_subsys_id),
|
|
||||||
struct cgroup_netprio_state, css);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Extend @dev->priomap so that it's large enough to accomodate
|
* Extend @dev->priomap so that it's large enough to accomodate
|
||||||
* @target_idx. @dev->priomap.priomap_len > @target_idx after successful
|
* @target_idx. @dev->priomap.priomap_len > @target_idx after successful
|
||||||
|
@ -87,68 +81,72 @@ static int extend_netdev_table(struct net_device *dev, u32 target_idx)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* netprio_prio - return the effective netprio of a cgroup-net_device pair
|
* netprio_prio - return the effective netprio of a cgroup-net_device pair
|
||||||
* @cgrp: cgroup part of the target pair
|
* @css: css part of the target pair
|
||||||
* @dev: net_device part of the target pair
|
* @dev: net_device part of the target pair
|
||||||
*
|
*
|
||||||
* Should be called under RCU read or rtnl lock.
|
* Should be called under RCU read or rtnl lock.
|
||||||
*/
|
*/
|
||||||
static u32 netprio_prio(struct cgroup *cgrp, struct net_device *dev)
|
static u32 netprio_prio(struct cgroup_subsys_state *css, struct net_device *dev)
|
||||||
{
|
{
|
||||||
struct netprio_map *map = rcu_dereference_rtnl(dev->priomap);
|
struct netprio_map *map = rcu_dereference_rtnl(dev->priomap);
|
||||||
|
int id = css->cgroup->id;
|
||||||
|
|
||||||
if (map && cgrp->id < map->priomap_len)
|
if (map && id < map->priomap_len)
|
||||||
return map->priomap[cgrp->id];
|
return map->priomap[id];
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* netprio_set_prio - set netprio on a cgroup-net_device pair
|
* netprio_set_prio - set netprio on a cgroup-net_device pair
|
||||||
* @cgrp: cgroup part of the target pair
|
* @css: css part of the target pair
|
||||||
* @dev: net_device part of the target pair
|
* @dev: net_device part of the target pair
|
||||||
* @prio: prio to set
|
* @prio: prio to set
|
||||||
*
|
*
|
||||||
* Set netprio to @prio on @cgrp-@dev pair. Should be called under rtnl
|
* Set netprio to @prio on @css-@dev pair. Should be called under rtnl
|
||||||
* lock and may fail under memory pressure for non-zero @prio.
|
* lock and may fail under memory pressure for non-zero @prio.
|
||||||
*/
|
*/
|
||||||
static int netprio_set_prio(struct cgroup *cgrp, struct net_device *dev,
|
static int netprio_set_prio(struct cgroup_subsys_state *css,
|
||||||
u32 prio)
|
struct net_device *dev, u32 prio)
|
||||||
{
|
{
|
||||||
struct netprio_map *map;
|
struct netprio_map *map;
|
||||||
|
int id = css->cgroup->id;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
/* avoid extending priomap for zero writes */
|
/* avoid extending priomap for zero writes */
|
||||||
map = rtnl_dereference(dev->priomap);
|
map = rtnl_dereference(dev->priomap);
|
||||||
if (!prio && (!map || map->priomap_len <= cgrp->id))
|
if (!prio && (!map || map->priomap_len <= id))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
ret = extend_netdev_table(dev, cgrp->id);
|
ret = extend_netdev_table(dev, id);
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
map = rtnl_dereference(dev->priomap);
|
map = rtnl_dereference(dev->priomap);
|
||||||
map->priomap[cgrp->id] = prio;
|
map->priomap[id] = prio;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct cgroup_subsys_state *cgrp_css_alloc(struct cgroup *cgrp)
|
static struct cgroup_subsys_state *cgrp_css_alloc(struct cgroup *cgrp)
|
||||||
{
|
{
|
||||||
struct cgroup_netprio_state *cs;
|
struct cgroup_subsys_state *css;
|
||||||
|
|
||||||
cs = kzalloc(sizeof(*cs), GFP_KERNEL);
|
css = kzalloc(sizeof(*css), GFP_KERNEL);
|
||||||
if (!cs)
|
if (!css)
|
||||||
return ERR_PTR(-ENOMEM);
|
return ERR_PTR(-ENOMEM);
|
||||||
|
|
||||||
return &cs->css;
|
return css;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int cgrp_css_online(struct cgroup *cgrp)
|
static int cgrp_css_online(struct cgroup *cgrp)
|
||||||
{
|
{
|
||||||
struct cgroup *parent = cgrp->parent;
|
struct cgroup_subsys_state *css = cgroup_css(cgrp, net_prio_subsys_id);
|
||||||
|
struct cgroup_subsys_state *parent_css;
|
||||||
struct net_device *dev;
|
struct net_device *dev;
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
|
||||||
if (!parent)
|
if (!cgrp->parent)
|
||||||
return 0;
|
return 0;
|
||||||
|
parent_css = cgroup_css(cgrp->parent, net_prio_subsys_id);
|
||||||
|
|
||||||
rtnl_lock();
|
rtnl_lock();
|
||||||
/*
|
/*
|
||||||
|
@ -156,9 +154,9 @@ static int cgrp_css_online(struct cgroup *cgrp)
|
||||||
* onlining, there is no need to clear them on offline.
|
* onlining, there is no need to clear them on offline.
|
||||||
*/
|
*/
|
||||||
for_each_netdev(&init_net, dev) {
|
for_each_netdev(&init_net, dev) {
|
||||||
u32 prio = netprio_prio(parent, dev);
|
u32 prio = netprio_prio(parent_css, dev);
|
||||||
|
|
||||||
ret = netprio_set_prio(cgrp, dev, prio);
|
ret = netprio_set_prio(css, dev, prio);
|
||||||
if (ret)
|
if (ret)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -168,7 +166,7 @@ static int cgrp_css_online(struct cgroup *cgrp)
|
||||||
|
|
||||||
static void cgrp_css_free(struct cgroup *cgrp)
|
static void cgrp_css_free(struct cgroup *cgrp)
|
||||||
{
|
{
|
||||||
kfree(cgrp_netprio_state(cgrp));
|
kfree(cgroup_css(cgrp, net_prio_subsys_id));
|
||||||
}
|
}
|
||||||
|
|
||||||
static u64 read_prioidx(struct cgroup *cgrp, struct cftype *cft)
|
static u64 read_prioidx(struct cgroup *cgrp, struct cftype *cft)
|
||||||
|
@ -179,11 +177,12 @@ static u64 read_prioidx(struct cgroup *cgrp, struct cftype *cft)
|
||||||
static int read_priomap(struct cgroup *cont, struct cftype *cft,
|
static int read_priomap(struct cgroup *cont, struct cftype *cft,
|
||||||
struct cgroup_map_cb *cb)
|
struct cgroup_map_cb *cb)
|
||||||
{
|
{
|
||||||
|
struct cgroup_subsys_state *css = cgroup_css(cont, net_prio_subsys_id);
|
||||||
struct net_device *dev;
|
struct net_device *dev;
|
||||||
|
|
||||||
rcu_read_lock();
|
rcu_read_lock();
|
||||||
for_each_netdev_rcu(&init_net, dev)
|
for_each_netdev_rcu(&init_net, dev)
|
||||||
cb->fill(cb, dev->name, netprio_prio(cont, dev));
|
cb->fill(cb, dev->name, netprio_prio(css, dev));
|
||||||
rcu_read_unlock();
|
rcu_read_unlock();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -191,6 +190,7 @@ static int read_priomap(struct cgroup *cont, struct cftype *cft,
|
||||||
static int write_priomap(struct cgroup *cgrp, struct cftype *cft,
|
static int write_priomap(struct cgroup *cgrp, struct cftype *cft,
|
||||||
const char *buffer)
|
const char *buffer)
|
||||||
{
|
{
|
||||||
|
struct cgroup_subsys_state *css = cgroup_css(cgrp, net_prio_subsys_id);
|
||||||
char devname[IFNAMSIZ + 1];
|
char devname[IFNAMSIZ + 1];
|
||||||
struct net_device *dev;
|
struct net_device *dev;
|
||||||
u32 prio;
|
u32 prio;
|
||||||
|
@ -205,7 +205,7 @@ static int write_priomap(struct cgroup *cgrp, struct cftype *cft,
|
||||||
|
|
||||||
rtnl_lock();
|
rtnl_lock();
|
||||||
|
|
||||||
ret = netprio_set_prio(cgrp, dev, prio);
|
ret = netprio_set_prio(css, dev, prio);
|
||||||
|
|
||||||
rtnl_unlock();
|
rtnl_unlock();
|
||||||
dev_put(dev);
|
dev_put(dev);
|
||||||
|
|
Loading…
Reference in a new issue