UDP网口(1)概述

在这里插入图片描述

1.计算机网络知识在互联网中的应用

以在浏览器中输入淘宝网为例,介绍数据在互联网是如何传输的。我们将要发送的数据包称作A(无论经历了怎么的编码都叫做A)。1.在发送数据之前,主机应该有自己的MAC地址和IP地址才具备发送的条件,每一块网卡上都有一个唯一的MAC地址,IP地址使用DHCP动态主机配置协议统一管理。2.打开浏览器,输入淘宝网址(又称域名),在浏览器缓存中查找是否保存有这个域名对应的IP地址,如果没有。将采用DNS(域名解析协议)解析ip地址,具体过程为:网络客户端PC输入www.baidu.com问本地DNS服务器,该网址的ip地址是多少,本地服务器查看缓存列表,缓存中没有就去问根(13台)DNS服务器,根回复去问.com区域管理,.com回应,由163.com管理,由163.com服务器返回ip地址,完成域名解析。3.已知对端IP之后,此时由浏览器(应用层)打包http协议找到传输层的对应端口,传输层使用UDP、TCP之一打包到网络层(UDP面向报文主要用于高速数据的实时传输,TCP面向连接,区别于UDP最大的特点是在传输数据之前先要建立连接(这是数据之外的开销,就是常说的三次握手),传输结束后要结束连接(四次挥手),而UDP可能随时的发送报文)。此时A在主机中的网络层。4.互联网分三个区域,接入层(用户主机所在一级,或大或小的局域网),汇聚层(运营商管理的交互机与数据链路),核心网。A要通过自己所处的局域网必须经过该局域网的路由器(指的是实验室多台主机共用的那个路由器,或者家里的路由器),路由器去寻找接入层与汇聚层之间的交换机。那么此时A应该打包MAC头,到达数据链路层,此时数据在向前传输首先应该知道该路由器的MAC地址,用到了ARP地址解析协议(广播ARP报文),已知对端的ip地址,获取对端的MAC地址,已知对端MAC之后,A打包MAC头,在以太网中传输到路由器上。注:以太网中传输是用到MAC地址的,而以太网是局域网的组网协议(类似的协议还有WLAN!),也就是说对于发送端,MAC地址或者说以太网协议,仅在本地主机到那个直连的路由器之间应用。5.A到达路由器之后,将寻找最短路径(路由)找对端,将采用到RIP路由信息协议和OSFP开放式最短路径优先协议找下一跳的路径,当A到达核心网中时,由于AS域自治,可能还需使用AS之间的边界网关协议BGP,最终A到达淘宝服务器。6.淘宝服务器响应A的请求,返回数据将经历A来时经历的动作到达A。这种交互方式称之为C/S交互,常见的如访问网址;与之对应的另一种交互方式是P2P,例如微信聊天(发消息不去找服务器,而是找某个客户端)。
上述是计算机网络知识在互联网中的应用,涉及各种互联网中的设备与转发。根据冯诺依曼关于计算机架构的理论,具有中央处理器,存储器,输入输出设备,控制器的设备就是计算机,因此计算机网络知识适用于FPGA应用场景。基于不同网络设备实现不同应用的场景很多,TCP/IP协议架构十分庞杂,计算机网络知识很丰富。FPGA实现UDP网口通信系列文章将阐述FPGA与PC如何实现点对点通信。

2.认识FPGA实现UDP网口通信

