ALTERA千兆网IP核Triple-Speed Ethernet使用方法

2023-12-05 02:32

本文主要是介绍ALTERA千兆网IP核Triple-Speed Ethernet使用方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、实验实现功能

本文仅实现最简单的fpga向电脑主机发送hello world,UDP包,每隔一秒发送一次。上板跑通,可证明整条传输链路打通,对IP核的配置及使用是正确的。主要参考文献是altera官方的ug 01008"Triple-Speed Ethernet Intel FPGA IP User Guide".读者需对以太网OSI分层模型有基本的了解。需要知道物理层帧格式、IP层包格式以及UDP报文格式。这个在UG01008的附录内也有介绍。

二、数据流以及控制流

搭建nios片上系统,CPU c程序通过avalon_mm总线配置千兆网(即三速以太网(Triple-Speed Ethernet,TSE)IP核,配置完成后,拉起一个PIO寄存器的值,指示逻辑模块定时发送以太网帧(物理层)。

三、工程需注意点

工程结构如下图

tse_top例化三个模块。

1.frame_send是定时发送以太网帧的逻辑模块,通过avalon_streanm接口连接到qsys模块tse_qsys上。

2.tse_qsys为片上系统的顶层文件,内涵nios cpu,jtag_uart,onchip mem,tse ip核以及pio等组件。

3.pll为qsys和frame_send模块以及tse_top提供数个频率的时钟。

tse_top顶层模块

tse_top的输入输出口如下图

o_rgm_clk是rgmii接口时钟,本实验为125Mhz(TSE IP核配置为千兆模式,百兆模式下该时钟应为12.5MHz,十兆模式下应为1.25Mhz)

o_rgm_data是rgmii接口数据,位宽为4位,若ip核配置为gmii接口,则该信号为8位。rgmii接口下,ip核内例化了ddr时钟,上升沿和下降沿均可以采样数据,因而可以节省一半的数据引脚。

o_rgm_ctl是rgmii接口的控制信号,也是双沿传输的。上升沿传输发送使能,下降沿传输发送使能和发送错误的异或。

o_phy_clk_25m是发送给phy芯片的时钟,没有这个时钟,phy芯片不会工作的。

o_phy_rst_n是phy芯片的复位信号。上点后,phy芯片需要被复位。

tse_qsys模块

该模块是qsys的顶层模块。

搭建qsys系统时需要注意一下几点。

1.tse ip核内FIFO宽度设置为8bit较为方便。

2.时钟频率按照ug1008设置,即配置IP核的avalon_mm总线时钟50mhz,ip核接收逻辑端以太网帧的avalon stream总线频率100Mhz.

3.例化qsys顶层时,magic_sleep_n需设置1.ff_tx_crc_fwd需设置0.status_connection_set_10设0,status_connection_set_1000设1.

frame_send模块

该模块在nios配置完ip核后,开始定时发送以太网帧。

该模块需注意一下几点:

1.

图中,frame_length至少为64byte.

2.ff_tx_crc_fwd被设置为0后,ip核会自动为以太网帧添加FCS

3.ip核自动为帧添加preable和sfd

其他内容按照以太网帧格式生成即可。

四、c程序和实验运行流程

1.c程序按照ug1008 97页推荐配置IP核参数即可.

2.quartus内编译完工程后烧录进板子,打开wireshark设置好捕获规则,开始捕捉。然后eclipse内运行c程序,程序运行完后,逻辑模块即开始持续发送udp报文,电脑端wirehark内可捕获到来自板子的UDP报文。

这篇关于ALTERA千兆网IP核Triple-Speed Ethernet使用方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java 中的 @SneakyThrows 注解使用方法(简化异常处理的利与弊)

《Java中的@SneakyThrows注解使用方法(简化异常处理的利与弊)》为了简化异常处理,Lombok提供了一个强大的注解@SneakyThrows,本文将详细介绍@SneakyThro... 目录1. @SneakyThrows 简介 1.1 什么是 Lombok?2. @SneakyThrows

判断PyTorch是GPU版还是CPU版的方法小结

《判断PyTorch是GPU版还是CPU版的方法小结》PyTorch作为当前最流行的深度学习框架之一,支持在CPU和GPU(NVIDIACUDA)上运行,所以对于深度学习开发者来说,正确识别PyTor... 目录前言为什么需要区分GPU和CPU版本?性能差异硬件要求如何检查PyTorch版本?方法1:使用命

Qt实现网络数据解析的方法总结

《Qt实现网络数据解析的方法总结》在Qt中解析网络数据通常涉及接收原始字节流,并将其转换为有意义的应用层数据,这篇文章为大家介绍了详细步骤和示例,感兴趣的小伙伴可以了解下... 目录1. 网络数据接收2. 缓冲区管理(处理粘包/拆包)3. 常见数据格式解析3.1 jsON解析3.2 XML解析3.3 自定义

使用Python和Pyecharts创建交互式地图

《使用Python和Pyecharts创建交互式地图》在数据可视化领域,创建交互式地图是一种强大的方式,可以使受众能够以引人入胜且信息丰富的方式探索地理数据,下面我们看看如何使用Python和Pyec... 目录简介Pyecharts 简介创建上海地图代码说明运行结果总结简介在数据可视化领域,创建交互式地

SpringMVC 通过ajax 前后端数据交互的实现方法

《SpringMVC通过ajax前后端数据交互的实现方法》:本文主要介绍SpringMVC通过ajax前后端数据交互的实现方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价... 在前端的开发过程中,经常在html页面通过AJAX进行前后端数据的交互,SpringMVC的controll

Java中的工具类命名方法

《Java中的工具类命名方法》:本文主要介绍Java中的工具类究竟如何命名,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录Java中的工具类究竟如何命名?先来几个例子几种命名方式的比较到底如何命名 ?总结Java中的工具类究竟如何命名?先来几个例子JD

Java Stream流使用案例深入详解

《JavaStream流使用案例深入详解》:本文主要介绍JavaStream流使用案例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录前言1. Lambda1.1 语法1.2 没参数只有一条语句或者多条语句1.3 一个参数只有一条语句或者多

Spring Security自定义身份认证的实现方法

《SpringSecurity自定义身份认证的实现方法》:本文主要介绍SpringSecurity自定义身份认证的实现方法,下面对SpringSecurity的这三种自定义身份认证进行详细讲解,... 目录1.内存身份认证(1)创建配置类(2)验证内存身份认证2.JDBC身份认证(1)数据准备 (2)配置依

Java Spring 中 @PostConstruct 注解使用原理及常见场景

《JavaSpring中@PostConstruct注解使用原理及常见场景》在JavaSpring中,@PostConstruct注解是一个非常实用的功能,它允许开发者在Spring容器完全初... 目录一、@PostConstruct 注解概述二、@PostConstruct 注解的基本使用2.1 基本代

C#使用StackExchange.Redis实现分布式锁的两种方式介绍

《C#使用StackExchange.Redis实现分布式锁的两种方式介绍》分布式锁在集群的架构中发挥着重要的作用,:本文主要介绍C#使用StackExchange.Redis实现分布式锁的... 目录自定义分布式锁获取锁释放锁自动续期StackExchange.Redis分布式锁获取锁释放锁自动续期分布式