基于FPGA的UDP协议栈设计第六章_仲裁模块设计

2024-03-24 18:44

本文主要是介绍基于FPGA的UDP协议栈设计第六章_仲裁模块设计,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 前言:
  • 一、模块设计
    • 1、模块接口
    • 2、实现方式
  • 总结:

前言:

仲裁模块设计,解决当IP层同时收到UDP层和ICMP层数据以及MAC层同时收到ARP层和IP层数据时候的仲裁问题

一、模块设计

1、模块接口

设计代码为本人参考FPGA奇哥系列网课自行编写
端口A相较于端口B有更高的优先级

module Data_2to1_arbiter#(parameter       P_INTERVAL_LEN  = 10
)(input           i_clk               ,input           i_rst               ,input  [7 :0]   i_data_a            ,input           i_valid_a           ,input           i_last_a            ,input  [15:0]   i_len_a             ,input  [15:0]   i_type_a            ,input  [7 :0]   i_data_b            ,input           i_valid_b           ,input           i_last_b            ,input  [15:0]   i_len_b             ,input  [15:0]   i_type_b            ,output          o_nxt_frame_stop    ,output [7 :0]   o_data              ,output          o_valid             ,output          o_last              ,output [15:0]   o_len               ,output [15:0]   o_type               
);

2、实现方式

通过FIFO实现仲裁过程:
ARP报文和ICMP报文具有更高的优先级,因为他们往往很久才会传输一次。

FIFO_8x256 FIFO_8x256_port_a (.clk      (i_clk          ),   .din      (ri_data_a      ),   .wr_en    (ri_valid_a     ), .rd_en    (r_fifo_rden_a  ), .dout     (w_fifo_douta   ),  .full     (w_fifo_fulla   ),  .empty    (w_fifo_emptya  )  
);FIFO_32x16 FIFO_32x16_port_a (.clk      (i_clk                  ), .din      ({ri_type_a,ri_len_a}   ), .wr_en    (w_valid_a_pos          ), .rd_en    (w_fifo_rden_a_pos      ), .dout     (w_fifo_douta_type_len  ), .full     (), .empty    ()  
);FIFO_8x256 FIFO_8x256_port_b (.clk      (i_clk          ),   .din      (ri_data_b      ),   .wr_en    (ri_valid_b     ), .rd_en    (r_fifo_rden_b  ), .dout     (w_fifo_doutb   ),  .full     (w_fifo_fullb   ),  .empty    (w_fifo_emptyb  )  
);FIFO_32x16 FIFO_32x16_port_b (.clk      (i_clk                  ), .din      ({ri_type_b,ri_len_b}   ), .wr_en    (w_valid_b_pos          ), .rd_en    (w_fifo_rden_b_pos      ), .dout     (w_fifo_doutb_type_len  ), .full     (), .empty    ()  
);

一共有四个FIFO模块,分别用来存储端口A和端口B的数据和类型长度信息,输入的数据进入相应的FIFO当中,对应的类型和长度信息也存入FIFO,在if-else当中FIFO_a(存优先级高的报文,ICMP或ARP)的响应优先级更高,通过判断FIFO是否为空进行相应仲裁。

//每次发完数据仲裁信号归零,当仲裁信号为0时候才会响应下一次
always @(posedge i_clk or posedge i_rst)beginif(i_rst)r_arbiter <= 'd0;else if(ro_last)r_arbiter <= 'd0;else if(!w_fifo_emptya && r_arbiter == 0 && r_interval_cnt == P_INTERVAL_LEN)r_arbiter <= 'd1;else if(!w_fifo_emptyb && r_arbiter == 0 && r_interval_cnt == P_INTERVAL_LEN)r_arbiter <= 'd2;elser_arbiter <= r_arbiter;
end

总结:

完整代码参考GitHub:https://github.com/shun6-6/Tri_Eth_UDP_pro_stack

