aboutsummaryrefslogtreecommitdiffstats
path: root/firmware/zpu/lib/net_common.c
diff options
context:
space:
mode:
authorJosh Blum <josh@joshknows.com>2011-03-16 12:34:27 -0700
committerJosh Blum <josh@joshknows.com>2011-03-16 12:34:27 -0700
commita49811fc3627f36e50bceeb0e92949ac7a58d400 (patch)
tree4b0102a5653d9d7b898ba58919c022ac04b9a807 /firmware/zpu/lib/net_common.c
parent3faf872dcdca4f57a3af8da6cd5f667cc1061245 (diff)
downloaduhd-a49811fc3627f36e50bceeb0e92949ac7a58d400.tar.gz
uhd-a49811fc3627f36e50bceeb0e92949ac7a58d400.tar.bz2
uhd-a49811fc3627f36e50bceeb0e92949ac7a58d400.zip
usrp2: cleanup checksum code and fix precompute checksum bug
Diffstat (limited to 'firmware/zpu/lib/net_common.c')
-rw-r--r--firmware/zpu/lib/net_common.c23
1 files changed, 9 insertions, 14 deletions
diff --git a/firmware/zpu/lib/net_common.c b/firmware/zpu/lib/net_common.c
index b7bcdcd89..2e3257b35 100644
--- a/firmware/zpu/lib/net_common.c
+++ b/firmware/zpu/lib/net_common.c
@@ -48,21 +48,16 @@ static const eth_mac_addr_t BCAST_MAC_ADDR = {{0xff, 0xff, 0xff, 0xff, 0xff, 0xf
uint16_t dsp0_dst_port, err0_dst_port, dsp1_dst_port;
/***********************************************************************
- * Checksum routines
+ * 16-bit one's complement sum
**********************************************************************/
-static unsigned int CHKSUM(unsigned int x, unsigned int *chksum){
- *chksum += x;
- *chksum = (*chksum & 0xffff) + (*chksum>>16);
- *chksum = (*chksum & 0xffff) + (*chksum>>16);
- return x;
-}
-
-static unsigned int chksum_buffer(
- unsigned short *buf, int nshorts,
- unsigned int initial_chksum
+static uint32_t chksum_buffer(
+ uint16_t *buf, size_t nshorts,
+ uint32_t initial_chksum
){
- unsigned int chksum = initial_chksum;
- for (int i = 0; i < nshorts; i++) CHKSUM(buf[i], &chksum);
+ uint32_t chksum = initial_chksum;
+ for (size_t i = 0; i < nshorts; i++) chksum += buf[i];
+
+ while (chksum >> 16) chksum = (chksum & 0xffff) + (chksum >> 16);
return chksum;
}
@@ -154,7 +149,7 @@ void setup_framer(
IPH_CHKSUM_SET(&frame.ip, 0);
frame.ip.src = sock_src.addr;
frame.ip.dest = sock_dst.addr;
- IPH_CHKSUM_SET(&frame.ip, ~chksum_buffer(
+ IPH_CHKSUM_SET(&frame.ip, chksum_buffer(
(unsigned short *) &frame.ip,
sizeof(frame.ip)/sizeof(short), 0
));