sctp: remove unnecessary byteshifting, calculate directly in big-endian
Signed-off-by: Harvey Harrison <harvey.harrison@gmail.com> Signed-off-by: Vlad Yasevich <vladislav.yasevich@hp.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
committed by
David S. Miller
parent
4e54064e0a
commit
336d3262df
@@ -46,9 +46,14 @@
|
|||||||
#include <net/sctp/sctp.h>
|
#include <net/sctp/sctp.h>
|
||||||
#include <linux/crc32c.h>
|
#include <linux/crc32c.h>
|
||||||
|
|
||||||
static inline __u32 sctp_start_cksum(__u8 *buffer, __u16 length)
|
static inline __be32 sctp_crc32c(__be32 crc, u8 *buffer, u16 length)
|
||||||
{
|
{
|
||||||
__u32 crc = ~(__u32) 0;
|
return (__force __be32)crc32c((__force u32)crc, buffer, length);
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline __be32 sctp_start_cksum(__u8 *buffer, __u16 length)
|
||||||
|
{
|
||||||
|
__be32 crc = ~cpu_to_be32(0);
|
||||||
__u8 zero[sizeof(__u32)] = {0};
|
__u8 zero[sizeof(__u32)] = {0};
|
||||||
|
|
||||||
/* Optimize this routine to be SCTP specific, knowing how
|
/* Optimize this routine to be SCTP specific, knowing how
|
||||||
@@ -56,23 +61,23 @@ static inline __u32 sctp_start_cksum(__u8 *buffer, __u16 length)
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
/* Calculate CRC up to the checksum. */
|
/* Calculate CRC up to the checksum. */
|
||||||
crc = crc32c(crc, buffer, sizeof(struct sctphdr) - sizeof(__u32));
|
crc = sctp_crc32c(crc, buffer, sizeof(struct sctphdr) - sizeof(__u32));
|
||||||
|
|
||||||
/* Skip checksum field of the header. */
|
/* Skip checksum field of the header. */
|
||||||
crc = crc32c(crc, zero, sizeof(__u32));
|
crc = sctp_crc32c(crc, zero, sizeof(__u32));
|
||||||
|
|
||||||
/* Calculate the rest of the CRC. */
|
/* Calculate the rest of the CRC. */
|
||||||
crc = crc32c(crc, &buffer[sizeof(struct sctphdr)],
|
crc = sctp_crc32c(crc, &buffer[sizeof(struct sctphdr)],
|
||||||
length - sizeof(struct sctphdr));
|
length - sizeof(struct sctphdr));
|
||||||
return crc;
|
return crc;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline __u32 sctp_update_cksum(__u8 *buffer, __u16 length, __u32 crc32)
|
static inline __be32 sctp_update_cksum(__u8 *buffer, __u16 length, __be32 crc32)
|
||||||
{
|
{
|
||||||
return crc32c(crc32, buffer, length);
|
return sctp_crc32c(crc32, buffer, length);
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline __u32 sctp_end_cksum(__u32 crc32)
|
static inline __be32 sctp_end_cksum(__be32 crc32)
|
||||||
{
|
{
|
||||||
return ntohl(~crc32);
|
return ~crc32;
|
||||||
}
|
}
|
||||||
|
@@ -36,7 +36,7 @@ sctp_manip_pkt(struct sk_buff *skb,
|
|||||||
sctp_sctphdr_t *hdr;
|
sctp_sctphdr_t *hdr;
|
||||||
unsigned int hdroff = iphdroff + iph->ihl*4;
|
unsigned int hdroff = iphdroff + iph->ihl*4;
|
||||||
__be32 oldip, newip;
|
__be32 oldip, newip;
|
||||||
u32 crc32;
|
__be32 crc32;
|
||||||
|
|
||||||
if (!skb_make_writable(skb, hdroff + sizeof(*hdr)))
|
if (!skb_make_writable(skb, hdroff + sizeof(*hdr)))
|
||||||
return false;
|
return false;
|
||||||
@@ -61,7 +61,7 @@ sctp_manip_pkt(struct sk_buff *skb,
|
|||||||
crc32 = sctp_update_cksum((u8 *)skb->data, skb_headlen(skb),
|
crc32 = sctp_update_cksum((u8 *)skb->data, skb_headlen(skb),
|
||||||
crc32);
|
crc32);
|
||||||
crc32 = sctp_end_cksum(crc32);
|
crc32 = sctp_end_cksum(crc32);
|
||||||
hdr->checksum = htonl(crc32);
|
hdr->checksum = crc32;
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@@ -83,8 +83,8 @@ static inline int sctp_rcv_checksum(struct sk_buff *skb)
|
|||||||
{
|
{
|
||||||
struct sk_buff *list = skb_shinfo(skb)->frag_list;
|
struct sk_buff *list = skb_shinfo(skb)->frag_list;
|
||||||
struct sctphdr *sh = sctp_hdr(skb);
|
struct sctphdr *sh = sctp_hdr(skb);
|
||||||
__u32 cmp = ntohl(sh->checksum);
|
__be32 cmp = sh->checksum;
|
||||||
__u32 val = sctp_start_cksum((__u8 *)sh, skb_headlen(skb));
|
__be32 val = sctp_start_cksum((__u8 *)sh, skb_headlen(skb));
|
||||||
|
|
||||||
for (; list; list = list->next)
|
for (; list; list = list->next)
|
||||||
val = sctp_update_cksum((__u8 *)list->data, skb_headlen(list),
|
val = sctp_update_cksum((__u8 *)list->data, skb_headlen(list),
|
||||||
|
@@ -365,7 +365,7 @@ int sctp_packet_transmit(struct sctp_packet *packet)
|
|||||||
struct sctp_transport *tp = packet->transport;
|
struct sctp_transport *tp = packet->transport;
|
||||||
struct sctp_association *asoc = tp->asoc;
|
struct sctp_association *asoc = tp->asoc;
|
||||||
struct sctphdr *sh;
|
struct sctphdr *sh;
|
||||||
__u32 crc32 = 0;
|
__be32 crc32 = __constant_cpu_to_be32(0);
|
||||||
struct sk_buff *nskb;
|
struct sk_buff *nskb;
|
||||||
struct sctp_chunk *chunk, *tmp;
|
struct sctp_chunk *chunk, *tmp;
|
||||||
struct sock *sk;
|
struct sock *sk;
|
||||||
@@ -538,7 +538,7 @@ int sctp_packet_transmit(struct sctp_packet *packet)
|
|||||||
/* 3) Put the resultant value into the checksum field in the
|
/* 3) Put the resultant value into the checksum field in the
|
||||||
* common header, and leave the rest of the bits unchanged.
|
* common header, and leave the rest of the bits unchanged.
|
||||||
*/
|
*/
|
||||||
sh->checksum = htonl(crc32);
|
sh->checksum = crc32;
|
||||||
|
|
||||||
/* IP layer ECN support
|
/* IP layer ECN support
|
||||||
* From RFC 2481
|
* From RFC 2481
|
||||||
|
Reference in New Issue
Block a user