rfc1071-校验和

参考 rfc1071

   (1)  Adjacent octets to be checksummed are paired to form 16-bit
        integers, and the 1's complement sum of these 16-bit integers is
        formed.
   (2)  To generate a checksum, the checksum field itself is cleared,
        the 16-bit 1's complement sum is computed over the octets
        concerned, and the 1's complement of this sum is placed in the
        checksum field.
   (3)  To check a checksum, the 1's complement sum is computed over the
        same set of octets, including the checksum field.  If the result
        is all 1 bits (-0 in 1's complement arithmetic), the check
        succeeds.

rfc提到校验和的计算有三个步骤: 

  1. 计算时16位对齐,1's complement 求和(并在最后取反后放进报文)
  2. 计算前校验和字段清空
  3. 校验结果应该是全1(取反后全是0)

但是具体什么是1's complement 求和,rfc中似乎并没有的说明,也只是带着提到了一点:

        On a 2's complement machine, the 1's complement sum must be
        computed by means of an "end around carry", i.e., any overflows
        from the most significant bits are added into the least
        significant bits. See the examples below.

这里参考 谢希仁的《计算机网路》和最后的rfc代码示例:

        1's complement 求和就是二进制求和后,最高位向最低为进位

所以最后的这个取反的过程是不算进 1's complement 求和的,要注意

紧接着,rfc 又提到一些性质:

(下面使用 +‘ 表示  1's complement 求和 , 使用一组 [A, B] 等字母组合表示一个:16位的2进制数,这里要和16进制的A-F区分开,A是高8位,B是低8位,代表的数字就是 A*256 + B)

1. 计算顺序可交换 

( [A,B] +' [C,D] +' ... +' [J,0] ) +' ( [0,K] +' ... +' [Y,Z] )

 这个就是加法的结合律,没什么

2.  字节序可换(结果也只改变顺序)

[B,A] +' [D,C] +' ... +' [Z,Y]

这里有点思维跳跃的,其实还好理解,比如 [A,B]+[C,D],如果AC有进位,根据反码和的要求,这个进位会传给BD, 同样,BD如果有进位就会传给AC;

字节交换顺序后 [B,A]+[D,C] 的进位方式仍然不变,仍然是BD进位给AC, AC进位给BD,所以最后的结果也只是存在一个字节之间的交换而已。

这里带来的好处就是,当我们收到一个报文时,虽然大端机器和小端机器取出 16 位数据的方式是不一样的,但是字节序可换的性质保证了计算结果并不会影响到,校验时得到的结果是否全是 1, 或者取反全是 0。

除此之外还有多个性质,暂时先不理解,先看一下代码:

    check_sum(uint16_t *addr, int count)
    {
       register long sum = 0;

        while( count > 1 )  {
           /*  This is the inner loop */
               sum += * (unsigned short) addr++;
               count -= 2;
       }

           /*  Add left-over byte, if any */
       if( count > 0 )
               sum += * (unsigned char *) addr;

           /*  Fold 32-bit sum to 16 bits */
       while (sum>>16)
           sum = (sum & 0xffff) + (sum >> 16);

       checksum = ~sum;
   }

因为这个check_sum 中包含了最后的取反,所以在校验端如果仍然是使用这个函数,那正确的结果就会是全零。

最后是奇偶的地方,我觉得还存在一点问题:

sum += * (unsigned char *) addr;

如果最后仍多了一个字节,那么按照在数据最后填充一个全0 的字节来理解的话, 在小端的cpu上 确实是这么写,但是大端cpu 似乎还要再左移8 位。参考谢希仁的《计算机网路》中udp校验的图来看,似乎确实是这样的。

RFC分类文档。计算机网络教学中涉及的部分RFC文档,全部为PDF格式。为了方便阅读和查找,在文件名中增加了分类标识,详见以下列表。 2003-10-20 17:17 3,909 rfc0768_UDP.pdf 2004-11-23 08:41 18,279 rfc0790_Const.pdf 2003-10-21 11:39 54,096 rfc0791_IP(1).pdf 2003-10-29 18:45 19,596 rfc0792_IP(2)_ICMP.pdf 2003-09-18 09:58 104,423 rfc0793_TCP(1).pdf 2004-11-23 08:41 27,250 rfc0820_Const.pdf 2003-09-25 08:54 70,703 rfc0821_SMTP.pdf 2003-09-25 14:45 65,954 rfc0822_MailFormat.pdf 2002-03-27 12:00 14,687 rfc0826_ARP.pdf 2003-09-23 16:05 22,861 rfc0854_TELNET.pdf 2004-11-23 08:42 30,605 rfc0870_Const.pdf 2003-11-04 09:45 16,949 rfc0896_Congest(3)_Nagle.pdf 2004-11-23 08:42 46,567 rfc0900_Const.pdf 2004-11-24 20:07 35,565 rfc0904_EGP.txt.pdf 2004-11-23 08:43 53,633 rfc0923_Const.pdf 2004-11-23 08:48 58,170 rfc0943_Const.pdf 2003-10-29 18:47 22,260 rfc0950_IP(3)_Subnet.pdf 2003-09-22 07:55 85,028 rfc0959_FTP.pdf 2004-11-23 08:51 69,146 rfc0960_Const.pdf 2003-09-18 09:52 14,018 rfc0973_DNS(Old).pdf 2004-11-23 08:57 90,057 rfc0990_Const.pdf 2003-09-18 09:44 74,992 rfc1034_DNS(1).pdf 2003-09-26 07:15 71,404 rfc1035_DNS(2).pdf 2002-03-27 12:00 34,025 rfc1071_ChkSum.pdf 2004-11-29 21:50 22,886 rfc1112_IGMPv1.pdf 2003-10-29 18:48 22,886 rfc1112_IP(4)_IGMP.pdf 2003-10-29 16:44 7,563 rfc1121_Poems.pdf 2003-10-29 18:10 160,932 rfc1122_Requirements(1).pdf 2003-10-29 18:11 134,198 rfc1123_Requirements(2).pdf 2002-03-27 12:00 71,764 rfc1144_PPP(1).pdf 2002-03-27 12:00 37,120 rfc1180_TCP_Tutor.pdf 2003-09-28 16:52 15,414 rfc1183_DNS(3).pdf 2003-09-18 09:50 53,137 rfc1323_TCP(2).pdf 2002-03-27 12:00 13,226 rfc1332_IPCP(1).pdf 2003-10-21 11:39 40,646 rfc1349_IP(5)_TOS.pdf 2002-03-27 12:00 25,289 rfc1577_IPATM(1).pdf 2002-03-27 12:00 62,705 rfc1661_PPP(2).pdf 2004-12-21 09:36 32,400 rfc1662_PPP(3).pdf 2003-10-20 17:51 269,481 rfc1700_Const.pdf 2003-11-11 16:36 11,801 rfc1723_RIP(1).pdf 2002-03-27 12:00 77,343 rfc1752_IPv6.pdf 2002-03-27 12:00 73,474 rfc1771_BGP4.pdf 2002-03-27 12:00 13,530 rfc1773_BGP4(Exp).pdf 2004-11-30 08:47 44,286 rfc1883_IPv6(1).pdf 2002-03-27 12:00 45,646 rfc1932_IPATM(3).pdf 2003-09-25 16:49 28,683 rfc1939_POP3.pdf 2003-10-27 07:34 16,420 rfc2018_TCP(3).pdf 2003-09-25 14:46 45,265 rfc2045_MIME(1).pdf 2003-09-25 14:48 64,973 rfc2046_MIME(2).pdf 2003-09-25 17:22 103,961 rfc2060_IMAP4.pdf 2003-10-29 16:29 3,766 rfc2119_Keywords.pdf 2012-06-11 21:37 62,073 rfc2131_DHCP(1).pdf 2004-11-23 09:04 62,073 rfc2131_DHCP.pdf 2002-03-27 12:00 8,459 rfc2153_PPP(3).pdf 2003-11-11 16:39 277,994 rfc2178_OSPF(1).pdf 2002-03-27 12:00 40,206 rfc2225_IPATM(2).pdf 2004-11-29 21:49 29,419 rfc2236_IGMPv2.pdf 2003-11-11 16:39 294,503 rfc2328_OSPF(2).pdf 2003-11-11 16:37 58,799 rfc2453_RIP(2).pdf 2004-11-30 08:46 47,382 rfc2460_IPv6(2).pdf 2003-10-21 11:40 31,341 rfc2474_IP(6)_IPv6.pdf 2003-11-03 16:03 38,666 rfc2481_Congest(1).pdf 2003-10-29 17:48 82,498 rfc2525_Problem.pdf 2003-10-27 07:34 20,578 rfc2581_TCP(4).pdf 2003-11-04 10:04 17,943 rfc2582_Congest(4)_NewReno.pdf 2003-09-18 08:35 550,558 rfc2616_HTTP1.1.pdf 2003-11-03 16:04 98,412 rfc3168_Congest(2).pdf 2003-10-20 17:40 3,590 rfc3232_Const.pdf 2002-05-07 12:00 16,151 rfc3241_IPCP(2).pdf 2003-10-29 14:54 69,600 rfc3300_Status.pdf 2004-11-29 21:45 68,321 rfc3376_IGMPv3.pdf 2003-10-29 16:26 22,562 rfc3390_TCP(5).pdf 2004-11-23 09:05 12,410 rfc3396_DHCP(2).pdf 2012-04-12 16:56 28,241 rfc5556_bridge(memo).pdf
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值