diff options
author | Tejun Heo <tj@kernel.org> | 2015-12-07 17:38:52 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2015-12-08 22:02:33 -0500 |
commit | 2a56a1fec290bf0bc4676bbf4efdb3744953a3e7 (patch) | |
tree | c02ca93b96c4fa2c8aacf24f72f63d861794e567 /net/core/sock.c | |
parent | 297dbde19cf6a0ccb6fd4396c6220a5912ed61e8 (diff) |
net: wrap sock->sk_cgrp_prioidx and ->sk_classid inside a struct
Introduce sock->sk_cgrp_data which is a struct sock_cgroup_data.
->sk_cgroup_prioidx and ->sk_classid are moved into it. The struct
and its accessors are defined in cgroup-defs.h. This is to prepare
for overloading the fields with a cgroup pointer.
This patch mostly performs equivalent conversions but the followings
are noteworthy.
* Equality test before updating classid is removed from
sock_update_classid(). This shouldn't make any noticeable
difference and a similar test will be implemented on the helper side
later.
* sock_update_netprioidx() now takes struct sock_cgroup_data and can
be moved to netprio_cgroup.h without causing include dependency
loop. Moved.
* The dummy version of sock_update_netprioidx() converted to a static
inline function while at it.
Signed-off-by: Tejun Heo <tj@kernel.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/core/sock.c')
-rw-r--r-- | net/core/sock.c | 15 |
1 files changed, 2 insertions, 13 deletions
diff --git a/net/core/sock.c b/net/core/sock.c index 7965ef487375..947741dc43fa 100644 --- a/net/core/sock.c +++ b/net/core/sock.c | |||
@@ -1393,17 +1393,6 @@ static void sk_prot_free(struct proto *prot, struct sock *sk) | |||
1393 | module_put(owner); | 1393 | module_put(owner); |
1394 | } | 1394 | } |
1395 | 1395 | ||
1396 | #if IS_ENABLED(CONFIG_CGROUP_NET_PRIO) | ||
1397 | void sock_update_netprioidx(struct sock *sk) | ||
1398 | { | ||
1399 | if (in_interrupt()) | ||
1400 | return; | ||
1401 | |||
1402 | sk->sk_cgrp_prioidx = task_netprioidx(current); | ||
1403 | } | ||
1404 | EXPORT_SYMBOL_GPL(sock_update_netprioidx); | ||
1405 | #endif | ||
1406 | |||
1407 | /** | 1396 | /** |
1408 | * sk_alloc - All socket objects are allocated here | 1397 | * sk_alloc - All socket objects are allocated here |
1409 | * @net: the applicable net namespace | 1398 | * @net: the applicable net namespace |
@@ -1432,8 +1421,8 @@ struct sock *sk_alloc(struct net *net, int family, gfp_t priority, | |||
1432 | sock_net_set(sk, net); | 1421 | sock_net_set(sk, net); |
1433 | atomic_set(&sk->sk_wmem_alloc, 1); | 1422 | atomic_set(&sk->sk_wmem_alloc, 1); |
1434 | 1423 | ||
1435 | sock_update_classid(sk); | 1424 | sock_update_classid(&sk->sk_cgrp_data); |
1436 | sock_update_netprioidx(sk); | 1425 | sock_update_netprioidx(&sk->sk_cgrp_data); |
1437 | } | 1426 | } |
1438 | 1427 | ||
1439 | return sk; | 1428 | return sk; |