FPGA实现UDP网口点对点通信,首先要讨论三个问题,第一,数据交互的双方都是FPGA(或PC)里面的谁(具体指哪一个协议)?通过解决这个问题,明白当前要建立的数据链路通道从哪里来到哪里去;第二,指明设备硬件的环境,例如,什么接口,什么芯片等,了解应用基于的硬件环境,搞清每一个硬件部分发挥的作用;第三,不同的硬件环境应该采用不同的技术方案,并且明确基于这样的数据链路和硬件环境创建什么样的应用。本节将回答第一个问题,下一节回答第二第三个问题。
OSI网络模型有七层,但更为人熟知的是五层网络模型。如下图所示左半部分,上层的协议对于下层协议而言只是一个“数据段”。以FPGA到PC上行数据为例,FPGA将用户数据(应用层数据)打包,添加传输层协议信息形成传输层数据,依次类推网络层数据和链路层数据(这几个步骤都是要FPGA完成的)。通过物理层传输到PC设备上,PC上边的接收流程对开发者不可见,或者说使用QT中的Socket开发无需关注底层数据,直接在传输层获取应用层数据即可。如图右半部分,这是一个TCP/IP协议簇的简要示意,下面关注在这个数据链路中到底要实现什么协议?在PC与FPGA连接的场景中,大多是通过网口下发设备运行所需数据,或者通过网口接收设备采集的数据,并不做网络应用,而是偏向于工业控制和数据采集,因此应用层通常是设备的数据,而不去实现某应用层协议。对于传输层通常是TCP和UDP两种,TCP使用单FPGA架构实现的案例很少,主要原因是协议复杂,硬件资源有限,即便实现可靠性和稳定性无法保证。可通过在FPGA内部搭建软核或者使用Soc实现TCP协议,但这种做法与其他的处理器相比不占优势,因此实际应用也不多见。在多数与PC相连用作数据采集的场景中,实现UDP协议能够传输数据即可。网络层将实现ip协议,这是因为UDP协议在ip数据包中打包。此外还可根据应用场景实现ARP协议和ping通信。ARP可以根据已知的对端的ip地址广播(指对端mac地址设置为广播地址)ARP请求报文,网络中所有设备收到ARP请求,匹配IP的设备将返回ARP应答包,以此告知自己的MAC地址。实现ARP协议的好处是,PC给FPGA发送数据,需要知道FPGA板卡的MAC地址,FPGA也需要知道PC的MAC地址,实现ARP协议,当切换不同的PC与FPGA通信时,FPGA可识别不同主机的MAC地址(否则需要在命令提示符对话框中使用arp -s命令手动绑定)。在链路层将按照以太网数据帧格式将网络层数据打包即可。
在这里插入图片描述

3.FPGA实现UDP网口通信的方案

实际上,任何设备实现计算机网络的某个功能就是要在对应的协议层实现相应的协议。FPGA实现UDP网口通信就是要在传输层实现UDP协议,在网络层实现IP(大部分都需要ARP协议),在物理层实现以太网协议,数据链路层没有什么协议。具体为在PHY层实现物理信号的传输和接收,如编码、解码、串行化、解串行化、介质连接管理等。数据链路层中的MAC(Media Access Control)子层负责帧封装和解封装,将上层协议的数据包封装成以太网帧,添加以太网头部和尾部(如源MAC地址、目标MAC地址、以太网类型字段等);负责帧校验和:计算和验证以太网帧的校验和(Frame Check Sequence,FCS);负责帧过滤:根据MAC地址过滤帧,只接收发给本设备的帧或广播帧;负责流量控制:实现流量控制机制(如基于IEEE 802.3x的流控)等。此外数据链路层的LLC(Logical Link Control)子层提供逻辑链路控制服务,使得上层协议能够通过一个统一的接口访问数据链路层。网络层的IP协议负责数据包的寻址和路由,处理IP头部生成和解析;ARP协议将IP地址映射为MAC地址,必要时发送ARP请求和处理ARP回复。UDP协议提供无连接、不可靠的传输服务,负责UDP头部的生成和解析。
对于实现计算机网络的设备,具体是设备中的哪些部分实现哪一层是无关紧要的,也正因为如此,形成了不同的方案,不同方案之间也有不同优缺点适用于不同的应用场景。此外,以太网方案现在用的最多的是千兆网口和万兆网口,本系列介绍不同的方案实现这两种接口。
方案一,使用FPGA组包实现MAC层及以上的层+外部的PHY芯片实现物理层。这种方案FPGA只需要按照与PHY芯片一致的通信接口,按照不同层的通信要求传输数据即可。这类通信接口常见的有RGMII、GMII等(二者都适配)千兆以太网口。这种方案灵活性高,可根据自己的需求定制满足特定场景需求,也不需要购买额外的IP核,成本相对较低。但需要对MAC层的协议和实现有深入的了解,相对的开发难度大,调试成本较高。
方案二,使用xilinx 三态以太网 IP核实现mac层+外部的phy芯片实现物理层。这种方案使用Xilinx提供的IP核已经经过验证,使用方便,降低了开发难度,开发效率会高,与此同时它依赖于IP核的功能,灵活性相对较低。
方案三,使用三态以太网IP核+PCS/PMA实现物理层(通过SFP与PC连接)它的有点是集成度高:通过IP核实现MAC和PCS/PMA层,简化了设计。高性能:可以支持更高的传输速率,通常用于千兆或万兆以太网通信。缺点:成本较高:需要额外购买PCS/PMA的IP核。硬件要求高:需要使用SFP模块进行光电转换,增加了硬件成本和复杂性。这种方案需要使用光电转换模块与PC的网卡相连,或者PC端配备相应的SFP光纤网卡或具备SFP接口的交换机。
方案四,使用10G Ethernet Subsystem IP核实现UDP通信的所有层与协议,进而实现万兆以太网通信。该方案同样需要PC端配备相应的SFP光纤网卡。

