-
问题描述
在工程中,需要在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等错误出现,怎么修改电路,尝试各种连接配置,都不能完全解决此问题; -
解决方法
最后尝试把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等错误出现;具体为什么,目前不知道原因;
-
后续测试问题发现
后续测试过程中,虽然例化为slave的sgmii接口虽然能够正常通信,使用带宽测试工具,也能够得到带宽统计数据,但是测试中,发现这些slave的接口依然会有丢包重传,数据传输过程中也时不时的会有link down & rxdisperr错误发生,从而导致丢包重传,从而带宽测试时,作为slave的sgmii接口的带宽怎么也没有作为master的sgmii接口带宽高。
查找问题很久,基本可以排除电路的问题,很是怀疑xilinx提供的sgmii ipcore有问题,不能使用级联的方式实现多个sgmii ipcore的例化。
sgmii ipcore link不成功调试经验
最新推荐文章于 2024-10-30 21:42:34 发布