FPGA千兆网系列2-----UDP发送与接收

该博客详细介绍了在FPGA中实现UDP发送与接收的步骤,包括开发环境、系统框图和具体代码实现。内容涵盖UDP包、ARP请求与应答的处理,以及如何通过网络调试助手进行测试。此外,还讨论了获取PC MAC地址的重要性,并提供了一个可用于数据传输的基础框架。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

开发环境

  • 小梅哥AC6102开发板(内含RTL8211E千兆以太网phy芯片)
  • quartus prime17.1
  • win10
  • 千兆网卡 这个需要电脑支持,不支持就玩不了了
  • udp协议介绍请参考我之前写的udp和arp
  • 本实例支持udp的发送与接收
  • 支持arp的发送和接收

系统框图

在这里插入图片描述

发送

本实例支持发送3种包

  • 发送udp包,s3_in是外部按键,按下时为低,松开为高。当s3_in被按下时,经过udp_debounce滤波,会输出一个udp_wr信号给generate_data模块,当udp_wr为低时,generate_data就会每隔1s产生1024个数据,并写入到wfifo中,当wfifo中的数据到达1024个时,也就是wfifo_wrusedw >= 1024时,auto_read_write模块就会产生一个udp_tx信号。然后通知eth_mac_send去发送一个udp包。
    auto_read_write产生udp_tx代码如下:
//tx_en
always  @(posedge clk or negedge rst_n)begin
    if(rst_n==1'b0)begin
        tx_en   <=  1'b0;
    end
    else if(wfifo_wrusedw >= 'd1024)begin
        tx_en   <=  1'b1;
    end
    else begin
        tx_en   <=  
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值