6 volatile u8_t uip_acc32[4];
8 void uip_add32 ( u8_t *op32, u16_t op16 ) {
9 * ( ( uint32_t * ) uip_acc32 ) =
10 htonl ( ntohl ( *( ( uint32_t * ) op32 ) ) + op16 );
13 #define BUF ((uip_tcpip_hdr *)&uip_buf[UIP_LLH_LEN])
14 #define IP_PROTO_TCP 6
16 u16_t uip_chksum(u16_t *sdata, u16_t len) {
19 for(acc = 0; len > 1; len -= 2) {
22 /* Overflow, so we add the carry to acc (i.e., increase by
29 /* add up any odd byte */
31 acc += htons(((u16_t)(*(u8_t *)sdata)) << 8);
32 if(acc < htons(((u16_t)(*(u8_t *)sdata)) << 8)) {
40 u16_t uip_ipchksum(void) {
41 return uip_chksum((u16_t *)&uip_buf[UIP_LLH_LEN], 20);
44 u16_t uip_tcpchksum(void) {
48 /* Compute the checksum of the TCP header. */
49 hsum = uip_chksum((u16_t *)&uip_buf[20 + UIP_LLH_LEN], 20);
51 /* Compute the checksum of the data in the TCP packet and add it to
52 the TCP header checksum. */
53 sum = uip_chksum((u16_t *)uip_appdata,
54 (u16_t)(((((u16_t)(BUF->len[0]) << 8) + BUF->len[1]) - 40)));
56 if((sum += hsum) < hsum) {
60 if((sum += BUF->srcipaddr[0]) < BUF->srcipaddr[0]) {
63 if((sum += BUF->srcipaddr[1]) < BUF->srcipaddr[1]) {
66 if((sum += BUF->destipaddr[0]) < BUF->destipaddr[0]) {
69 if((sum += BUF->destipaddr[1]) < BUF->destipaddr[1]) {
72 if((sum += (u16_t)htons((u16_t)IP_PROTO_TCP)) < (u16_t)htons((u16_t)IP_PROTO_TCP)) {
76 hsum = (u16_t)htons((((u16_t)(BUF->len[0]) << 8) + BUF->len[1]) - 20);
78 if((sum += hsum) < hsum) {