Commit 7cd61888 authored by Al Viro's avatar Al Viro Committed by David S. Miller

slhc annotations

Signed-off-by: default avatarAl Viro <viro@zeniv.linux.org.uk>
Signed-off-by: default avatarJeff Garzik <jeff@garzik.org>
parent 3dd5f1d4
...@@ -233,6 +233,7 @@ slhc_compress(struct slcompress *comp, unsigned char *icp, int isize, ...@@ -233,6 +233,7 @@ slhc_compress(struct slcompress *comp, unsigned char *icp, int isize,
register unsigned char *cp = new_seq; register unsigned char *cp = new_seq;
struct iphdr *ip; struct iphdr *ip;
struct tcphdr *th, *oth; struct tcphdr *th, *oth;
__sum16 csum;
/* /*
...@@ -428,7 +429,7 @@ slhc_compress(struct slcompress *comp, unsigned char *icp, int isize, ...@@ -428,7 +429,7 @@ slhc_compress(struct slcompress *comp, unsigned char *icp, int isize,
/* Grab the cksum before we overwrite it below. Then update our /* Grab the cksum before we overwrite it below. Then update our
* state with this packet's header. * state with this packet's header.
*/ */
deltaA = ntohs(th->check); csum = th->check;
memcpy(&cs->cs_ip,ip,20); memcpy(&cs->cs_ip,ip,20);
memcpy(&cs->cs_tcp,th,20); memcpy(&cs->cs_tcp,th,20);
/* We want to use the original packet as our compressed packet. /* We want to use the original packet as our compressed packet.
...@@ -449,7 +450,8 @@ slhc_compress(struct slcompress *comp, unsigned char *icp, int isize, ...@@ -449,7 +450,8 @@ slhc_compress(struct slcompress *comp, unsigned char *icp, int isize,
*cpp = ocp; *cpp = ocp;
*cp++ = changes; *cp++ = changes;
} }
cp = put16(cp,(short)deltaA); /* Write TCP checksum */ *(__sum16 *)cp = csum;
cp += 2;
/* deltaS is now the size of the change section of the compressed header */ /* deltaS is now the size of the change section of the compressed header */
memcpy(cp,new_seq,deltaS); /* Write list of deltas */ memcpy(cp,new_seq,deltaS); /* Write list of deltas */
memcpy(cp+deltaS,icp+hlen,isize-hlen); memcpy(cp+deltaS,icp+hlen,isize-hlen);
...@@ -519,10 +521,8 @@ slhc_uncompress(struct slcompress *comp, unsigned char *icp, int isize) ...@@ -519,10 +521,8 @@ slhc_uncompress(struct slcompress *comp, unsigned char *icp, int isize)
thp = &cs->cs_tcp; thp = &cs->cs_tcp;
ip = &cs->cs_ip; ip = &cs->cs_ip;
if((x = pull16(&cp)) == -1) { /* Read the TCP checksum */ thp->check = *(__sum16 *)cp;
goto bad; cp += 2;
}
thp->check = htons(x);
thp->psh = (changes & TCP_PUSH_BIT) ? 1 : 0; thp->psh = (changes & TCP_PUSH_BIT) ? 1 : 0;
/* /*
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment