|
@@ -1362,7 +1362,6 @@ static struct sock *sk_prot_alloc(struct proto *prot, gfp_t priority,
|
|
|
if (!try_module_get(prot->owner))
|
|
|
goto out_free_sec;
|
|
|
sk_tx_queue_clear(sk);
|
|
|
- cgroup_sk_alloc(&sk->sk_cgrp_data);
|
|
|
}
|
|
|
|
|
|
return sk;
|
|
@@ -1422,6 +1421,7 @@ struct sock *sk_alloc(struct net *net, int family, gfp_t priority,
|
|
|
sock_net_set(sk, net);
|
|
|
atomic_set(&sk->sk_wmem_alloc, 1);
|
|
|
|
|
|
+ cgroup_sk_alloc(&sk->sk_cgrp_data);
|
|
|
sock_update_classid(&sk->sk_cgrp_data);
|
|
|
sock_update_netprioidx(&sk->sk_cgrp_data);
|
|
|
}
|
|
@@ -1566,6 +1566,9 @@ struct sock *sk_clone_lock(const struct sock *sk, const gfp_t priority)
|
|
|
newsk->sk_priority = 0;
|
|
|
newsk->sk_incoming_cpu = raw_smp_processor_id();
|
|
|
atomic64_set(&newsk->sk_cookie, 0);
|
|
|
+
|
|
|
+ cgroup_sk_alloc(&newsk->sk_cgrp_data);
|
|
|
+
|
|
|
/*
|
|
|
* Before updating sk_refcnt, we must commit prior changes to memory
|
|
|
* (Documentation/RCU/rculist_nulls.txt for details)
|