基于FPGA的万兆网调试

2023-12-29 21:48
文章标签 调试 fpga 万兆网

本文主要是介绍基于FPGA的万兆网调试,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、高速接口测试 用ibert
2、vivado2019.1无论如何修改片子,在例化ibert时都会报错,放弃vivado,在ise中ibert调试。
在这里插入图片描述
3、(1)
在这里插入图片描述
(2)
在这里插入图片描述
(3)
在这里插入图片描述
(4)
在这里插入图片描述
(5)
在这里插入图片描述
(6)等待生成完成后,关闭ISE.
4、打开chipscope,下载example_IBERT.bit.
5、在ibert console中可以修改属性,对gtx高速接口进行测试比如回环,眼图分析等,测试比较简单,不做过多介绍。
在这里插入图片描述
6、GTX测试,VIVADO新建GTX工程,选择 7 series FPGA Transceivers Wizard
(1)
在这里插入图片描述
(2)以为我要用万兆网,所以先速率选择10.3125G,选择正确的GTX收发器和时钟,此处正确选择后,约束文件中可直接用系统生成xdc。
在这里插入图片描述
(3)
在这里插入图片描述
(4)
在这里插入图片描述
(5)其他默认即可
(6)生成IP后,右键点击选择生成example design
(7)修改顶层,删除check后的结果指示信号。DRP接口需要时钟,例化一个时钟IP核,输出100M时钟,给DRP时钟引脚,添加一个外部按键信号,连接按键信号与数据生成模块的复位信号,功能就是当按键触发时,生成数据模块开始工作或者停止工作,方便观察信号。在生成数据和控制信号前加(* dont_touch=“true” *)防止信号被优化,其余不做更改。
(8)新建约束文件debug,并设置为目标文件,使以后的约束均在此文件中做修改。打开例程中的约束文件,添加DRP时钟来源的约束,增加按键信号的输入,删除check后的结果指示信号的约束,保存。
(9)综合,添加抓取信号,此处需要注意的是,start信号需要用自由时钟也就是上电就有的时钟去抓取,最好用drp的那个时钟去抓取,当值debug时,发生找不到时钟的问题。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
(10)生成bit,下载。
(11)外部环回光纤,发送端,通过gt0发送数据和COMMA码
在这里插入图片描述
(12)外部环回光纤,接收端,通过gt1接收数据和COMMA码
在这里插入图片描述
(13)GTX在工作10.3125时,也是正常的。

7、例化ten_gig_eth_pcs_pma的IP核,xilinx公司在10GBASE_R的模式下此IP是免费的,同时由于我的板子是K7,也仅仅支持此模式。xilinx 10的mac是收费的,由于是点对点传输数据,则可以不用mac中那么复杂的功能,仅仅接用物理通道,实现数据的收发即可,所以可以自行编写一个简单的mac。
8、简单mac仿真,模块gmii环回。
在这里插入图片描述
9、上板测试,光纤回环,也能正确收到数据
在这里插入图片描述

10、调试成功。

这篇关于基于FPGA的万兆网调试的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/550824

相关文章

前端bug调试的方法技巧及常见错误

《前端bug调试的方法技巧及常见错误》:本文主要介绍编程中常见的报错和Bug,以及调试的重要性,调试的基本流程是通过缩小范围来定位问题,并给出了推测法、删除代码法、console调试和debugg... 目录调试基本流程调试方法排查bug的两大技巧如何看控制台报错前端常见错误取值调用报错资源引入错误解析错误

使用C/C++调用libcurl调试消息的方式

《使用C/C++调用libcurl调试消息的方式》在使用C/C++调用libcurl进行HTTP请求时,有时我们需要查看请求的/应答消息的内容(包括请求头和请求体)以方便调试,libcurl提供了多种... 目录1. libcurl 调试工具简介2. 输出请求消息使用 CURLOPT_VERBOSE使用 C

C++中实现调试日志输出

《C++中实现调试日志输出》在C++编程中,调试日志对于定位问题和优化代码至关重要,本文将介绍几种常用的调试日志输出方法,并教你如何在日志中添加时间戳,希望对大家有所帮助... 目录1. 使用 #ifdef _DEBUG 宏2. 加入时间戳:精确到毫秒3.Windows 和 MFC 中的调试日志方法MFC

ASIO网络调试助手之一:简介

多年前,写过几篇《Boost.Asio C++网络编程》的学习文章,一直没机会实践。最近项目中用到了Asio,于是抽空写了个网络调试助手。 开发环境: Win10 Qt5.12.6 + Asio(standalone) + spdlog 支持协议: UDP + TCP Client + TCP Server 独立的Asio(http://www.think-async.com)只包含了头文件,不依

如何在Visual Studio中调试.NET源码

今天偶然在看别人代码时,发现在他的代码里使用了Any判断List<T>是否为空。 我一般的做法是先判断是否为null,再判断Count。 看了一下Count的源码如下: 1 [__DynamicallyInvokable]2 public int Count3 {4 [__DynamicallyInvokable]5 get

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能

vscode中文乱码问题,注释,终端,调试乱码一劳永逸版

忘记咋回事突然出现了乱码问题,很多方法都试了,注释乱码解决了,终端又乱码,调试窗口也乱码,最后经过本人不懈努力,终于全部解决了,现在分享给大家我的方法。 乱码的原因是各个地方用的编码格式不统一,所以把他们设成统一的utf8. 1.电脑的编码格式 开始-设置-时间和语言-语言和区域 管理语言设置-更改系统区域设置-勾选Bata版:使用utf8-确定-然后按指示重启 2.vscode

起点中文网防止网页调试的代码展示

起点中文网对爬虫非常敏感。如图,想在页面启用调试后会显示“已在调试程序中暂停”。 选择停用断点并继续运行后会造成cpu占用率升高电脑卡顿。 经简单分析网站使用了js代码用于防止调试并在强制继续运行后造成电脑卡顿,代码如下: function A(A, B) {if (null != B && "undefined" != typeof Symbol && B[Symbol.hasInstan

php 7之PhpStorm + Nginx + Xdebug运行调试

操作环境: windows PHP 7.1.10 PhpStorm-2017.2.4 Xdebug 2.5.4 Xdebug helper 1.6.1 nginx-1.12.2 注意查看端口占用情况 netstat -ano //查看所以端口netstat -aon|findstr "80" //查看指定端口占用情况 比如80端口查询情况 TCP 0.0.0.0:8