这篇关于基于FPGA的UDP协议栈设计第六章_仲裁模块设计的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Node.js net模块的使用示例

《Node.jsnet模块的使用示例》本文主要介绍了Node.jsnet模块的使用示例,net模块支持TCP通信,处理TCP连接和数据传输,具有一定的参考价值,感兴趣的可以了解一下... 目录简介引入 net 模块核心概念TCP (传输控制协议)Socket服务器TCP 服务器创建基本服务器服务器配置选项服

Qt 中集成mqtt协议的使用方法

《Qt中集成mqtt协议的使用方法》文章介绍了如何在工程中引入qmqtt库,并通过声明一个单例类来暴露订阅到的主题数据,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一,引入qmqtt 库二,使用一,引入qmqtt 库我是将整个头文件/源文件都添加到了工程中进行编译,这样 跨平台

Python利用自带模块实现屏幕像素高效操作

《Python利用自带模块实现屏幕像素高效操作》这篇文章主要为大家详细介绍了Python如何利用自带模块实现屏幕像素高效操作,文中的示例代码讲解详,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、获取屏幕放缩比例2、获取屏幕指定坐标处像素颜色3、一个简单的使用案例4、总结1、获取屏幕放缩比例from

nginx-rtmp-module模块实现视频点播的示例代码

《nginx-rtmp-module模块实现视频点播的示例代码》本文主要介绍了nginx-rtmp-module模块实现视频点播,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习... 目录预置条件Nginx点播基本配置点播远程文件指定多个播放位置参考预置条件配置点播服务器 192.

Python中的可视化设计与UI界面实现

《Python中的可视化设计与UI界面实现》本文介绍了如何使用Python创建用户界面(UI),包括使用Tkinter、PyQt、Kivy等库进行基本窗口、动态图表和动画效果的实现,通过示例代码,展示... 目录从像素到界面:python带你玩转UI设计示例:使用Tkinter创建一个简单的窗口绘图魔法:用

多模块的springboot项目发布指定模块的脚本方式

《多模块的springboot项目发布指定模块的脚本方式》该文章主要介绍了如何在多模块的SpringBoot项目中发布指定模块的脚本,作者原先的脚本会清理并编译所有模块,导致发布时间过长,通过简化脚本... 目录多模块的springboot项目发布指定模块的脚本1、不计成本地全部发布2、指定模块发布总结多模

Python中构建终端应用界面利器Blessed模块的使用

《Python中构建终端应用界面利器Blessed模块的使用》Blessed库作为一个轻量级且功能强大的解决方案,开始在开发者中赢得口碑,今天,我们就一起来探索一下它是如何让终端UI开发变得轻松而高... 目录一、安装与配置:简单、快速、无障碍二、基本功能:从彩色文本到动态交互1. 显示基本内容2. 创建链

Node.js 中 http 模块的深度剖析与实战应用小结

《Node.js中http模块的深度剖析与实战应用小结》本文详细介绍了Node.js中的http模块,从创建HTTP服务器、处理请求与响应,到获取请求参数,每个环节都通过代码示例进行解析,旨在帮... 目录Node.js 中 http 模块的深度剖析与实战应用一、引言二、创建 HTTP 服务器:基石搭建(一

Java如何接收并解析HL7协议数据

《Java如何接收并解析HL7协议数据》文章主要介绍了HL7协议及其在医疗行业中的应用,详细描述了如何配置环境、接收和解析数据,以及与前端进行交互的实现方法,文章还分享了使用7Edit工具进行调试的经... 目录一、前言二、正文1、环境配置2、数据接收:HL7Monitor3、数据解析:HL7Busines

python中的与时间相关的模块应用场景分析

《python中的与时间相关的模块应用场景分析》本文介绍了Python中与时间相关的几个重要模块:`time`、`datetime`、`calendar`、`timeit`、`pytz`和`dateu... 目录1. time 模块2. datetime 模块3. calendar 模块4. timeit