4.FPGA实现UDP网口文章安排

本文作为概述介绍要做的哪些事情以及相互之间的关系。方案一用两篇文章介绍,其篇名与链接是UDP网口(2)逻辑组包(上)、UDP网口(3)逻辑组包(下);随后在方案一的基础上做了一个应用,篇名与链接是UDP网口(4)ROM存储网口转发Qt显示;方案二篇名与链接是UDP网口(5)TEMAC IP核组包。方案三的代码开发工作已经完成,相关硬件在采购中,将在验证后第一时间发布。方案四的篇名与链接是UDP网口(6)10G subsystem Ethernet IP实现万兆以太网通信。

5.传送门

END

🔈文章原创,首发于CSDN论坛。
🔈欢迎点赞❤❤收藏⭐⭐打赏💴💴!
🔈欢迎评论区或私信指出错误❌,提出宝贵意见或疑问❓。


相关推荐

  1. 【网络】修改名字|网络设备|管理

    2024-07-21 03:44:02       54 阅读
  2. 【服务器】服务器的管理

    2024-07-21 03:44:02       57 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-21 03:44:02       60 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-21 03:44:02       63 阅读
  3. 在Django里面运行非项目文件

    2024-07-21 03:44:02       51 阅读
  4. Python语言-面向对象

    2024-07-21 03:44:02       62 阅读

热门阅读

  1. C++编程:实现一个跨平台安全的定时器Timer模块

    2024-07-21 03:44:02       21 阅读
  2. CSS中object-fit: cover;

    2024-07-21 03:44:02       20 阅读
  3. Git使用

    2024-07-21 03:44:02       20 阅读
  4. 推荐收藏!Python Flask 项目生产环境部署指南

    2024-07-21 03:44:02       22 阅读
  5. 对androidTestDebug 产物进行重新签名

    2024-07-21 03:44:02       17 阅读
  6. Hi6278

    Hi6278

    2024-07-21 03:44:02      22 阅读
  7. 安装archlinux

    2024-07-21 03:44:02       19 阅读
  8. 如何通过结构体来观察内存对齐和填充

    2024-07-21 03:44:02       20 阅读
  9. cd命令学习

    2024-07-21 03:44:02       20 阅读
  10. git rebase 和 git merge区别

    2024-07-21 03:44:02       19 阅读