uip中 tcp 校验疑问?

[复制链接]
2173|1
 楼主| kaly_liu 发表于 2013-6-3 14:37 | 显示全部楼层 |阅读模式
ip, ui, TCP, AC, AD
根据查的资料TCP校验应该是 :TCP伪首部+TCP首部+数据
但是我在uip里面看程序视乎有点不理解?
  1. #include "uip.h"
  2. #include "uip_arch.h"

  3. #define BUF ((uip_tcpip_hdr *)&uip_buf[UIP_LLH_LEN])
  4. #define IP_PROTO_TCP    6

  5. /*-----------------------------------------------------------------------------------*/
  6. void
  7. uip_add32(u8_t *op32, u16_t op16)
  8. {
  9.   
  10.   uip_acc32[3] = op32[3] + (op16 & 0xff);
  11.   uip_acc32[2] = op32[2] + (op16 >> 8);
  12.   uip_acc32[1] = op32[1];
  13.   uip_acc32[0] = op32[0];
  14.   
  15.   if(uip_acc32[2] < (op16 >> 8)) {
  16.     ++uip_acc32[1];   
  17.     if(uip_acc32[1] == 0) {
  18.       ++uip_acc32[0];
  19.     }
  20.   }
  21.   
  22.   
  23.   if(uip_acc32[3] < (op16 & 0xff)) {
  24.     ++uip_acc32[2];  
  25.     if(uip_acc32[2] == 0) {
  26.       ++uip_acc32[1];   
  27.       if(uip_acc32[1] == 0) {
  28.         ++uip_acc32[0];
  29.       }
  30.     }
  31.   }
  32. }
  33. /*-----------------------------------------------------------------------------------*/
  34. u16_t
  35. uip_chksum(u16_t *sdata, u16_t len)
  36. {
  37.   u16_t acc;
  38.   
  39.   for(acc = 0; len > 1; len -= 2) {
  40.     acc += *sdata;
  41.     if(acc < *sdata) {
  42.       /* Overflow, so we add the carry to acc (i.e., increase by
  43.          one). */
  44.       ++acc;
  45.     }
  46.     ++sdata;
  47.   }

  48.   /* add up any odd byte */
  49.   if(len == 1) {
  50.     acc += htons(((u16_t)(*(u8_t *)sdata)) << 8);
  51.     if(acc < htons(((u16_t)(*(u8_t *)sdata)) << 8)) {
  52.       ++acc;
  53.     }
  54.   }

  55.   return acc;
  56. }
  57. /*-----------------------------------------------------------------------------------*/
  58. u16_t
  59. uip_ipchksum(void)
  60. {
  61.   return uip_chksum((u16_t *)&uip_buf[UIP_LLH_LEN], 20);
  62. }
  63. /*-----------------------------------------------------------------------------------*/
  64. u16_t
  65. uip_tcpchksum(void)
  66. {
  67.   u16_t hsum, sum;

  68.   
  69.   /* Compute the checksum of the TCP header. */
  70.   hsum = uip_chksum((u16_t *)&uip_buf[20 + UIP_LLH_LEN], 20);

  71.   /* Compute the checksum of the data in the TCP packet and add it to
  72.      the TCP header checksum. */
  73.   sum = uip_chksum((u16_t *)uip_appdata,
  74.                    (u16_t)(((((u16_t)(BUF->len[0]) << 8) + BUF->len[1]) - 40)));

  75.   if((sum += hsum) < hsum) {
  76.     ++sum;
  77.   }
  78.   
  79.   if((sum += BUF->srcipaddr[0]) < BUF->srcipaddr[0]) {
  80.     ++sum;
  81.   }
  82.   if((sum += BUF->srcipaddr[1]) < BUF->srcipaddr[1]) {
  83.     ++sum;
  84.   }
  85.   if((sum += BUF->destipaddr[0]) < BUF->destipaddr[0]) {
  86.     ++sum;
  87.   }
  88.   if((sum += BUF->destipaddr[1]) < BUF->destipaddr[1]) {
  89.     ++sum;
  90.   }
  91.   if((sum += (u16_t)htons((u16_t)IP_PROTO_TCP)) < (u16_t)htons((u16_t)IP_PROTO_TCP)) {
  92.     ++sum;
  93.   }

  94.   hsum = (u16_t)htons((((u16_t)(BUF->len[0]) << 8) + BUF->len[1]) - 20);
  95.   
  96.   if((sum += hsum) < hsum) {
  97.     ++sum;
  98.   }
  99.   
  100.   return sum;
  101. }
  102. /*-----------------------------------------------------------------------------------*/
我看里面的uip_chksum(u16_t *sdata, u16_t len)为什么那个len是  -2 呢?不是一个一个的?
758044068 发表于 2013-6-3 15:24 | 显示全部楼层
u16_t 是两个字节,是16位;所以len=20,每次2是正确的;最后一次减1是为了判断数据是否正好是16的倍数,否者补0.

评分

参与人数 1威望 +3 收起 理由
kaly_liu + 3 很给力!

查看全部评分

您需要登录后才可以回帖 登录 | 注册

本版积分规则

23

主题

344

帖子

3

粉丝
快速回复 在线客服 返回列表 返回顶部