BY Nan Zang
注意:本论坛博客所有内容皆来源于Xilinx工程师,如需转载,请写明出处作者及赛灵思论坛链接并发邮件至cncrc@xilinx.com,未经Xilinx及著作权人许可,禁止用作商业用途
Versal™ ACAP(自适应计算加速平台)是高度集成化的多核计算平台,可通过灵活的自适应能力来满足不断变化的动态算法的需求。VCK190 是赛灵思最早发布的 Versal AI Core 评估器件之一。
本篇博文将为您详解如下所述设计创建步骤:
Versal 上的 PS-GEM
千兆以太网 MAC (GEM) 可提供符合 IEEE 802.3-2016 标准的硬核 10/100/1000 Mbps 接口。
在 PS 低功耗域 (LPD) 中有 2 个 GEM 控制器。
每个控制器均独立运行,且各含 1 个管理数据输入/输出 (MDIO) 接口以供其外部 PHY 配合 RGMII 接口使用。
GEM 包含下列组件:
在无需 DMA 操作的系统应用中,可使用配置选项移除 DMA 模块,并且可使用外部 FIFO 接口将 GEM 集成到 SoC 环境中。
GEM 块包含以下信号接口:
I/O 选项包括:
注:Versal 中不支持内部 SERDES 接口 (SGMII)。在 MPSoC 器件中支持此类接口。
在 VCK190 器件上,GEM0 和 GEM1 均硬连线到板上的 2 个外部 RGMII PHY。
有 2 个 RJ45 端口,分别用于 GEM0 和 GEM1。如要测试 GEM1 RGMII 端口,请确保 GEM0 RGMII 端口同样通过电缆连接,因为此端口使用共享 MDIO 线(使用 GEM0 MDIO 作为主接口)。
请参阅以下 VCK190 截屏。在右上角有 2 个 RJ45 端口用于 Versal 以太网。
在 Vivado 中创建 IP integrator 设计
请下载随附的 Tcl 文件并遵循以下步骤进行操作。
注:单独使用“运行块自动化设置功能 (run block automation)”时,CIP 与 NoC 之间部分连接缺失。随附的 Tcl 文件可用于确保 CIP 和 NoC 中配置设置正确。
在 Vitis 中构建并运行 LwIP 应用
我们已构建了 IP integrator 设计并已导出了含器件镜像的硬件设计。现在,我们将在 Vitis 中创建 lwIP 示例,并在 VCK190 评估板上运行。
要切换到 GEM1 RJ45 以便进行测试,用户应使用 XPAR_XEMACPS_1_BASEADDR 修改 platform_config.h。
可在 BSP 的 xparameters.h 中找到以太网定义。
请参阅以下示例:在 platform_config.h 中,更改以下定义:
将此定义更新为:
#define PLATFORM_EMAC_BASEADDR XPAR_XEMACPS_1_BASEADDR
现在,您可重新构建应用并重新运行测试。
LwIP 性能
以下是 lwIP 响应服务器应用的 BSP 设置。
对于 lwIP TCP/UDP 性能服务器,默认将设置下列参数。
这些 lwIP 参数对于性能调优至关重要。
用户应参阅 lwIP 文档中的“配置内存选项”、“配置封装缓存 (Pbuf) 内存选项”和“TEMAC 适配器选项”部分,以了解有关各参数的更多信息。
https://china.xilinx.com/support/documentation/user_guides/ug1137-zynq-ultrascale-mpsoc-swdev.pdf
这些参数可控制所分配和使用的内存量以及 Pbuf 和描述符数量。
如果系统受到限制,无法处理这些包,则 BD 和 Pbuf 将被快速用尽,且无法根据要求快速清空以供使用。由此导致性能受到影响。
但我们还应平衡可使用的内存量,以便在用于性能基准测试的评估板上将这些参数调整为适合 1Gbps 的最优值。您可以此为参考,根据自己的要求来对这些参数进行调优。
只有注册用户才能在此添加评论。 如果您已经注册,请登录。 如果您还没有注册,请注册并登录。