0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

Xilinx平台以太网接口(一)TCP/IP基础

C29F_xilinx_inc 来源:赛灵思 作者:赛灵思 2022-02-19 17:54 次阅读

本系列文章基于xilinx三速以太网IP进行学习介绍。

在完成以太网通信实验之前,必须要对以太网基础知识进行了解。时间充裕的可以看看《图解TCP/IP》作为扫盲。本文重点对以太网帧结构进行介绍。

一、以太网帧格式

以太网帧格式:

Xilinx平台以太网接口(一)TCP/IP基础

前导码(Preamble):8 字节,连续 7 个 8’h55 加 1 个 8’hd5,表示一个帧的开始,用于双方设备数据的同步。

目的 MAC 地址:6 字节,存放目的设备的物理地址,即 MAC 地址 ;

源 MAC 地址:6 字节,存放发送端设备的物理地址 ;

长度/类型:2 字节,小于1500为长度,大于则为类型,用于指定协议类型,常用的有 0800 表示 IP 协议,0806 表示 ARP 协议,8035 表示 RARP 协议 ;

数据:46 到 1500 字节,最少 46 字节,不足需要补全 46 字节,例如 IP 协议层就包含在数据 部分,包括其 IP 头及数据。

FCS:帧尾,4 字节,称为帧校验序列,采用 32 位 CRC 校验,对目的 MAC 地址字段到数据字段进行校验。

进一步扩展,以 UDP 协议为例,可以看到其结构如下,除了以太网首部的 14 字节,数据部 分包含 IP 首部,UDP 首部,应用数据共 46~1500 字节。

pYYBAGIQvvCAHqHSAABs23kCbJM852.jpg

基于FPGA的以太网通信基本都是UDP协议。

UDP协议:用户数据报协议,一种无连接的传输层协议,提供面向事务的简单不可靠信息传送服务。数据传输过程中延迟小、数据传输效率高。

二、UDP 协议的报头格式

Xilinx平台以太网接口(一)TCP/IP基础

UDP 报头由 4 个域组成,其中每个域各占用 2 个字节,具体如下:

① UDP 源端口

② 目标端口号

③ 数据报长度

④ 校验和

UDP 协议使用端口号为不同的应用保留其各自的数据传输通道。数据发送一方将 UDP 数据报通过源端口发送出去,而数据接收一方则通过目标端口接收数据。

数据报的长度是指包括报头和数据部分在内的总字节数。因为报头的长度是固定的,所以该 域主要被用来计算可变长度的数据部分(又称为数据负载)。数据报的最大长度根据操作环境的不同而各异。从理论上说,包含报头在内的数据报的最大长度为 65535 字节。不过,一些实际应用往往会限制数据报的大小,有时会降低到 8192 字节。

UDP 协议使用报头中的校验值来保证数据的安全。UDP校验和=(IP伪头部+(UDP首部+数据每两个字节拼接分别相加的和))。校验值首先在数据发送方通过特殊的算法计算得出,在传递到接收方之后,还需要再重新计算。如果某个数据报在传输过程中被第三方篡改或者由于线路噪音等原因受到损坏,发送和接收方的校验计算值将不会相符,由此 UDP 协议可以检测是否出错。虽然 UDP 提供有错误检测,但检测到错误时,错误校正,只是简单地把损坏的消息段扔掉,或者给应用程序提供警告信息。

三、PING功能

ICMP 是 TCP/IP 协议族的一个 IP 层子协议,包含在 IP 数据报里,用于 IP 主机、路由器之间传递控制消息。控制消息是指网络是否连通,主机是否可达等功能。其中 ping 功能采用回送请求和回答报文,回送请求报文类型为 8’h08,回答报文类型为 8’h00。

Xilinx平台以太网接口(一)TCP/IP基础

下一篇,我们将对基于FPGA的以太网通信系统架构进行介绍。

审核编辑:汤梓红

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 以太网
    +关注

    关注

    40

    文章

    5079

    浏览量

    166248
  • 接口
    +关注

    关注

    33

    文章

    7643

    浏览量

    148520
收藏 人收藏

    评论

    相关推荐

    车载以太网基础视频——应用层#车载以太网

    车载以太网
    北汇信息POLELINK
    发布于 :2023年09月22日 09:05:01

    车载以太网总线基础培训——传输层#车载以太网

    车载以太网
    北汇信息POLELINK
    发布于 :2023年09月21日 10:57:36

    车载以太网基础培训——网络层#车载以太网

    车载以太网
    北汇信息POLELINK
    发布于 :2023年09月20日 08:51:32

    车载以太网基础培训——车载以太网的链路层#车载以太网

    车载以太网
    北汇信息POLELINK
    发布于 :2023年09月19日 16:25:21

    车载以太网基础培训——物理层简介#车载以太网

    车载以太网
    北汇信息POLELINK
    发布于 :2023年09月18日 16:37:56

    车载以太网测试系统测试实例介绍#车载以太网

    车载以太网
    北汇信息POLELINK
    发布于 :2023年09月12日 17:27:48

    Vector的车载以太网总线接口卡VN5000系列快速入门#车载以太网

    车载以太网
    北汇信息POLELINK
    发布于 :2023年09月12日 11:19:23

    如何通过CubeMX来初始化以太网工程

    实验内容: 1.使用CubeMX初始化以太网工程,并实现TCP Echo Server的功能。 2.在前面工程的基础上,实现通过STM32F769的以太网
    发表于 09-11 07:56

    车载以太网测试系统组成#车载以太网

    车载以太网
    北汇信息POLELINK
    发布于 :2023年09月05日 16:47:18

    车载以太网接口卡VN5650开箱视频来啦!#车载以太网

    接口车载以太网
    北汇信息POLELINK
    发布于 :2023年09月04日 14:32:29

    车载以太网快速入门#车载以太网

    车载以太网
    北汇信息POLELINK
    发布于 :2023年09月01日 17:54:31

    Xilinx KU系列三速以太网IP核RGMII时序约束方法

    基于RGMII时序广泛应用于以太网通信中,基于Xilinx的三速以太网时序分析,不同的Xilinx系列方法不一样
    的头像 发表于 07-07 14:15 3403次阅读
    <b class='flag-5'>Xilinx</b> KU系列三速<b class='flag-5'>以太网</b><b class='flag-5'>IP</b>核RGMII时序约束方法

    以太网接口硬件知识

    以太网口是我们日常工程中常用的通信接口以太网接口有很多种,本文将对常用以太网接口进行科普介绍。
    发表于 06-25 15:56 3379次阅读
    <b class='flag-5'>以太网</b><b class='flag-5'>接口</b>硬件知识

    简谈基于FPGA的千兆以太网设计

    怎么样的呢?当然,像我们常用的以太网协议有TCP/IP,UDPTCP/IP和UDP相比,TCP/IP
    发表于 06-01 18:39

    rs485转tcp网关盒子怎么用(rs485协议转以太网tcp/ip

    /IP协议之间的通信,可以使用RS485转TCP网关盒子。本文将介绍如何使用RS485转TCP网关盒子进行RS485协议转以太网TCP/
    的头像 发表于 05-05 15:50 1885次阅读
    rs485转<b class='flag-5'>tcp</b>网关盒子怎么用(rs485协议转<b class='flag-5'>以太网</b><b class='flag-5'>tcp</b>/<b class='flag-5'>ip</b>)