Re: [PATCH 03/23] netprio_cgroup: pass around @css instead of @cgroup and kill struct cgroup_netprio_state

2013-08-02 Thread Neil Horman
On Thu, Aug 01, 2013 at 05:49:41PM -0400, Tejun Heo wrote:
> 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 
> Cc: Neil Horman 
> Cc: David S. Miller 
Acked-by: Neil Horman 

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/


Re: [PATCH 03/23] netprio_cgroup: pass around @css instead of @cgroup and kill struct cgroup_netprio_state

2013-08-01 Thread David Miller
From: Tejun Heo 
Date: Thu,  1 Aug 2013 17:49:41 -0400

> 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 

Acked-by: David S. Miller 
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/


[PATCH 03/23] netprio_cgroup: pass around @css instead of @cgroup and kill struct cgroup_netprio_state

2013-08-01 Thread Tejun Heo
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 
Cc: Neil Horman 
Cc: David S. Miller 
---
 include/net/netprio_cgroup.h |  4 
 net/core/netprio_cgroup.c| 56 ++--
 2 files changed, 28 insertions(+), 32 deletions(-)

diff --git a/include/net/netprio_cgroup.h b/include/net/netprio_cgroup.h
index 8110fa7..a24f8bb 100644
--- a/include/net/netprio_cgroup.h
+++ b/include/net/netprio_cgroup.h
@@ -25,10 +25,6 @@ struct netprio_map {
u32 priomap[];
 };
 
-struct cgroup_netprio_state {
-   struct cgroup_subsys_state css;
-};
-
 extern void sock_update_netprioidx(struct sock *sk);
 
 #if IS_BUILTIN(CONFIG_NETPRIO_CGROUP)
diff --git a/net/core/netprio_cgroup.c b/net/core/netprio_cgroup.c
index ccf8523..5dfac88 100644
--- a/net/core/netprio_cgroup.c
+++ b/net/core/netprio_cgroup.c
@@ -29,12 +29,6 @@
 
 #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
  * @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
- * @cgrp: cgroup part of the target pair
+ * @css: css part of the target pair
  * @dev: net_device part of the target pair
  *
  * 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);
+   int id = css->cgroup->id;
 
-   if (map && cgrp->id < map->priomap_len)
-   return map->priomap[cgrp->id];
+   if (map && id < map->priomap_len)
+   return map->priomap[id];
return 0;
 }
 
 /**
  * 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
  * @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.
  */
-static int netprio_set_prio(struct cgroup *cgrp, struct net_device *dev,
-   u32 prio)
+static int netprio_set_prio(struct cgroup_subsys_state *css,
+   struct net_device *dev, u32 prio)
 {
struct netprio_map *map;
+   int id = css->cgroup->id;
int ret;
 
/* avoid extending priomap for zero writes */
map = rtnl_dereference(dev->priomap);
-   if (!prio && (!map || map->priomap_len <= cgrp->id))
+   if (!prio && (!map || map->priomap_len <= id))
return 0;
 
-   ret = extend_netdev_table(dev, cgrp->id);
+   ret = extend_netdev_table(dev, id);
if (ret)
return ret;
 
map = rtnl_dereference(dev->priomap);
-   map->priomap[cgrp->id] = prio;
+   map->priomap[id] = prio;
return 0;
 }
 
 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);
-   if (!cs)
+   css = kzalloc(sizeof(*css), GFP_KERNEL);
+   if (!css)
return ERR_PTR(-ENOMEM);
 
-   return &cs->css;
+   return css;
 }
 
 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;
int ret = 0;
 
-   if (!parent)
+   if (!cgrp->parent)
return 0;
+   parent_css = cgroup_css(cgrp->parent, net_prio_subsys_id);
 
rtnl_lock();
/*
@@ -156,9 +154,9 @@ static int cgrp_css_online(struct cgroup *cgrp)
 * onlining, there is no need to clear them on offline.
 */
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);
+