Linux下rgmii接口与fpga相连,FPGA控制RGMII接口PHY芯片88E1512网络通信

一、前言

网络通信中的PHY芯片接口种类有很多,之前接触过GMII接口的PHY芯片RTL8211EG。但GMII接口数量较多,本文使用RGMII接口的88E1512搭建网络通信系统。这类接口总线位宽小,可以降低电路成本,在实际项目中应用更广泛。

二、从GMII过度到RGMII

先看看GMII和RGMII主要的接口。

GMII:

发送gmii_tx_clkgmii_tx_d[7:0]gmii_tx_engmii_tx_er

接收gmii_rx_clkgmii_rx_d[7:0]gmii_rx_dvgmii_rx_er

RGMII:

发送tx_clktx_d[3:0]tx_ctrl

接收rx_clkrx_d[3:0]rx_ctrl

44c2a819e45acebcf0824e661838df29.png

为什么接口变少了?首先数据总线从时钟单边沿采样8bit转变为了双边沿采样4bit,从88E1512Datasheet中时序图可以直观看出这一点。

f96b8ddced208217fadfdaf40cc747cb.png

RGMII中上升沿发送一字节数据的低四位,下降沿发送剩余的高四位数据。接收端时钟双边沿采样,因此125MHZ*8bit=125MHZ*4bit*2=1000Mbit/s。至于GMII中的数据有效和数据错误指示信号被ctrl信号复用:tx_ctrl在时钟tx_clk上升沿发送是tx_en,在下降沿发送是tx_en^tx_er。rx_ctrl在时钟rx_clk上升沿接收是rx_dv,在下降沿接收是rx_en^rx_er。综上,RGMII接口引脚数从25个降低到14个。

三、addclockskew

从上边的时序图分析,数据在时钟的边沿变化。因此如果不做额外处理,接收端无法稳定采样。为了解决这一问题,常见的做法是为时钟信号添加延时,使其边沿对准数据总线的稳定区间。可以在控制器端、PCB走线以及PHY芯片内部添加时钟偏移,本文使用最后一种方式实现。

8de29f170c3ae463f0d41f4a54b39c6e.png

在第三阶段中添加延迟。数据发送方向,FPGA侧的TX_CLK信号不需要额外处理,也就是说FPGA发送与数据边沿对齐的时钟信号。TXD和TX_CLK信号波形如图。

5bdbdd1e36ba5ea18808cbd29bd91d0d.png

PHY内部会调整TX_CLK,使之能够稳定采样TXD。数据接收方向,由于RX_CLK由PHY提供,PHY芯片直接产生与数据中心对齐的时钟信号。RXD和RX_CLK信号波形如图。

e2e970b369ed11efc4207ccf1660661b.png

可见,使PHY芯片工作在延迟模式下时,FPGA单不需要添加额外的逻辑来保证稳定采样。发送方向直接将数据驱动时钟作为TX_CLK信号发送,接收方向直接利用RX_CLK对RXD信号采样。

四、系统设计方案

本文使用ZYNQ内部的MAC控制器实现数据链路层功能。但由于其接口为GMII,需要用到GMII_to_RGMIIIPCore转换接口逻辑。上层网络协议则通过LWIP开源协议栈完成。首先配置ZYNQIP,使能ENET1并以EMIO方式引出。

6fec6d14aa43ec0b85a9ac49543dd627.png

系统硬件结构如图:

492e3d48f82d4488d9c08b25b40da826.png

在较高速设计场合下,输入输出接口部分很容易出现数据采样不稳定的现象。这时候就要通过Inputdelay,outputdelay约束以及STA来分析设计是否满足稳定采样需求。input/outputdelay是指数据相对于时钟的延迟,只有设置好上述两个数值,综合工具才会往正确的方向优化并给出合理的时序报告。

FPGA与RGMII接口的PHY芯片之间的时序关系按照数据接口同步和数据采样方式属于源同步DDR采样。inputdelay约束对应接收方向,时序关系是中心对齐。outputdelay约束对应发送方向,时序关系是边沿对齐。前者由于很多时候不知道上游器件Tcko信息,会使用示波器测量有效数据窗口来计算。而后者因为是边沿对齐,通过示波器测量抖动窗口并使用skewbasedmethod计算。这部分笔者还没有亲身实践过,若有误欢迎指出。

参考文献

1千兆以太网芯片88E1111RGMII模式的驱动-我心狂野-博客园

2RGMII布线指导RGMIILayoutGuide|无线时代

3RGMII_PHY测试笔记1基于开发板MiS603-X25-whilebreak-电子技术应用-AET-北大中文核心期刊-最丰富的电子设计资源平台

5RGMIIInterfacemingConsideraTIons|EthernetFMC

6ALTERAAN477:DesigningRGMIIInterfaceswithFPGAsandHardCopyASICs

7米联客ESFP1512以太网SFP光电卡教程

本文为csdn博主“FPGA技术江湖”原创文章,在此特别鸣谢。

原文链接:https://blog.csdn.net/qq_40310273/arTIcle/details/106355201

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/431324.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

面试题12:打印1到最大的n位数

题目描述 输入数字n&#xff0c;按顺序打印出1到最大的n位十进制数。比如输入3&#xff0c;则打印出1、2、3一直到最大的3位数即999。 题目分析 剑指Offer&#xff08;纪念版&#xff09;P94 代码实现 void Print1ToMaxOfNDigits_2(int n) {if(n < 0)return;char* number n…

tp3 普通模式url模式_[tp3.2.1]开启URL(重写模式),省略URL中的index.php

重写模式(省略url中的index.php)在apache配置文件httpd.conf中,查找1.mod_rewrite.so, 启动此模块2.AllowOverride , 值 All3. 把下面的内容保存为.htaccess文件放到应用入口文件的同级目录下Options FollowSymlinksRewriteEngine onRewriteCond %{REQUEST_FILENAME} !-dRewrit…

esxi usb插口_酷暑大作战 | USB-C风扇新体验

“枯藤老树昏鸦&#xff0c;空调 Wi-Fi 西瓜”每到炎热的夏天&#xff0c;人类的梦想就变得朴实、无华而简单但当我们吹不到空调时&#xff0c;如何还能享受阵阵清凉&#xff1f;今天我们介绍的两款新型电扇或许可以提供新思路&#xff1a;edon 循环电扇GUZI 挂颈电扇越来越多人…

删除linux内核多余架构,删除多余Linux内核方法

我使用的是Linux Mint&#xff0c;更新频繁&#xff0c;旧版本的Linux内核只会浪费硬盘空间&#xff0c;因此我会定期删除多余的内核。查看已安装所有内核&#xff1a;sudo dpkg --get-selections |grep linux-image查看当前正在使用的内核&#xff1a;uname -r删除不需要的内核…

数据库连接

http://www.cnblogs.com/JamyWong/archive/2009/06/03/1495499.html 转载于:https://www.cnblogs.com/wqy61/p/4835265.html

arduino 光控灯_Arduino光控开关

扩展实验&#xff0c;使用光敏电阻同样可以达到类似电位计调节LED亮度的效果&#xff0c;如实验电位计控制LED亮度&#xff1a;http://jingyan.baidu.com/article/49711c61785102fa441b7c81.html&#xff0c;只需要将代码修改如下为所示代码&#xff0c;并正确上传执行即可&…

手写tomcat socket closed_【消费电子】:重在阅读,新增手写 BOOX Nova Pro 体验评测...

此文出自于《消费电子》对BOOX Nova Pro的评测&#xff0c;本文已征得李强作者授权转载。【《消费电子》杂志社】越来越多的人选择在移动设备上阅读、学习&#xff0c;正所谓“需求诞生市场”&#xff0c;如今这类产品已经相当之丰富。越来越多的人选择在移动设备上阅读、学习&…

Linux fwrite 什么时候刷新,linux的fwrite()使用方法,当前时间写入文本的程序

1.函数功能用来读写一个数据块。2.一般调用形式fwrite(buffer,size,count,fp);3.说明(1)buffer&#xff1a;是一个指针&#xff0c;对fread来说&#xff0c;它是读入数据的存放地址。对fwrite来说&#xff0c;是要输出数据的地址。(2)size&#xff1a;要读写的字节数&#xff1…

BFS HDOJ 1242 Rescue

题目传送门 题意&#xff1a;从r走到a&#xff0c;遇到x多走一步&#xff0c;问最小走到a的步数 分析&#xff1a;因为r有多个&#xff0c;反过来想从a走到某个r的最小步数&#xff0c;简单的BFS。我对这题有特殊的感情&#xff0c;去年刚来集训队时肉鸽推荐了这题&#xff0c;…

mysql insert 不需要日志_详解MySQL|你不知道的新特性-8.0错误日志增强

