1 /* SPDX-License-Identifier: GPL-2.0 */ 2 #ifndef _SOCK_REUSEPORT_H 3 #define _SOCK_REUSEPORT_H 4 5 #include <linux/filter.h> 6 #include <linux/skbuff.h> 7 #include <linux/types.h> 8 #include <linux/spinlock.h> 9 #include <net/sock.h> 10 11 extern spinlock_t reuseport_lock; 12 13 struct sock_reuseport { 14 struct rcu_head rcu; 15 16 u16 max_socks; /* length of socks */ 17 u16 num_socks; /* elements in socks */ 18 u16 num_closed_socks; /* closed elements in socks */ 19 u16 incoming_cpu; 20 /* The last synq overflow event timestamp of this 21 * reuse->socks[] group. 22 */ 23 unsigned int synq_overflow_ts; 24 /* ID stays the same even after the size of socks[] grows. */ 25 unsigned int reuseport_id; 26 unsigned int bind_inany:1; 27 unsigned int has_conns:1; 28 struct bpf_prog __rcu *prog; /* optional BPF sock selector */ 29 struct sock *socks[] __counted_by(max_socks); 30 }; 31 32 extern int reuseport_alloc(struct sock *sk, bool bind_inany); 33 extern int reuseport_add_sock(struct sock *sk, struct sock *sk2, 34 bool bind_inany); 35 extern void reuseport_detach_sock(struct sock *sk); 36 void reuseport_stop_listen_sock(struct sock *sk); 37 extern struct sock *reuseport_select_sock(struct sock *sk, 38 u32 hash, 39 struct sk_buff *skb, 40 int hdr_len); 41 struct sock *reuseport_migrate_sock(struct sock *sk, 42 struct sock *migrating_sk, 43 struct sk_buff *skb); 44 extern int reuseport_attach_prog(struct sock *sk, struct bpf_prog *prog); 45 extern int reuseport_detach_prog(struct sock *sk); 46 47 static inline bool reuseport_has_conns(struct sock *sk) 48 { 49 struct sock_reuseport *reuse; 50 bool ret = false; 51 52 rcu_read_lock(); 53 reuse = rcu_dereference(sk->sk_reuseport_cb); 54 if (reuse && reuse->has_conns) 55 ret = true; 56 rcu_read_unlock(); 57 58 return ret; 59 } 60 61 void reuseport_has_conns_set(struct sock *sk); 62 void reuseport_update_incoming_cpu(struct sock *sk, int val); 63 64 #endif /* _SOCK_REUSEPORT_H */ 65