基于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

相关文章

Qt spdlog日志模块的使用详解

《Qtspdlog日志模块的使用详解》在Qt应用程序开发中,良好的日志系统至关重要,本文将介绍如何使用spdlog1.5.0创建满足以下要求的日志系统,感兴趣的朋友一起看看吧... 目录版本摘要例子logmanager.cpp文件main.cpp文件版本spdlog版本:1.5.0采用1.5.0版本主要

Nginx中配置HTTP/2协议的详细指南

《Nginx中配置HTTP/2协议的详细指南》HTTP/2是HTTP协议的下一代版本,旨在提高性能、减少延迟并优化现代网络环境中的通信效率,本文将为大家介绍Nginx配置HTTP/2协议想详细步骤,需... 目录一、HTTP/2 协议概述1.HTTP/22. HTTP/2 的核心特性3. HTTP/2 的优

关于WebSocket协议状态码解析

《关于WebSocket协议状态码解析》:本文主要介绍关于WebSocket协议状态码的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录WebSocket协议状态码解析1. 引言2. WebSocket协议状态码概述3. WebSocket协议状态码详解3

Python使用date模块进行日期处理的终极指南

《Python使用date模块进行日期处理的终极指南》在处理与时间相关的数据时,Python的date模块是开发者最趁手的工具之一,本文将用通俗的语言,结合真实案例,带您掌握date模块的六大核心功能... 目录引言一、date模块的核心功能1.1 日期表示1.2 日期计算1.3 日期比较二、六大常用方法详

python中time模块的常用方法及应用详解

《python中time模块的常用方法及应用详解》在Python开发中,时间处理是绕不开的刚需场景,从性能计时到定时任务,从日志记录到数据同步,时间模块始终是开发者最得力的工具之一,本文将通过真实案例... 目录一、时间基石:time.time()典型场景:程序性能分析进阶技巧:结合上下文管理器实现自动计时

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创建一个简单的窗口绘图魔法:用