Skip to content

Latest commit

 

History

History
143 lines (75 loc) · 6.2 KB

README.md

File metadata and controls

143 lines (75 loc) · 6.2 KB

UDP and ARP Implementation

Warning: This code was written by the author while highly intoxicated, therefore it is rather messy, though functional. The author takes no responsibility for any issues within the code.

Features

The code includes the following functionalities:

  • ARP reception and response, as well as ARP request
  • UDP packet sending and reception
  • Generation and verification of UDP checksum

Note: The code is suitable for IPv4 only.

The Verilog file for the UDP interface can be found at: udp_18k/src/udp.sv

In the top-level file of this project, the IP address of the FPGA is set to 192.168.15.14.

This code will send received packets to the source port +1 of the source address.

Testing

udp_test.py includes a test case, which has been tested on Linux but not on Windows. For this test case, please set the local IP address to 192.168.15.15. Many abnormal terminations of the test case are due to the inability to open ports or the failure to timely listen to received packets. If necessary, please add a delay.

Interface and Compatibility

This code uses an RMII interface, and is only suitable for 100M Ethernet, not suitable for 10M Ethernet.

The serial management interface of this code is only suitable for RTL8201. It configures the CRS/CRS_DV pin as RXDV function, waits for the connection to be established, sets the phy_rdy bit (i.e., sets the ready interface), and then can start working. This logic could be modified for other PHY chips if needed.

This code is written in System Verilog and is not compatible with Verilog 2005.

Clock Generation and Usage

The code uses Gowin's PLL to generate a 1MHz clock and does not use any primitives apart from this.

Warranty and Issues

This code comes with no warranty, but if you encounter any bugs, please feel free to raise an issue.

Usage and Attribution

This code is free to use, but please retain the author information.

Author

LAKKA/JA_P_S

UDP 和 ARP 实现

**警告:**这段代码是作者在烂醉如泥的状态下编写的,因此可能显得混乱,但基本上功能是正常的。作者对代码中的任何问题不承担责任。

功能

这段代码包括以下功能:

  • ARP 接收和回复,以及 ARP 请求
  • UDP 包的发送和接收
  • UDP 校验和的生成和验证

注意: 该代码仅适用于 IPv4。

UDP 接口的 Verilog 文件可以在这里找到:udp_18k/src/udp.sv

在本项目的顶级文件中,FPGA 的 IP 地址设为 192.168.15.14

这段代码会将接收到的数据包发送到源地址的源端口 +1 的端口。

测试

udp_test.py 包含了一个测试用例,已在 Linux 上测试,但未在 Windows 上测试。对于这个测试用例,请将本地 IP 地址设置为 192.168.15.15。测试用例的异常结束很多来自于端口无法打开以及没有来得及监听到收到的包,如果需要的话,请增加延时。

接口和兼容性

这段代码使用 RMII 接口,仅适用于 100M 以太网,不适用于 10M 以太网。

这段代码的串行管理接口仅适用于 RTL8201。它将 CRS/CRS_DV 引脚配置为 RXDV 功能,等待连接建立后,设置 phy_rdy 位(即设置 ready 接口),然后可以开始工作。如果需要,可以修改此逻辑以用于其他 PHY 芯片。

这段代码使用 System Verilog 编写,不兼容于 Verilog 2005。

时钟生成和使用

这段代码使用 Gowin 的 PLL 生成一个 1MHz 的时钟,除此之外没有使用任何原语。

保修和问题

这段代码不提供任何保修,但如果你发现任何问题,请随时提出问题。

使用和归属

这段代码可以免费使用,但请保留作者信息。

作者

LAKKA/JA_P_S

UDPおよびARPの実装

警告: このコードは作者が泥酔状態で書かれましたので、非常に混乱していますが、基本的には機能します。作者はコード内の問題について一切の責任を負いません。

特徴

このコードには以下の機能が含まれています:

  • ARP受信と応答、およびARPリクエスト
  • UDPパケットの送信と受信
  • UDPチェックサムの生成と検証

注意: このコードはIPv4専用です。

UDPインターフェイスのVerilogファイルは、udp_18k/src/udp.svにあります。

このプロジェクトのトップレベルのファイルで、FPGAのIPアドレスは192.168.15.14に設定されています。

このコードは、受信したパケットを送信元アドレスの送信元ポート+1のポートに送信します。

テスト

udp_test.pyにはテストケースが含まれており、Linux上でテストされていますが、Windows上ではテストされていません。このテストケースを使用する場合は、ローカルIPアドレスを192.168.15.15に設定してください。テストケースの異常終了の多くは、ポートが開かれない、または受信したパケットをタイムリーにリッスンできないことに起因します。必要であれば、遅延を追加してください。

インターフェイスと互換性

このコードはRMIIインターフェイスを使用し、100M Ethernet専用であり、10M Ethernetには適していません。

このコードのシリアル管理インターフェイスはRTL8201専用です。これはCRS/CRS_DVピンをRXDV機能として設定し、接続が確立されるのを待ってからphy_rdyビットを設定(つまり、readyインターフェイスを設定)し、その後作業を開始します。必要であれば、このロジックは他のPHYチップに対して修正可能です。

このコードはSystem Verilogで記述されており、Verilog 2005とは互換性がありません。

クロック生成と使用

このコードはGowinのPLLを使用して1MHzのクロックを生成し、それ以外のプリミティブは使用していません。

保証と問題

このコードには保証はありませんが、バグを発見した場合は気軽に問題を提出してください。

使用と帰属

このコードは自由に使用することができますが、作者の情報を保持してください。

作者

LAKKA/JA_P_S