千兆以太网数据发送(二):IP、UDP检验和计算

我们设计的以太网整个发送链路如下图所示,在千兆以太网数据发送(一):心跳帧的组建中已经实现了timer模块和gen_frame_ctrl模块,得到UDP的基本帧结构,但是检验和、CRC等字段都给的0。本文将在此基础上计算出IP检验和以及UDP校验和,进一步完善以太网数据包。
以太网发送链路

一、IP校验和计算方式

以太网帧结构中需要进行IP校验的字段范围如下图。IP校验和的计算是将IP首部的20字节按照2字节进行分割,然后逐个相加。如果相加结果超过16'hffff,就把超出部分与低16位再次相加,直到最终结果小于16位的最大值为止。最后,将最终小于16位的结果取反作为IP校验和。校验和的高字节在前,低字节在后,将之前填充在以太网协议中的0进行替换即可。
IP检验和范围

由上文可知,20字节按照2字节进行分割后得到10个16bit字段,现在我们考虑一种极限情况,假设10个字段都为最大值16'ffff,那么想加后的值等于9FFF6,地16bit和9相加等于FFFF,没有超过FFFF。因此,我们最多只需要判断一次相加结果是否大于16'hffff,再将超出部分与低16位相加即可。

二、UDP校验和计算方式

以太网帧结构中需要进行UDP校验的字段范围如下图。UDP校验和的计算方式与IP校验和计算方式类似,特殊的是还需要加上IP伪首部,将IP伪首部、UDP 首部的 8 个 bytes 和数据按照2字节进行分割,然后逐个相加。
UDP检验和范围

由于本次构建的是心跳帧,数据部分都为16'h0000,因此即使在每个字段都取最大值16'hffff时,同样只需要判断一次相加结果是否大于16'hffff,再将超出部分与低16位相加。

三、模块实现

思路:模块输入的信号分为两路,一路存入ram中,一路进行IP check和UDP Check。当校验和计算完成后,开始从ram中读出数据,当读取到检验和位置时,用计算得到的校验值替换读出的值。

具体实现中,当校验和计算完成后拉高ram读使能信号,读出113个数据后拉低。ram读出的数据会延后使能信号一拍,再加上寄存器寄存一拍(实现对应校验和位置替换),所以本模块输出的数据有效信号check_en将延后ram读使能信号两拍。部分代码如下:

cpp 复制代码
//rd_ram_en
always @(posedge sclk) begin
    if (rst == 1'b1) begin
        rd_ram_en <= 1'b0;
    end
    else if (rd_ram_addr == 'd113 && rd_ram_en == 1'b1) begin
        rd_ram_en <= 1'b0;       
    end
    else if (tx_end_flag == 1'b1) begin
        rd_ram_en <= 1'b1;
    end
end


//check_data
always @(posedge sclk) begin
    if (rst == 1'b1) begin
        check_data <= 'd0;
    end
    else if (rd_ram_addr == 'd33 && rd_ram_en == 1'b1) begin
        check_data <= ip_check_sum[15:8];
    end
    else if (rd_ram_addr == 'd34 && rd_ram_en == 1'b1) begin
        check_data <= ip_check_sum[7:0];        
    end
    else if (rd_ram_addr == 'd49 && rd_ram_en == 1'b1) begin
        check_data <= udp_check_sum[15:8];
    end
    else if (rd_ram_addr == 'd50 && rd_ram_en == 1'b1) begin
        check_data <= udp_check_sum[7:0];        
    end
    else begin
        check_data <= rd_ram_data;
    end
end

四、仿真测试

在仿真波形中可以看到IP校验和为16'h79e8,UDP校验和为16'h3968,与手算结果一致。
仿真波形1

再观察最终模块输出的check_en和check_data[7:0]信号,可以看到对应校验和的位置已经被填充上计算出的值。
仿真波形1

相关推荐
国科安芯25 分钟前
抗辐照MCU芯片在激光雷达领域的适配性分析
网络·人工智能·单片机·嵌入式硬件·fpga开发
数字IC吗喽2 小时前
三、ILA逻辑分析仪抓取及查看波形
fpga开发
小无名呀3 小时前
socket_udp
linux·网络·c++·网络协议·计算机网络·udp
花阴偷移3 小时前
逆向基础--汇编基础(CS与IP) (05)
网络·汇编·网络协议·tcp/ip
天玺-vains4 小时前
借助Github Action实现通过 HTTP 请求触发邮件通知
网络协议·http·github
ZhengEnCi4 小时前
N2G-为什么90%的人不会计算子网掩码?大厂网络工程师的CIDR与子网掩码完全解析
网络协议
bnsarocket5 小时前
Verilog和FPGA的自学笔记8——按键消抖与模块化设计
笔记·fpga开发·verilog·自学·硬件编程
薛之谦_5 小时前
【SSL】什么是自签名证书及使用Java生成SSL自签名证书
java·网络协议·ssl
wit_yuan5 小时前
linux udp广播数据包实际用例
linux·服务器·udp
捷米研发三部5 小时前
EtherNet/IP转EtherNet/IP协议转换网关实现欧姆龙 PLC与罗克韦尔PLC通讯的配置案例
网络·网络协议