Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 134580
b: refs/heads/master
c: 4458f04
h: refs/heads/master
v: v3
  • Loading branch information
Vlad Yasevich authored and David S. Miller committed Feb 16, 2009
1 parent 31c15e3 commit 299a6de
Show file tree
Hide file tree
Showing 5 changed files with 21 additions and 22 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 06e868066e3b5828383eb40ff4d1c0029100b0b5
refs/heads/master: 4458f04c02a46c679a90ef71f866a415c192deb4
2 changes: 1 addition & 1 deletion trunk/include/linux/sctp.h
Original file line number Diff line number Diff line change
Expand Up @@ -60,7 +60,7 @@ typedef struct sctphdr {
__be16 source;
__be16 dest;
__be32 vtag;
__be32 checksum;
__le32 checksum;
} __attribute__((packed)) sctp_sctphdr_t;

#ifdef __KERNEL__
Expand Down
14 changes: 7 additions & 7 deletions trunk/include/net/sctp/checksum.h
Original file line number Diff line number Diff line change
Expand Up @@ -46,14 +46,14 @@
#include <net/sctp/sctp.h>
#include <linux/crc32c.h>

static inline __be32 sctp_crc32c(__be32 crc, u8 *buffer, u16 length)
static inline __u32 sctp_crc32c(__u32 crc, u8 *buffer, u16 length)
{
return (__force __be32)crc32c((__force u32)crc, buffer, length);
return crc32c(crc, buffer, length);
}

static inline __be32 sctp_start_cksum(__u8 *buffer, __u16 length)
static inline __u32 sctp_start_cksum(__u8 *buffer, __u16 length)
{
__be32 crc = ~cpu_to_be32(0);
__u32 crc = ~(__u32)0;
__u8 zero[sizeof(__u32)] = {0};

/* Optimize this routine to be SCTP specific, knowing how
Expand All @@ -72,12 +72,12 @@ static inline __be32 sctp_start_cksum(__u8 *buffer, __u16 length)
return crc;
}

static inline __be32 sctp_update_cksum(__u8 *buffer, __u16 length, __be32 crc32)
static inline __u32 sctp_update_cksum(__u8 *buffer, __u16 length, __u32 crc32)
{
return sctp_crc32c(crc32, buffer, length);
}

static inline __be32 sctp_end_cksum(__be32 crc32)
static inline __le32 sctp_end_cksum(__be32 crc32)
{
return (__force __be32)~cpu_to_le32((__force u32)crc32);
return cpu_to_le32(~crc32);
}
11 changes: 6 additions & 5 deletions trunk/net/sctp/input.c
Original file line number Diff line number Diff line change
Expand Up @@ -83,14 +83,15 @@ static inline int sctp_rcv_checksum(struct sk_buff *skb)
{
struct sk_buff *list = skb_shinfo(skb)->frag_list;
struct sctphdr *sh = sctp_hdr(skb);
__be32 cmp = sh->checksum;
__be32 val = sctp_start_cksum((__u8 *)sh, skb_headlen(skb));
__le32 cmp = sh->checksum;
__le32 val;
__u32 tmp = sctp_start_cksum((__u8 *)sh, skb_headlen(skb));

for (; list; list = list->next)
val = sctp_update_cksum((__u8 *)list->data, skb_headlen(list),
val);
tmp = sctp_update_cksum((__u8 *)list->data, skb_headlen(list),
tmp);

val = sctp_end_cksum(val);
val = sctp_end_cksum(tmp);

if (val != cmp) {
/* CRC failure, dump it. */
Expand Down
14 changes: 6 additions & 8 deletions trunk/net/sctp/output.c
Original file line number Diff line number Diff line change
Expand Up @@ -367,7 +367,6 @@ int sctp_packet_transmit(struct sctp_packet *packet)
struct sctp_transport *tp = packet->transport;
struct sctp_association *asoc = tp->asoc;
struct sctphdr *sh;
__be32 crc32 = cpu_to_be32(0);
struct sk_buff *nskb;
struct sctp_chunk *chunk, *tmp;
struct sock *sk;
Expand Down Expand Up @@ -532,16 +531,15 @@ int sctp_packet_transmit(struct sctp_packet *packet)
* by CRC32-C as described in <draft-ietf-tsvwg-sctpcsum-02.txt>.
*/
if (!sctp_checksum_disable && !(dst->dev->features & NETIF_F_NO_CSUM)) {
crc32 = sctp_start_cksum((__u8 *)sh, cksum_buf_len);
crc32 = sctp_end_cksum(crc32);
__u32 crc32 = sctp_start_cksum((__u8 *)sh, cksum_buf_len);

/* 3) Put the resultant value into the checksum field in the
* common header, and leave the rest of the bits unchanged.
*/
sh->checksum = sctp_end_cksum(crc32);
} else
nskb->ip_summed = CHECKSUM_UNNECESSARY;

/* 3) Put the resultant value into the checksum field in the
* common header, and leave the rest of the bits unchanged.
*/
sh->checksum = crc32;

/* IP layer ECN support
* From RFC 2481
* "The ECN-Capable Transport (ECT) bit would be set by the
Expand Down

0 comments on commit 299a6de

Please sign in to comment.