2019-05-27 08:55:01 +02:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
2005-04-16 15:20:36 -07:00
|
|
|
/*
|
|
|
|
* INET An implementation of the TCP/IP protocol suite for the LINUX
|
|
|
|
* operating system. INET is implemented using the BSD Socket
|
|
|
|
* interface as the means of communication with the user level.
|
|
|
|
*
|
|
|
|
* Definitions for the UDP protocol.
|
|
|
|
*
|
|
|
|
* Version: @(#)udp.h 1.0.2 04/28/93
|
|
|
|
*
|
|
|
|
* Author: Fred N. van Kempen, <waltje@uWalt.NL.Mugnet.ORG>
|
|
|
|
*/
|
|
|
|
#ifndef _LINUX_UDP_H
|
|
|
|
#define _LINUX_UDP_H
|
|
|
|
|
2005-12-27 02:43:12 -02:00
|
|
|
#include <net/inet_sock.h>
|
2008-03-23 22:06:51 -07:00
|
|
|
#include <linux/skbuff.h>
|
2008-06-16 17:14:11 -07:00
|
|
|
#include <net/netns/hash.h>
|
2012-10-13 10:46:48 +01:00
|
|
|
#include <uapi/linux/udp.h>
|
2008-03-23 22:06:51 -07:00
|
|
|
|
|
|
|
static inline struct udphdr *udp_hdr(const struct sk_buff *skb)
|
|
|
|
{
|
|
|
|
return (struct udphdr *)skb_transport_header(skb);
|
|
|
|
}
|
|
|
|
|
udp: Introduce optional per-netns hash table.
The maximum hash table size is 64K due to the nature of the protocol. [0]
It's smaller than TCP, and fewer sockets can cause a performance drop.
On an EC2 c5.24xlarge instance (192 GiB memory), after running iperf3 in
different netns, creating 32Mi sockets without data transfer in the root
netns causes regression for the iperf3's connection.
uhash_entries sockets length Gbps
64K 1 1 5.69
1Mi 16 5.27
2Mi 32 4.90
4Mi 64 4.09
8Mi 128 2.96
16Mi 256 2.06
32Mi 512 1.12
The per-netns hash table breaks the lengthy lists into shorter ones. It is
useful on a multi-tenant system with thousands of netns. With smaller hash
tables, we can look up sockets faster, isolate noisy neighbours, and reduce
lock contention.
The max size of the per-netns table is 64K as well. This is because the
possible hash range by udp_hashfn() always fits in 64K within the same
netns and we cannot make full use of the whole buckets larger than 64K.
/* 0 < num < 64K -> X < hash < X + 64K */
(num + net_hash_mix(net)) & mask;
Also, the min size is 128. We use a bitmap to search for an available
port in udp_lib_get_port(). To keep the bitmap on the stack and not
fire the CONFIG_FRAME_WARN error at build time, we round up the table
size to 128.
The sysctl usage is the same with TCP:
$ dmesg | cut -d ' ' -f 6- | grep "UDP hash"
UDP hash table entries: 65536 (order: 9, 2097152 bytes, vmalloc)
# sysctl net.ipv4.udp_hash_entries
net.ipv4.udp_hash_entries = 65536 # can be changed by uhash_entries
# sysctl net.ipv4.udp_child_hash_entries
net.ipv4.udp_child_hash_entries = 0 # disabled by default
# ip netns add test1
# ip netns exec test1 sysctl net.ipv4.udp_hash_entries
net.ipv4.udp_hash_entries = -65536 # share the global table
# sysctl -w net.ipv4.udp_child_hash_entries=100
net.ipv4.udp_child_hash_entries = 100
# ip netns add test2
# ip netns exec test2 sysctl net.ipv4.udp_hash_entries
net.ipv4.udp_hash_entries = 128 # own a per-netns table with 2^n buckets
We could optimise the hash table lookup/iteration further by removing
the netns comparison for the per-netns one in the future. Also, we
could optimise the sparse udp_hslot layout by putting it in udp_table.
[0]: https://lore.kernel.org/netdev/4ACC2815.7010101@gmail.com/
Signed-off-by: Kuniyuki Iwashima <kuniyu@amazon.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2022-11-14 13:57:57 -08:00
|
|
|
#define UDP_HTABLE_SIZE_MIN_PERNET 128
|
2024-05-05 10:03:42 +02:00
|
|
|
#define UDP_HTABLE_SIZE_MIN (IS_ENABLED(CONFIG_BASE_SMALL) ? 128 : 256)
|
udp: Introduce optional per-netns hash table.
The maximum hash table size is 64K due to the nature of the protocol. [0]
It's smaller than TCP, and fewer sockets can cause a performance drop.
On an EC2 c5.24xlarge instance (192 GiB memory), after running iperf3 in
different netns, creating 32Mi sockets without data transfer in the root
netns causes regression for the iperf3's connection.
uhash_entries sockets length Gbps
64K 1 1 5.69
1Mi 16 5.27
2Mi 32 4.90
4Mi 64 4.09
8Mi 128 2.96
16Mi 256 2.06
32Mi 512 1.12
The per-netns hash table breaks the lengthy lists into shorter ones. It is
useful on a multi-tenant system with thousands of netns. With smaller hash
tables, we can look up sockets faster, isolate noisy neighbours, and reduce
lock contention.
The max size of the per-netns table is 64K as well. This is because the
possible hash range by udp_hashfn() always fits in 64K within the same
netns and we cannot make full use of the whole buckets larger than 64K.
/* 0 < num < 64K -> X < hash < X + 64K */
(num + net_hash_mix(net)) & mask;
Also, the min size is 128. We use a bitmap to search for an available
port in udp_lib_get_port(). To keep the bitmap on the stack and not
fire the CONFIG_FRAME_WARN error at build time, we round up the table
size to 128.
The sysctl usage is the same with TCP:
$ dmesg | cut -d ' ' -f 6- | grep "UDP hash"
UDP hash table entries: 65536 (order: 9, 2097152 bytes, vmalloc)
# sysctl net.ipv4.udp_hash_entries
net.ipv4.udp_hash_entries = 65536 # can be changed by uhash_entries
# sysctl net.ipv4.udp_child_hash_entries
net.ipv4.udp_child_hash_entries = 0 # disabled by default
# ip netns add test1
# ip netns exec test1 sysctl net.ipv4.udp_hash_entries
net.ipv4.udp_hash_entries = -65536 # share the global table
# sysctl -w net.ipv4.udp_child_hash_entries=100
net.ipv4.udp_child_hash_entries = 100
# ip netns add test2
# ip netns exec test2 sysctl net.ipv4.udp_hash_entries
net.ipv4.udp_hash_entries = 128 # own a per-netns table with 2^n buckets
We could optimise the hash table lookup/iteration further by removing
the netns comparison for the per-netns one in the future. Also, we
could optimise the sparse udp_hslot layout by putting it in udp_table.
[0]: https://lore.kernel.org/netdev/4ACC2815.7010101@gmail.com/
Signed-off-by: Kuniyuki Iwashima <kuniyu@amazon.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2022-11-14 13:57:57 -08:00
|
|
|
#define UDP_HTABLE_SIZE_MAX 65536
|
2005-04-16 15:20:36 -07:00
|
|
|
|
2015-03-18 14:05:33 -07:00
|
|
|
static inline u32 udp_hashfn(const struct net *net, u32 num, u32 mask)
|
2008-06-16 17:11:50 -07:00
|
|
|
{
|
2009-10-07 00:37:59 +00:00
|
|
|
return (num + net_hash_mix(net)) & mask;
|
2008-06-16 17:11:50 -07:00
|
|
|
}
|
|
|
|
|
2023-09-12 09:17:21 +00:00
|
|
|
enum {
|
|
|
|
UDP_FLAGS_CORK, /* Cork is required */
|
2023-09-12 09:17:22 +00:00
|
|
|
UDP_FLAGS_NO_CHECK6_TX, /* Send zero UDP6 checksums on TX? */
|
2023-09-12 09:17:23 +00:00
|
|
|
UDP_FLAGS_NO_CHECK6_RX, /* Allow zero UDP6 checksums on RX? */
|
2023-09-12 09:17:24 +00:00
|
|
|
UDP_FLAGS_GRO_ENABLED, /* Request GRO aggregation */
|
2023-09-12 09:17:26 +00:00
|
|
|
UDP_FLAGS_ACCEPT_FRAGLIST,
|
|
|
|
UDP_FLAGS_ACCEPT_L4,
|
2023-09-12 09:17:27 +00:00
|
|
|
UDP_FLAGS_ENCAP_ENABLED, /* This socket enabled encap */
|
2023-09-12 09:17:30 +00:00
|
|
|
UDP_FLAGS_UDPLITE_SEND_CC, /* set via udplite setsockopt */
|
|
|
|
UDP_FLAGS_UDPLITE_RECV_CC, /* set via udplite setsockopt */
|
2023-09-12 09:17:21 +00:00
|
|
|
};
|
|
|
|
|
2005-04-16 15:20:36 -07:00
|
|
|
struct udp_sock {
|
|
|
|
/* inet_sock has to be the first member */
|
|
|
|
struct inet_sock inet;
|
2009-11-08 10:17:30 +00:00
|
|
|
#define udp_port_hash inet.sk.__sk_common.skc_u16hashes[0]
|
|
|
|
#define udp_portaddr_hash inet.sk.__sk_common.skc_u16hashes[1]
|
2009-11-08 10:17:58 +00:00
|
|
|
#define udp_portaddr_node inet.sk.__sk_common.skc_portaddr_node
|
2023-09-12 09:17:21 +00:00
|
|
|
|
|
|
|
unsigned long udp_flags;
|
|
|
|
|
2005-04-16 15:20:36 -07:00
|
|
|
int pending; /* Any pending frames ? */
|
2014-05-23 08:47:32 -07:00
|
|
|
__u8 encap_type; /* Is this an Encapsulation socket? */
|
2023-09-12 09:17:27 +00:00
|
|
|
|
2024-11-14 18:52:05 +08:00
|
|
|
#if !IS_ENABLED(CONFIG_BASE_SMALL)
|
|
|
|
/* For UDP 4-tuple hash */
|
|
|
|
__u16 udp_lrpa_hash;
|
|
|
|
struct hlist_nulls_node udp_lrpa_node;
|
|
|
|
#endif
|
|
|
|
|
2005-04-16 15:20:36 -07:00
|
|
|
/*
|
2006-06-30 18:25:18 +02:00
|
|
|
* Following member retains the information to create a UDP header
|
2005-04-16 15:20:36 -07:00
|
|
|
* when the socket is uncorked.
|
|
|
|
*/
|
|
|
|
__u16 len; /* total length of pending frames */
|
udp: generate gso with UDP_SEGMENT
Support generic segmentation offload for udp datagrams. Callers can
concatenate and send at once the payload of multiple datagrams with
the same destination.
To set segment size, the caller sets socket option UDP_SEGMENT to the
length of each discrete payload. This value must be smaller than or
equal to the relevant MTU.
A follow-up patch adds cmsg UDP_SEGMENT to specify segment size on a
per send call basis.
Total byte length may then exceed MTU. If not an exact multiple of
segment size, the last segment will be shorter.
The implementation adds a gso_size field to the udp socket, ip(v6)
cmsg cookie and inet_cork structure to be able to set the value at
setsockopt or cmsg time and to work with both lockless and corked
paths.
Initial benchmark numbers show UDP GSO about as expensive as TCP GSO.
tcp tso
3197 MB/s 54232 msg/s 54232 calls/s
6,457,754,262 cycles
tcp gso
1765 MB/s 29939 msg/s 29939 calls/s
11,203,021,806 cycles
tcp without tso/gso *
739 MB/s 12548 msg/s 12548 calls/s
11,205,483,630 cycles
udp
876 MB/s 14873 msg/s 624666 calls/s
11,205,777,429 cycles
udp gso
2139 MB/s 36282 msg/s 36282 calls/s
11,204,374,561 cycles
[*] after reverting commit 0a6b2a1dc2a2
("tcp: switch to GSO being always on")
Measured total system cycles ('-a') for one core while pinning both
the network receive path and benchmark process to that core:
perf stat -a -C 12 -e cycles \
./udpgso_bench_tx -C 12 -4 -D "$DST" -l 4
Note the reduction in calls/s with GSO. Bytes per syscall drops
increases from 1470 to 61818.
Signed-off-by: Willem de Bruijn <willemb@google.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-04-26 13:42:17 -04:00
|
|
|
__u16 gso_size;
|
2006-11-27 11:10:57 -08:00
|
|
|
/*
|
|
|
|
* Fields specific to UDP-Lite.
|
|
|
|
*/
|
|
|
|
__u16 pcslen;
|
|
|
|
__u16 pcrlen;
|
2007-06-27 15:37:46 -07:00
|
|
|
/*
|
|
|
|
* For encapsulation sockets.
|
|
|
|
*/
|
|
|
|
int (*encap_rcv)(struct sock *sk, struct sk_buff *skb);
|
2022-10-12 08:49:29 +01:00
|
|
|
void (*encap_err_rcv)(struct sock *sk, struct sk_buff *skb, int err,
|
|
|
|
__be16 port, u32 info, u8 *payload);
|
udp: Handle ICMP errors for tunnels with same destination port on both endpoints
For both IPv4 and IPv6, if we can't match errors to a socket, try
tunnels before ignoring them. Look up a socket with the original source
and destination ports as found in the UDP packet inside the ICMP payload,
this will work for tunnels that force the same destination port for both
endpoints, i.e. VXLAN and GENEVE.
Actually, lwtunnels could break this assumption if they are configured by
an external control plane to have different destination ports on the
endpoints: in this case, we won't be able to trace ICMP messages back to
them.
For IPv6 redirect messages, call ip6_redirect() directly with the output
interface argument set to the interface we received the packet from (as
it's the very interface we should build the exception on), otherwise the
new nexthop will be rejected. There's no such need for IPv4.
Tunnels can now export an encap_err_lookup() operation that indicates a
match. Pass the packet to the lookup function, and if the tunnel driver
reports a matching association, continue with regular ICMP error handling.
v2:
- Added newline between network and transport header sets in
__udp{4,6}_lib_err_encap() (David Miller)
- Removed redundant skb_reset_network_header(skb); in
__udp4_lib_err_encap()
- Removed redundant reassignment of iph in __udp4_lib_err_encap()
(Sabrina Dubroca)
- Edited comment to __udp{4,6}_lib_err_encap() to reflect the fact this
won't work with lwtunnels configured to use asymmetric ports. By the way,
it's VXLAN, not VxLAN (Jiri Benc)
Signed-off-by: Stefano Brivio <sbrivio@redhat.com>
Reviewed-by: Sabrina Dubroca <sd@queasysnail.net>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-11-08 12:19:14 +01:00
|
|
|
int (*encap_err_lookup)(struct sock *sk, struct sk_buff *skb);
|
2013-03-19 06:11:12 +00:00
|
|
|
void (*encap_destroy)(struct sock *sk);
|
2016-04-05 08:22:51 -07:00
|
|
|
|
|
|
|
/* GRO functions for UDP socket */
|
2018-06-24 14:13:49 +09:00
|
|
|
struct sk_buff * (*gro_receive)(struct sock *sk,
|
|
|
|
struct list_head *head,
|
2016-04-05 08:22:51 -07:00
|
|
|
struct sk_buff *skb);
|
|
|
|
int (*gro_complete)(struct sock *sk,
|
|
|
|
struct sk_buff *skb,
|
|
|
|
int nhoff);
|
2016-12-08 11:41:56 -08:00
|
|
|
|
2017-05-16 11:20:14 +02:00
|
|
|
/* udp_recvmsg try to use this before splicing sk_receive_queue */
|
|
|
|
struct sk_buff_head reader_queue ____cacheline_aligned_in_smp;
|
|
|
|
|
2016-12-08 11:41:56 -08:00
|
|
|
/* This field is dirtied by udp_recvmsg() */
|
|
|
|
int forward_deficit;
|
2022-10-20 19:48:52 +02:00
|
|
|
|
|
|
|
/* This fields follows rcvbuf value, and is touched by udp_recvmsg */
|
|
|
|
int forward_threshold;
|
2024-02-20 12:00:01 +01:00
|
|
|
|
|
|
|
/* Cache friendly copy of sk->sk_peek_off >= 0 */
|
|
|
|
bool peeking_with_offset;
|
2005-04-16 15:20:36 -07:00
|
|
|
};
|
|
|
|
|
2023-09-12 09:17:21 +00:00
|
|
|
#define udp_test_bit(nr, sk) \
|
|
|
|
test_bit(UDP_FLAGS_##nr, &udp_sk(sk)->udp_flags)
|
|
|
|
#define udp_set_bit(nr, sk) \
|
|
|
|
set_bit(UDP_FLAGS_##nr, &udp_sk(sk)->udp_flags)
|
2023-09-12 09:17:27 +00:00
|
|
|
#define udp_test_and_set_bit(nr, sk) \
|
|
|
|
test_and_set_bit(UDP_FLAGS_##nr, &udp_sk(sk)->udp_flags)
|
2023-09-12 09:17:21 +00:00
|
|
|
#define udp_clear_bit(nr, sk) \
|
|
|
|
clear_bit(UDP_FLAGS_##nr, &udp_sk(sk)->udp_flags)
|
|
|
|
#define udp_assign_bit(nr, sk, val) \
|
|
|
|
assign_bit(UDP_FLAGS_##nr, &udp_sk(sk)->udp_flags, val)
|
|
|
|
|
2024-04-11 08:11:24 +03:00
|
|
|
#define UDP_MAX_SEGMENTS (1 << 7UL)
|
udp: generate gso with UDP_SEGMENT
Support generic segmentation offload for udp datagrams. Callers can
concatenate and send at once the payload of multiple datagrams with
the same destination.
To set segment size, the caller sets socket option UDP_SEGMENT to the
length of each discrete payload. This value must be smaller than or
equal to the relevant MTU.
A follow-up patch adds cmsg UDP_SEGMENT to specify segment size on a
per send call basis.
Total byte length may then exceed MTU. If not an exact multiple of
segment size, the last segment will be shorter.
The implementation adds a gso_size field to the udp socket, ip(v6)
cmsg cookie and inet_cork structure to be able to set the value at
setsockopt or cmsg time and to work with both lockless and corked
paths.
Initial benchmark numbers show UDP GSO about as expensive as TCP GSO.
tcp tso
3197 MB/s 54232 msg/s 54232 calls/s
6,457,754,262 cycles
tcp gso
1765 MB/s 29939 msg/s 29939 calls/s
11,203,021,806 cycles
tcp without tso/gso *
739 MB/s 12548 msg/s 12548 calls/s
11,205,483,630 cycles
udp
876 MB/s 14873 msg/s 624666 calls/s
11,205,777,429 cycles
udp gso
2139 MB/s 36282 msg/s 36282 calls/s
11,204,374,561 cycles
[*] after reverting commit 0a6b2a1dc2a2
("tcp: switch to GSO being always on")
Measured total system cycles ('-a') for one core while pinning both
the network receive path and benchmark process to that core:
perf stat -a -C 12 -e cycles \
./udpgso_bench_tx -C 12 -4 -D "$DST" -l 4
Note the reduction in calls/s with GSO. Bytes per syscall drops
increases from 1470 to 61818.
Signed-off-by: Willem de Bruijn <willemb@google.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2018-04-26 13:42:17 -04:00
|
|
|
|
2023-03-17 15:55:30 +00:00
|
|
|
#define udp_sk(ptr) container_of_const(ptr, struct udp_sock, inet.sk)
|
2008-03-01 01:06:47 +09:00
|
|
|
|
2024-02-20 12:00:01 +01:00
|
|
|
static inline int udp_set_peek_off(struct sock *sk, int val)
|
|
|
|
{
|
|
|
|
sk_set_peek_off(sk, val);
|
|
|
|
WRITE_ONCE(udp_sk(sk)->peeking_with_offset, val >= 0);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2014-05-23 08:47:32 -07:00
|
|
|
static inline void udp_set_no_check6_tx(struct sock *sk, bool val)
|
|
|
|
{
|
2023-09-12 09:17:22 +00:00
|
|
|
udp_assign_bit(NO_CHECK6_TX, sk, val);
|
2014-05-23 08:47:32 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
static inline void udp_set_no_check6_rx(struct sock *sk, bool val)
|
|
|
|
{
|
2023-09-12 09:17:23 +00:00
|
|
|
udp_assign_bit(NO_CHECK6_RX, sk, val);
|
2014-05-23 08:47:32 -07:00
|
|
|
}
|
|
|
|
|
2023-09-12 09:17:22 +00:00
|
|
|
static inline bool udp_get_no_check6_tx(const struct sock *sk)
|
2014-05-23 08:47:32 -07:00
|
|
|
{
|
2023-09-12 09:17:22 +00:00
|
|
|
return udp_test_bit(NO_CHECK6_TX, sk);
|
2014-05-23 08:47:32 -07:00
|
|
|
}
|
|
|
|
|
2023-09-12 09:17:23 +00:00
|
|
|
static inline bool udp_get_no_check6_rx(const struct sock *sk)
|
2014-05-23 08:47:32 -07:00
|
|
|
{
|
2023-09-12 09:17:23 +00:00
|
|
|
return udp_test_bit(NO_CHECK6_RX, sk);
|
2014-05-23 08:47:32 -07:00
|
|
|
}
|
|
|
|
|
2018-11-07 12:38:30 +01:00
|
|
|
static inline void udp_cmsg_recv(struct msghdr *msg, struct sock *sk,
|
|
|
|
struct sk_buff *skb)
|
|
|
|
{
|
|
|
|
int gso_size;
|
|
|
|
|
|
|
|
if (skb_shinfo(skb)->gso_type & SKB_GSO_UDP_L4) {
|
|
|
|
gso_size = skb_shinfo(skb)->gso_size;
|
|
|
|
put_cmsg(msg, SOL_UDP, UDP_GRO, sizeof(gso_size), &gso_size);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-03-26 12:33:58 +01:00
|
|
|
DECLARE_STATIC_KEY_FALSE(udp_encap_needed_key);
|
|
|
|
#if IS_ENABLED(CONFIG_IPV6)
|
|
|
|
DECLARE_STATIC_KEY_FALSE(udpv6_encap_needed_key);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
static inline bool udp_encap_needed(void)
|
|
|
|
{
|
|
|
|
if (static_branch_unlikely(&udp_encap_needed_key))
|
|
|
|
return true;
|
|
|
|
|
|
|
|
#if IS_ENABLED(CONFIG_IPV6)
|
|
|
|
if (static_branch_unlikely(&udpv6_encap_needed_key))
|
|
|
|
return true;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2018-11-07 12:38:33 +01:00
|
|
|
static inline bool udp_unexpected_gso(struct sock *sk, struct sk_buff *skb)
|
|
|
|
{
|
2021-03-30 12:28:52 +02:00
|
|
|
if (!skb_is_gso(skb))
|
|
|
|
return false;
|
|
|
|
|
2023-09-12 09:17:26 +00:00
|
|
|
if (skb_shinfo(skb)->gso_type & SKB_GSO_UDP_L4 &&
|
|
|
|
!udp_test_bit(ACCEPT_L4, sk))
|
2021-03-30 12:28:52 +02:00
|
|
|
return true;
|
|
|
|
|
2023-09-12 09:17:26 +00:00
|
|
|
if (skb_shinfo(skb)->gso_type & SKB_GSO_FRAGLIST &&
|
|
|
|
!udp_test_bit(ACCEPT_FRAGLIST, sk))
|
2021-03-30 12:28:52 +02:00
|
|
|
return true;
|
|
|
|
|
2024-03-26 12:33:58 +01:00
|
|
|
/* GSO packets lacking the SKB_GSO_UDP_TUNNEL/_CSUM bits might still
|
|
|
|
* land in a tunnel as the socket check in udp_gro_receive cannot be
|
|
|
|
* foolproof.
|
|
|
|
*/
|
|
|
|
if (udp_encap_needed() &&
|
|
|
|
READ_ONCE(udp_sk(sk)->encap_rcv) &&
|
|
|
|
!(skb_shinfo(skb)->gso_type &
|
|
|
|
(SKB_GSO_UDP_TUNNEL | SKB_GSO_UDP_TUNNEL_CSUM)))
|
|
|
|
return true;
|
|
|
|
|
2021-03-30 12:28:52 +02:00
|
|
|
return false;
|
2018-11-07 12:38:33 +01:00
|
|
|
}
|
|
|
|
|
2021-03-30 12:28:53 +02:00
|
|
|
static inline void udp_allow_gso(struct sock *sk)
|
|
|
|
{
|
2023-09-12 09:17:26 +00:00
|
|
|
udp_set_bit(ACCEPT_L4, sk);
|
|
|
|
udp_set_bit(ACCEPT_FRAGLIST, sk);
|
2021-03-30 12:28:53 +02:00
|
|
|
}
|
|
|
|
|
2016-04-01 08:52:13 -07:00
|
|
|
#define udp_portaddr_for_each_entry(__sk, list) \
|
|
|
|
hlist_for_each_entry(__sk, list, __sk_common.skc_portaddr_node)
|
2009-11-09 05:26:33 +00:00
|
|
|
|
2016-04-01 08:52:13 -07:00
|
|
|
#define udp_portaddr_for_each_entry_rcu(__sk, list) \
|
|
|
|
hlist_for_each_entry_rcu(__sk, list, __sk_common.skc_portaddr_node)
|
2009-11-09 05:26:33 +00:00
|
|
|
|
2024-11-14 18:52:05 +08:00
|
|
|
#if !IS_ENABLED(CONFIG_BASE_SMALL)
|
|
|
|
#define udp_lrpa_for_each_entry_rcu(__up, node, list) \
|
|
|
|
hlist_nulls_for_each_entry_rcu(__up, node, list, udp_lrpa_node)
|
|
|
|
#endif
|
|
|
|
|
2017-03-31 11:47:39 +02:00
|
|
|
#define IS_UDPLITE(__sk) (__sk->sk_protocol == IPPROTO_UDPLITE)
|
2005-04-16 15:20:36 -07:00
|
|
|
|
|
|
|
#endif /* _LINUX_UDP_H */
|