Commit 99de9d40 authored by Eric Biggers's avatar Eric Biggers Committed by Jakub Kicinski
Browse files

sctp: use skb_crc32c() instead of __skb_checksum()



Make sctp_compute_cksum() just use the new function skb_crc32c(),
instead of calling __skb_checksum() with a skb_checksum_ops struct that
does CRC32C.  This is faster and simpler.

Signed-off-by: default avatarEric Biggers <ebiggers@google.com>
Reviewed-by: default avatarHannes Reinecke <hare@suse.de>
Link: https://patch.msgid.link/20250519175012.36581-6-ebiggers@kernel.org


Signed-off-by: default avatarJakub Kicinski <kuba@kernel.org>
parent 62673b7d
Loading
Loading
Loading
Loading
+3 −26
Original line number Diff line number Diff line
@@ -15,8 +15,6 @@
 *    Dinakaran Joseph
 *    Jon Grimm <jgrimm@us.ibm.com>
 *    Sridhar Samudrala <sri@us.ibm.com>
 *
 * Rewritten to use libcrc32c by:
 *    Vlad Yasevich <vladislav.yasevich@hp.com>
 */

@@ -25,39 +23,18 @@

#include <linux/types.h>
#include <linux/sctp.h>
#include <linux/crc32c.h>
#include <linux/crc32.h>

static inline __wsum sctp_csum_update(const void *buff, int len, __wsum sum)
{
	return (__force __wsum)crc32c((__force __u32)sum, buff, len);
}

static inline __wsum sctp_csum_combine(__wsum csum, __wsum csum2,
				       int offset, int len)
{
	return (__force __wsum)crc32c_combine((__force __u32)csum,
					      (__force __u32)csum2, len);
}

static const struct skb_checksum_ops sctp_csum_ops = {
	.update  = sctp_csum_update,
	.combine = sctp_csum_combine,
};

static inline __le32 sctp_compute_cksum(const struct sk_buff *skb,
					unsigned int offset)
{
	struct sctphdr *sh = (struct sctphdr *)(skb->data + offset);
	__le32 old = sh->checksum;
	__wsum new;
	u32 new;

	sh->checksum = 0;
	new = ~__skb_checksum(skb, offset, skb->len - offset, ~(__wsum)0,
			      &sctp_csum_ops);
	new = ~skb_crc32c(skb, offset, skb->len - offset, ~0);
	sh->checksum = old;

	return cpu_to_le32((__force __u32)new);
	return cpu_to_le32(new);
}

#endif /* __sctp_checksum_h__ */
+2 −2
Original line number Diff line number Diff line
@@ -212,7 +212,7 @@ config NF_CT_PROTO_SCTP
	bool 'SCTP protocol connection tracking support'
	depends on NETFILTER_ADVANCED
	default y
	select CRC32
	select NET_CRC32C
	help
	  With this option enabled, the layer 3 independent connection
	  tracking code will be able to do state tracking on SCTP connections.
@@ -475,7 +475,7 @@ endif # NF_CONNTRACK

config NF_TABLES
	select NETFILTER_NETLINK
	select CRC32
	select NET_CRC32C
	tristate "Netfilter nf_tables support"
	help
	  nftables is the new packet classification framework that intends to
+1 −1
Original line number Diff line number Diff line
@@ -105,7 +105,7 @@ config IP_VS_PROTO_AH

config  IP_VS_PROTO_SCTP
	bool "SCTP load balancing support"
	select CRC32
	select NET_CRC32C
	help
	  This option enables support for load balancing SCTP transport
	  protocol. Say Y if unsure.
+1 −1
Original line number Diff line number Diff line
@@ -11,8 +11,8 @@ config OPENVSWITCH
				     (!NF_NAT || NF_NAT) && \
				     (!NETFILTER_CONNCOUNT || NETFILTER_CONNCOUNT)))
	depends on PSAMPLE || !PSAMPLE
	select CRC32
	select MPLS
	select NET_CRC32C
	select NET_MPLS_GSO
	select DST_CACHE
	select NET_NSH
+1 −1
Original line number Diff line number Diff line
@@ -796,7 +796,7 @@ config NET_ACT_SKBEDIT
config NET_ACT_CSUM
	tristate "Checksum Updating"
	depends on NET_CLS_ACT && INET
	select CRC32
	select NET_CRC32C
	help
	  Say Y here to update some common checksum after some direct
	  packet alterations.
Loading