共2条
1/1 1 跳转至页
ZLG,IP ZLG_IP中校验和计算的小错误

问
if(length&0x01)//长度为奇数个时,要进行该操作
{
sum = sum + ((*check2)&0xff00);
}
这是ZLG_IP中UDP_BACK里的计算校验和程序里的一段代码,长度为奇数的时候执行到这里时check2已经指向最后一个字节的数据,在采用小端结构的计算机里,低字节在前,所以这时候应该是((*check2)&0x00ff);上位机接收到校验和不对的UDP帧就会悄悄丢掉,没有任何警告,所以这样的计算一旦发送奇数长的包就丢包,不知道周公是怎么调试这个程序的?
还有,在Udp.c里的计算校验和是
if(length&0x0001)//长度为奇数个时,要进行该操作
{
sum = sum + ((uint32)check[2*i]<<8);
}
这里利用以太网中和校验不关心字节的顺序来处理奇数帧,是正确的,为什么两个要分别处理? 答 1: 上位机对效验和不对的数据是否丢掉取决于上位机软件,如果软件没有效验CRC,照收不误 答 2: 如果双方协议不用效验CRC协议栈都可以省却这个产生CRC和效验CRC的开销 答 3: CRC是网卡芯片自动加上去的CRC是网卡芯片自动加上去的,自动校验的,不用软件处理,这里的校验是帧内部的和校验,如果发送端没有计算检验和而接收端检测到检验和有差错,那么U D P数据报就要被悄悄地丢弃。不产生任何差错报文(当I P层检测到I P首部检验和有差错时也这样做)。双方是可以协定是否进行校验,Host Requirements RFC声明,U D P检验和选项在默认条件下是打开的。它还声明,
如果发送端已经计算了检验和,那么接收端必须检验接收到的检验和(如接收到检验和不为0)。只是,许多系统没有遵守这一点,只是在出口检验和选项被打开时才验证接收到的检验和。
{
sum = sum + ((*check2)&0xff00);
}
这是ZLG_IP中UDP_BACK里的计算校验和程序里的一段代码,长度为奇数的时候执行到这里时check2已经指向最后一个字节的数据,在采用小端结构的计算机里,低字节在前,所以这时候应该是((*check2)&0x00ff);上位机接收到校验和不对的UDP帧就会悄悄丢掉,没有任何警告,所以这样的计算一旦发送奇数长的包就丢包,不知道周公是怎么调试这个程序的?
还有,在Udp.c里的计算校验和是
if(length&0x0001)//长度为奇数个时,要进行该操作
{
sum = sum + ((uint32)check[2*i]<<8);
}
这里利用以太网中和校验不关心字节的顺序来处理奇数帧,是正确的,为什么两个要分别处理? 答 1: 上位机对效验和不对的数据是否丢掉取决于上位机软件,如果软件没有效验CRC,照收不误 答 2: 如果双方协议不用效验CRC协议栈都可以省却这个产生CRC和效验CRC的开销 答 3: CRC是网卡芯片自动加上去的CRC是网卡芯片自动加上去的,自动校验的,不用软件处理,这里的校验是帧内部的和校验,如果发送端没有计算检验和而接收端检测到检验和有差错,那么U D P数据报就要被悄悄地丢弃。不产生任何差错报文(当I P层检测到I P首部检验和有差错时也这样做)。双方是可以协定是否进行校验,Host Requirements RFC声明,U D P检验和选项在默认条件下是打开的。它还声明,
如果发送端已经计算了检验和,那么接收端必须检验接收到的检验和(如接收到检验和不为0)。只是,许多系统没有遵守这一点,只是在出口检验和选项被打开时才验证接收到的检验和。
共2条
1/1 1 跳转至页
回复
打赏帖 | |
---|---|
汽车+汽车地线之间连接处理被打赏20分 | |
【Zephyr】使用Zephyr外设初始化过程解析被打赏30分 | |
【S32K146】S32DS watchdog 配置使用被打赏20分 | |
【Zephyr】使用 IAR 调试 Zephyr 镜像被打赏20分 | |
赚取电动螺丝刀+电源电路理论知识分享1被打赏5分 | |
我想要一部加热台+分享常见运算放大器电路的应用被打赏5分 | |
【Zephyr】MCXN947 Zephyr 开发入门适配shell被打赏20分 | |
我想要一部加热台+常见的MOS管驱动电路被打赏5分 | |
【我要开发板】6.联合MATLAB记录数据被打赏50分 | |
【换取手持数字示波器】MicrochipMPLABHarmony框架下串口调试printf输出记录被打赏29分 |