MySQL 8.0 重新定义了错误日志输出和过滤&#xff0c;改善了原来臃肿并且可读性很差的错误日志。比如增加了 JSON 输出&#xff0c;在原来的日志后面以序号以及 JSON 后缀的方式展示。比如我机器上的 MySQL 以 JSON 保存的错误日志 mysqld.log.00.json&#xff1a;[rootcentos-…

idea中java文件怎么运行_Java入门基础篇-如何在Java中创建只读文件

本文选自千锋教育《Java语言程序设计》&#xff0c;如需转载请注明出处&#xff0c;谢谢&#xff01;1、如何创建只读文件要使文件只读&#xff0c;我们只要将文件属性更改为只读就行&#xff1b;可以使用File类的setReadOnly()方法来实现。它会返回一个布尔值&#xff0c;这样…

模仿JavaAppArguments.java示例

要求&#xff1a;编写一个程序&#xff0c;此程序从命令行接受多个数字&#xff0c;求和之后输出结果。 设计思想&#xff1a;命令行的参数都是字符串&#xff0c;需要定义一个整形数组将其转化为整数&#xff0c;然后实现数字的相加&#xff0c;最后输出结果。 程序流程图&…

showdoc windows 搭建_ShowDoc的搭建

其实&#xff0c;官方文档也说的很清楚了。主要贴一下我遇见的问题。环境&#xff1a;LNMP(LAMP没试过&#xff0c;有兴趣的同学可以试试&#xff0c;然后发出来)PHP5.3以上版本、php-mbstring模块、php-pdo模块、mysql数据库克隆或者下载代码&#xff1a;https://github.com/s…

2020年408真题_自考书院:2020年10月00830现代语言学真题

免费发布2020年10月全国统一命题《00830现代语言学》试卷其他真题&#xff1a;甘肃自考网 >> 历年试题 >>http://www.gseea.net点击历年真题查看更多真题和复习资料【互动交流平台】&#xff1a;交流QQ一群&#xff1a;35167222交流QQ二群&#xff1a;251822544自考…

linux优先级队列,Python3 线程优先级队列( Queue)

导读Python 的 Queue 模块中提供了同步的、线程安全的队列类&#xff0c;包括FIFO(先入先出)队列Queue&#xff0c;LIFO(后入先出)队列LifoQueue&#xff0c;和优先级队列 PriorityQueue。这些队列都实现了锁原语&#xff0c;能够在多线程中直接使用&#xff0c;可以使用队列来…

泛泰A860(高通公司8064 cpu 1080p) 拂4.4中国民营recovery TWRP2.7.1.2文本(通过刷第三版)...

专业第三方开发团队 VegaDevTeam &#xff08;本team 由 syhost suky zhaochengw(z大) xuefy(大星星) tenfar(R大师) loogeo crazyi(天下无雪) windxixi(雪狐) wangsai008 组成&#xff09; 说说中文TWRP的简史: 中文TWRP是本人在2012.10月在原英文TWRP的基础上首次改…

linux重启memcache_Linux下的Memcache安装方法

Linux下Memcache服务器端的安装服务器端主要是安装memcache服务器端&#xff0c;目前的最新版本是 memcached-1.3.0 。下载&#xff1a;http://www.danga.com/memcached/dist/memcached-1.2.2.tar.gz另外&#xff0c;Memcache用到了libevent这个库用于Socket的处理&#xff0c;…

电脑机箱cad图纸_如何批量打印高清黑白CAD图纸?这么好用的方法现在才知道

工作中为了更方便查看和传阅CAD图纸&#xff0c;经常要将CAD图纸打印出来&#xff0c;有时候要打印很多张&#xff0c;而且还不是最终定稿&#xff01;如果打印成彩印也太浪费墨水了&#xff01;所以批量打印黑白图纸的技巧就显得十分重要啦&#xff01;很多小伙伴们都不知道怎…

c语言链表编程作业,C语言编程入门——链表

链表是为克服数组的缺点&#xff0c;在内存空间中离散存储&#xff0c;但需要一个指针记住下一个结点的地址&#xff0c;以便可以将链表结点连接起来。链表与数组的比较&#xff1a;数组优点&#xff1a;存取速度快。缺点&#xff1a;插入和删除元素的效率很低&#xff1b;需要…

Codeforces Round #233 (Div. 2)D. Painting The Wall 概率DP

D. Painting The WallUser ainta decided to paint a wall. The wall consists of n2 tiles, that are arranged in an n  n table. Some tiles are painted, and the others are not. As he wants to paint it beautifully, he will follow the rules below. Firstly user a…