Commit cd48bdda authored by Daniel Borkmann's avatar Daniel Borkmann Committed by David S. Miller

sock: make cookie generation global instead of per netns

Generating and retrieving socket cookies are a useful feature that is
exposed to BPF for various program types through bpf_get_socket_cookie()
helper.

The fact that the cookie counter is per netns is quite a limitation
for BPF in practice in particular for programs in host namespace that
use socket cookies as part of a map lookup key since they will be
causing socket cookie collisions e.g. when attached to BPF cgroup hooks
or cls_bpf on tc egress in host namespace handling container traffic
from veth or ipvlan devices with peer in different netns. Change the
counter to be global instead.

Socket cookie consumers must assume the value as opqaue in any case.
Not every socket must have a cookie generated and knowledge of the
counter value itself does not provide much value either way hence
conversion to global is fine.
Signed-off-by: default avatarDaniel Borkmann <daniel@iogearbox.net>
Cc: Eric Dumazet <edumazet@google.com>
Cc: Alexei Starovoitov <ast@kernel.org>
Cc: Willem de Bruijn <willemb@google.com>
Cc: Martynas Pumputis <m@lambda.lt>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 7bac762d
...@@ -61,7 +61,6 @@ struct net { ...@@ -61,7 +61,6 @@ struct net {
spinlock_t rules_mod_lock; spinlock_t rules_mod_lock;
u32 hash_mix; u32 hash_mix;
atomic64_t cookie_gen;
struct list_head list; /* list of network namespaces */ struct list_head list; /* list of network namespaces */
struct list_head exit_list; /* To linked to call pernet exit struct list_head exit_list; /* To linked to call pernet exit
......
...@@ -1466,8 +1466,8 @@ union bpf_attr { ...@@ -1466,8 +1466,8 @@ union bpf_attr {
* If no cookie has been set yet, generate a new cookie. Once * If no cookie has been set yet, generate a new cookie. Once
* generated, the socket cookie remains stable for the life of the * generated, the socket cookie remains stable for the life of the
* socket. This helper can be useful for monitoring per socket * socket. This helper can be useful for monitoring per socket
* networking traffic statistics as it provides a unique socket * networking traffic statistics as it provides a global socket
* identifier per namespace. * identifier that can be assumed unique.
* Return * Return
* A 8-byte long non-decreasing number on success, or 0 if the * A 8-byte long non-decreasing number on success, or 0 if the
* socket field is missing inside *skb*. * socket field is missing inside *skb*.
......
...@@ -19,6 +19,7 @@ static const struct sock_diag_handler *sock_diag_handlers[AF_MAX]; ...@@ -19,6 +19,7 @@ static const struct sock_diag_handler *sock_diag_handlers[AF_MAX];
static int (*inet_rcv_compat)(struct sk_buff *skb, struct nlmsghdr *nlh); static int (*inet_rcv_compat)(struct sk_buff *skb, struct nlmsghdr *nlh);
static DEFINE_MUTEX(sock_diag_table_mutex); static DEFINE_MUTEX(sock_diag_table_mutex);
static struct workqueue_struct *broadcast_wq; static struct workqueue_struct *broadcast_wq;
static atomic64_t cookie_gen;
u64 sock_gen_cookie(struct sock *sk) u64 sock_gen_cookie(struct sock *sk)
{ {
...@@ -27,7 +28,7 @@ u64 sock_gen_cookie(struct sock *sk) ...@@ -27,7 +28,7 @@ u64 sock_gen_cookie(struct sock *sk)
if (res) if (res)
return res; return res;
res = atomic64_inc_return(&sock_net(sk)->cookie_gen); res = atomic64_inc_return(&cookie_gen);
atomic64_cmpxchg(&sk->sk_cookie, 0, res); atomic64_cmpxchg(&sk->sk_cookie, 0, res);
} }
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment