sgmii ipcore link不成功调试经验

在工程实践中,遇到使用Xilinx SGMII IP Core进行多接口数据传输时,部分接口无法正常工作,表现为AN失败和rxdisperr错误。禁用AN功能后,问题暂时缓解,但数据传输中仍有linkdown和rxdisperr错误。测试发现,使用外部时钟源的接口无问题,而使用内部时钟输出的接口存在问题。推测可能与SGMII IP Core的级联方式或时钟同步有关,但具体原因不明。初步怀疑是IP Core本身的问题,对级联应用的支持不足。

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

  1. 问题描述
    在工程中,需要在pl端例化多个sgmii ipcore用于网络接口数据传输,例化时,会使用bank中的例化的一个sgmii ipcore作为master,例化的其他sgmii ipcore作为slave,master使用输入差分clock作为refclk,slave使用master输出的gtrefclk作为其输入refclk;实际上板调试时,发现在不同板卡上 ,有些sgmii ipcore不能正常工作,AN不成功,通过ila抓sgmii ipcore status,发现时常有rxdisperr等错误出现,怎么修改电路,尝试各种连接配置,都不能完全解决此问题;

  2. 解决方法
    最后尝试把sgmii ipcore的AN功能去掉,再上板测试,未发现有rxdisperr的情况,而且各个板卡的sgmii接口都可以正常通信;问题暂时解决;

    后面继续测试,发现在有数据传输的过程中,依然会出现sgmii ipcore link down的问题,还有rxdisperr等错误出现,导致数据丢包重传;

    继续做测试,发现通过级联例化多个sgmii ipcore,使用外部输入的差分时钟对作为gtrefclk_in的sgmii接口,数据传输过程中不会出现问题,不会有link down/rxdisperr错误发生;但是使用上面的ip输出的单端gtrefclk_out作为输入参考时钟的sgmii ipcore,在数据传输过程中就会出问题,会有link down&rxdisperr等错误出现;具体为什么,目前不知道原因;

  3. 后续测试问题发现
    后续测试过程中,虽然例化为slave的sgmii接口虽然能够正常通信,使用带宽测试工具,也能够得到带宽统计数据,但是测试中,发现这些slave的接口依然会有丢包重传,数据传输过程中也时不时的会有link down & rxdisperr错误发生,从而导致丢包重传,从而带宽测试时,作为slave的sgmii接口的带宽怎么也没有作为master的sgmii接口带宽高。
    查找问题很久,基本可以排除电路的问题,很是怀疑xilinx提供的sgmii ipcore有问题,不能使用级联的方式实现多个sgmii ipcore的例化。

评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值