diff options
author | Xin Long <lucien.xin@gmail.com> | 2020-10-29 15:04:57 +0800 |
---|---|---|
committer | Jakub Kicinski <kuba@kernel.org> | 2020-10-30 15:23:46 -0700 |
commit | 527beb8ef9c02c11f8ca0d59fc46f7d081db1c33 (patch) | |
tree | 162a86e3d444a7088a87eccf7a64da557441adf0 /net/sctp/Kconfig | |
parent | 3c7d4415db6a2fa9312e3b5a3e7ca08ed09c9f57 (diff) | |
download | lwn-527beb8ef9c02c11f8ca0d59fc46f7d081db1c33.tar.gz lwn-527beb8ef9c02c11f8ca0d59fc46f7d081db1c33.zip |
udp: support sctp over udp in skb_udp_tunnel_segment
For the gso of sctp over udp packets, sctp_gso_segment() will be called in
skb_udp_tunnel_segment(), we need to set transport_header to sctp header.
As all the current HWs can't handle both crc checksum and udp checksum at
the same time, the crc checksum has to be done in sctp_gso_segment() by
removing the NETIF_F_SCTP_CRC flag from the features.
Meanwhile, if the HW can't do udp checksum, csum and csum_start has to be
set correctly, and udp checksum will be done in __skb_udp_tunnel_segment()
by calling gso_make_checksum().
Thanks to Paolo, Marcelo and Guillaume for helping with this one.
v1->v2:
- no change.
v2->v3:
- remove the he NETIF_F_SCTP_CRC flag from the features.
- set csum and csum_start in sctp_gso_make_checksum().
Signed-off-by: Xin Long <lucien.xin@gmail.com>
Acked-by: Marcelo Ricardo Leitner <marcelo.leitner@gmail.com>
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
Diffstat (limited to 'net/sctp/Kconfig')
0 files changed, 0 insertions, 0 deletions