* [PATCH] sctp: remove unnecessary byteshifting, calculate crc in big-endian
@ 2008-07-04 1:13 Harvey Harrison
2008-07-09 20:59 ` Vlad Yasevich
0 siblings, 1 reply; 8+ messages in thread
From: Harvey Harrison @ 2008-07-04 1:13 UTC (permalink / raw)
To: David Miller; +Cc: linux-netdev, Andrew Morton
Signed-off-by: Harvey Harrison <harvey.harrison@gmail.com>
---
include/net/sctp/checksum.h | 23 ++++++++++++++---------
net/ipv4/netfilter/nf_nat_proto_sctp.c | 4 ++--
net/sctp/input.c | 4 ++--
net/sctp/output.c | 4 ++--
4 files changed, 20 insertions(+), 15 deletions(-)
diff --git a/include/net/sctp/checksum.h b/include/net/sctp/checksum.h
index ba75c67..b799fb2 100644
--- a/include/net/sctp/checksum.h
+++ b/include/net/sctp/checksum.h
@@ -46,9 +46,14 @@
#include <net/sctp/sctp.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};
/* 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. */
- 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. */
- crc = crc32c(crc, zero, sizeof(__u32));
+ crc = sctp_crc32c(crc, zero, sizeof(__u32));
/* 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));
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;
}
diff --git a/net/ipv4/netfilter/nf_nat_proto_sctp.c b/net/ipv4/netfilter/nf_nat_proto_sctp.c
index 82e4c0e..65e470b 100644
--- a/net/ipv4/netfilter/nf_nat_proto_sctp.c
+++ b/net/ipv4/netfilter/nf_nat_proto_sctp.c
@@ -36,7 +36,7 @@ sctp_manip_pkt(struct sk_buff *skb,
sctp_sctphdr_t *hdr;
unsigned int hdroff = iphdroff + iph->ihl*4;
__be32 oldip, newip;
- u32 crc32;
+ __be32 crc32;
if (!skb_make_writable(skb, hdroff + sizeof(*hdr)))
return false;
@@ -61,7 +61,7 @@ sctp_manip_pkt(struct sk_buff *skb,
crc32 = sctp_update_cksum((u8 *)skb->data, skb_headlen(skb),
crc32);
crc32 = sctp_end_cksum(crc32);
- hdr->checksum = htonl(crc32);
+ hdr->checksum = crc32;
return true;
}
diff --git a/net/sctp/input.c b/net/sctp/input.c
index d354a23..463d529 100644
--- a/net/sctp/input.c
+++ b/net/sctp/input.c
@@ -82,8 +82,8 @@ 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);
- __u32 cmp = ntohl(sh->checksum);
- __u32 val = sctp_start_cksum((__u8 *)sh, skb_headlen(skb));
+ __be32 cmp = sh->checksum;
+ __be32 val = sctp_start_cksum((__u8 *)sh, skb_headlen(skb));
for (; list; list = list->next)
val = sctp_update_cksum((__u8 *)list->data, skb_headlen(list),
diff --git a/net/sctp/output.c b/net/sctp/output.c
index abcd00d..e2158ad 100644
--- a/net/sctp/output.c
+++ b/net/sctp/output.c
@@ -364,7 +364,7 @@ int sctp_packet_transmit(struct sctp_packet *packet)
struct sctp_transport *tp = packet->transport;
struct sctp_association *asoc = tp->asoc;
struct sctphdr *sh;
- __u32 crc32 = 0;
+ __be32 crc32 = cpu_to_be32(0);
struct sk_buff *nskb;
struct sctp_chunk *chunk, *tmp;
struct sock *sk;
@@ -537,7 +537,7 @@ int sctp_packet_transmit(struct sctp_packet *packet)
/* 3) Put the resultant value into the checksum field in the
* common header, and leave the rest of the bits unchanged.
*/
- sh->checksum = htonl(crc32);
+ sh->checksum = crc32;
/* IP layer ECN support
* From RFC 2481
--
1.5.6.1.281.g1087e
^ permalink raw reply related [flat|nested] 8+ messages in thread
* Re: [PATCH] sctp: remove unnecessary byteshifting, calculate crc in big-endian
2008-07-04 1:13 [PATCH] sctp: remove unnecessary byteshifting, calculate crc in big-endian Harvey Harrison
@ 2008-07-09 20:59 ` Vlad Yasevich
2008-07-10 1:01 ` Harvey Harrison
0 siblings, 1 reply; 8+ messages in thread
From: Vlad Yasevich @ 2008-07-09 20:59 UTC (permalink / raw)
To: Harvey Harrison; +Cc: David Miller, linux-netdev, Andrew Morton
Harvey Harrison wrote:
> Signed-off-by: Harvey Harrison <harvey.harrison@gmail.com>
> ---
> include/net/sctp/checksum.h | 23 ++++++++++++++---------
> net/ipv4/netfilter/nf_nat_proto_sctp.c | 4 ++--
> net/sctp/input.c | 4 ++--
> net/sctp/output.c | 4 ++--
> 4 files changed, 20 insertions(+), 15 deletions(-)
>
> diff --git a/include/net/sctp/checksum.h b/include/net/sctp/checksum.h
> index ba75c67..b799fb2 100644
> --- a/include/net/sctp/checksum.h
> +++ b/include/net/sctp/checksum.h
> @@ -46,9 +46,14 @@
> #include <net/sctp/sctp.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};
>
> /* 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. */
> - 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. */
> - crc = crc32c(crc, zero, sizeof(__u32));
> + crc = sctp_crc32c(crc, zero, sizeof(__u32));
>
> /* 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));
> 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;
> }
> diff --git a/net/ipv4/netfilter/nf_nat_proto_sctp.c b/net/ipv4/netfilter/nf_nat_proto_sctp.c
> index 82e4c0e..65e470b 100644
> --- a/net/ipv4/netfilter/nf_nat_proto_sctp.c
> +++ b/net/ipv4/netfilter/nf_nat_proto_sctp.c
> @@ -36,7 +36,7 @@ sctp_manip_pkt(struct sk_buff *skb,
> sctp_sctphdr_t *hdr;
> unsigned int hdroff = iphdroff + iph->ihl*4;
> __be32 oldip, newip;
> - u32 crc32;
> + __be32 crc32;
>
> if (!skb_make_writable(skb, hdroff + sizeof(*hdr)))
> return false;
> @@ -61,7 +61,7 @@ sctp_manip_pkt(struct sk_buff *skb,
> crc32 = sctp_update_cksum((u8 *)skb->data, skb_headlen(skb),
> crc32);
> crc32 = sctp_end_cksum(crc32);
> - hdr->checksum = htonl(crc32);
> + hdr->checksum = crc32;
>
> return true;
> }
> diff --git a/net/sctp/input.c b/net/sctp/input.c
> index d354a23..463d529 100644
> --- a/net/sctp/input.c
> +++ b/net/sctp/input.c
> @@ -82,8 +82,8 @@ 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);
> - __u32 cmp = ntohl(sh->checksum);
> - __u32 val = sctp_start_cksum((__u8 *)sh, skb_headlen(skb));
> + __be32 cmp = sh->checksum;
> + __be32 val = sctp_start_cksum((__u8 *)sh, skb_headlen(skb));
>
> for (; list; list = list->next)
> val = sctp_update_cksum((__u8 *)list->data, skb_headlen(list),
> diff --git a/net/sctp/output.c b/net/sctp/output.c
> index abcd00d..e2158ad 100644
> --- a/net/sctp/output.c
> +++ b/net/sctp/output.c
> @@ -364,7 +364,7 @@ int sctp_packet_transmit(struct sctp_packet *packet)
> struct sctp_transport *tp = packet->transport;
> struct sctp_association *asoc = tp->asoc;
> struct sctphdr *sh;
> - __u32 crc32 = 0;
> + __be32 crc32 = cpu_to_be32(0);
Does this actually do anything?
Otherwise, good clean-up. Thanks
-vlad
> struct sk_buff *nskb;
> struct sctp_chunk *chunk, *tmp;
> struct sock *sk;
> @@ -537,7 +537,7 @@ int sctp_packet_transmit(struct sctp_packet *packet)
> /* 3) Put the resultant value into the checksum field in the
> * common header, and leave the rest of the bits unchanged.
> */
> - sh->checksum = htonl(crc32);
> + sh->checksum = crc32;
>
> /* IP layer ECN support
> * From RFC 2481
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH] sctp: remove unnecessary byteshifting, calculate crc in big-endian
2008-07-09 20:59 ` Vlad Yasevich
@ 2008-07-10 1:01 ` Harvey Harrison
2008-07-10 12:43 ` Vlad Yasevich
0 siblings, 1 reply; 8+ messages in thread
From: Harvey Harrison @ 2008-07-10 1:01 UTC (permalink / raw)
To: Vlad Yasevich; +Cc: David Miller, linux-netdev, Andrew Morton
On Wed, 2008-07-09 at 16:59 -0400, Vlad Yasevich wrote:
> Harvey Harrison wrote:
> > - __u32 crc32 = 0;
> > + __be32 crc32 = cpu_to_be32(0);
>
> Does this actually do anything?
>
> Otherwise, good clean-up. Thanks
>
Keeps sparse happy.
Harvey
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH] sctp: remove unnecessary byteshifting, calculate crc in big-endian
2008-07-10 1:01 ` Harvey Harrison
@ 2008-07-10 12:43 ` Vlad Yasevich
2008-07-11 18:07 ` Harvey Harrison
2008-07-17 19:21 ` Harvey Harrison
0 siblings, 2 replies; 8+ messages in thread
From: Vlad Yasevich @ 2008-07-10 12:43 UTC (permalink / raw)
To: Harvey Harrison; +Cc: David Miller, linux-netdev, Andrew Morton
Harvey Harrison wrote:
> On Wed, 2008-07-09 at 16:59 -0400, Vlad Yasevich wrote:
>> Harvey Harrison wrote:
>>> - __u32 crc32 = 0;
>>> + __be32 crc32 = cpu_to_be32(0);
>> Does this actually do anything?
>>
>> Otherwise, good clean-up. Thanks
>>
>
> Keeps sparse happy.
Wouldn't just a (__force __be32)0 do the same thing and
avoid useless byte swapping on little endian?
-vald
>
> Harvey
>
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH] sctp: remove unnecessary byteshifting, calculate crc in big-endian
2008-07-10 12:43 ` Vlad Yasevich
@ 2008-07-11 18:07 ` Harvey Harrison
2008-07-17 19:21 ` Harvey Harrison
1 sibling, 0 replies; 8+ messages in thread
From: Harvey Harrison @ 2008-07-11 18:07 UTC (permalink / raw)
To: Vlad Yasevich; +Cc: David Miller, linux-netdev, Andrew Morton
On Thu, 2008-07-10 at 08:43 -0400, Vlad Yasevich wrote:
> Harvey Harrison wrote:
> > On Wed, 2008-07-09 at 16:59 -0400, Vlad Yasevich wrote:
> >> Harvey Harrison wrote:
> >>> - __u32 crc32 = 0;
> >>> + __be32 crc32 = cpu_to_be32(0);
> >> Does this actually do anything?
> >>
> >> Otherwise, good clean-up. Thanks
> >>
> >
> > Keeps sparse happy.
>
> Wouldn't just a (__force __be32)0 do the same thing and
> avoid useless byte swapping on little endian?
>
I'm trying to get a patch accepted that makes cpu_to_be32 do compile-time
folding if possible, so in the future this won't produce any additional
code. For now, just use __constant_cpu_to_be32(0)
Harvey
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH] sctp: remove unnecessary byteshifting, calculate crc in big-endian
2008-07-10 12:43 ` Vlad Yasevich
2008-07-11 18:07 ` Harvey Harrison
@ 2008-07-17 19:21 ` Harvey Harrison
2008-07-17 19:24 ` Vlad Yasevich
1 sibling, 1 reply; 8+ messages in thread
From: Harvey Harrison @ 2008-07-17 19:21 UTC (permalink / raw)
To: Vlad Yasevich; +Cc: David Miller, linux-netdev, Andrew Morton
On Thu, 2008-07-10 at 08:43 -0400, Vlad Yasevich wrote:
> Harvey Harrison wrote:
> > On Wed, 2008-07-09 at 16:59 -0400, Vlad Yasevich wrote:
> >> Harvey Harrison wrote:
> >>> - __u32 crc32 = 0;
> >>> + __be32 crc32 = cpu_to_be32(0);
> >> Does this actually do anything?
> >>
> >> Otherwise, good clean-up. Thanks
> >>
> >
> > Keeps sparse happy.
>
> Wouldn't just a (__force __be32)0 do the same thing and
> avoid useless byte swapping on little endian?
>
Vlad, do you want me to revise the patch, or were you taking it as is?
Harvey
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH] sctp: remove unnecessary byteshifting, calculate crc in big-endian
2008-07-17 19:21 ` Harvey Harrison
@ 2008-07-17 19:24 ` Vlad Yasevich
2008-07-17 19:31 ` [PATCHv2] sctp: remove unnecessary byteshifting, calculate directly " Harvey Harrison
0 siblings, 1 reply; 8+ messages in thread
From: Vlad Yasevich @ 2008-07-17 19:24 UTC (permalink / raw)
To: Harvey Harrison; +Cc: David Miller, linux-netdev, Andrew Morton
Harvey Harrison wrote:
> On Thu, 2008-07-10 at 08:43 -0400, Vlad Yasevich wrote:
>> Harvey Harrison wrote:
>>> On Wed, 2008-07-09 at 16:59 -0400, Vlad Yasevich wrote:
>>>> Harvey Harrison wrote:
>>>>> - __u32 crc32 = 0;
>>>>> + __be32 crc32 = cpu_to_be32(0);
>>>> Does this actually do anything?
>>>>
>>>> Otherwise, good clean-up. Thanks
>>>>
>>> Keeps sparse happy.
>> Wouldn't just a (__force __be32)0 do the same thing and
>> avoid useless byte swapping on little endian?
>>
>
> Vlad, do you want me to revise the patch, or were you taking it as is?
>
> Harvey
>
Could you fix it please.
Thanks
-vlad
^ permalink raw reply [flat|nested] 8+ messages in thread
* [PATCHv2] sctp: remove unnecessary byteshifting, calculate directly in big-endian
2008-07-17 19:24 ` Vlad Yasevich
@ 2008-07-17 19:31 ` Harvey Harrison
0 siblings, 0 replies; 8+ messages in thread
From: Harvey Harrison @ 2008-07-17 19:31 UTC (permalink / raw)
To: Vlad Yasevich; +Cc: David Miller, linux-netdev, Andrew Morton
Signed-off-by: Harvey Harrison <harvey.harrison@gmail.com>
---
Vlad, I went with __constant_cpu_to_be32 which does the compile-time
folding, rather than the __force cast.
include/net/sctp/checksum.h | 23 ++++++++++++++---------
net/ipv4/netfilter/nf_nat_proto_sctp.c | 4 ++--
net/sctp/input.c | 4 ++--
net/sctp/output.c | 4 ++--
4 files changed, 20 insertions(+), 15 deletions(-)
diff --git a/include/net/sctp/checksum.h b/include/net/sctp/checksum.h
index ba75c67..b799fb2 100644
--- a/include/net/sctp/checksum.h
+++ b/include/net/sctp/checksum.h
@@ -46,9 +46,14 @@
#include <net/sctp/sctp.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};
/* 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. */
- 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. */
- crc = crc32c(crc, zero, sizeof(__u32));
+ crc = sctp_crc32c(crc, zero, sizeof(__u32));
/* 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));
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;
}
diff --git a/net/ipv4/netfilter/nf_nat_proto_sctp.c b/net/ipv4/netfilter/nf_nat_proto_sctp.c
index 82e4c0e..65e470b 100644
--- a/net/ipv4/netfilter/nf_nat_proto_sctp.c
+++ b/net/ipv4/netfilter/nf_nat_proto_sctp.c
@@ -36,7 +36,7 @@ sctp_manip_pkt(struct sk_buff *skb,
sctp_sctphdr_t *hdr;
unsigned int hdroff = iphdroff + iph->ihl*4;
__be32 oldip, newip;
- u32 crc32;
+ __be32 crc32;
if (!skb_make_writable(skb, hdroff + sizeof(*hdr)))
return false;
@@ -61,7 +61,7 @@ sctp_manip_pkt(struct sk_buff *skb,
crc32 = sctp_update_cksum((u8 *)skb->data, skb_headlen(skb),
crc32);
crc32 = sctp_end_cksum(crc32);
- hdr->checksum = htonl(crc32);
+ hdr->checksum = crc32;
return true;
}
diff --git a/net/sctp/input.c b/net/sctp/input.c
index d354a23..463d529 100644
--- a/net/sctp/input.c
+++ b/net/sctp/input.c
@@ -82,8 +82,8 @@ 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);
- __u32 cmp = ntohl(sh->checksum);
- __u32 val = sctp_start_cksum((__u8 *)sh, skb_headlen(skb));
+ __be32 cmp = sh->checksum;
+ __be32 val = sctp_start_cksum((__u8 *)sh, skb_headlen(skb));
for (; list; list = list->next)
val = sctp_update_cksum((__u8 *)list->data, skb_headlen(list),
diff --git a/net/sctp/output.c b/net/sctp/output.c
index abcd00d..e2158ad 100644
--- a/net/sctp/output.c
+++ b/net/sctp/output.c
@@ -364,7 +364,7 @@ int sctp_packet_transmit(struct sctp_packet *packet)
struct sctp_transport *tp = packet->transport;
struct sctp_association *asoc = tp->asoc;
struct sctphdr *sh;
- __u32 crc32 = 0;
+ __be32 crc32 = __constant_cpu_to_be32(0);
struct sk_buff *nskb;
struct sctp_chunk *chunk, *tmp;
struct sock *sk;
@@ -537,7 +537,7 @@ int sctp_packet_transmit(struct sctp_packet *packet)
/* 3) Put the resultant value into the checksum field in the
* common header, and leave the rest of the bits unchanged.
*/
- sh->checksum = htonl(crc32);
+ sh->checksum = crc32;
/* IP layer ECN support
* From RFC 2481
--
1.5.6.1.281.g1087e
^ permalink raw reply related [flat|nested] 8+ messages in thread
end of thread, other threads:[~2008-07-17 19:31 UTC | newest]
Thread overview: 8+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-07-04 1:13 [PATCH] sctp: remove unnecessary byteshifting, calculate crc in big-endian Harvey Harrison
2008-07-09 20:59 ` Vlad Yasevich
2008-07-10 1:01 ` Harvey Harrison
2008-07-10 12:43 ` Vlad Yasevich
2008-07-11 18:07 ` Harvey Harrison
2008-07-17 19:21 ` Harvey Harrison
2008-07-17 19:24 ` Vlad Yasevich
2008-07-17 19:31 ` [PATCHv2] sctp: remove unnecessary byteshifting, calculate directly " Harvey Harrison
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).