芯路恒电子技术论坛

 找回密码
 立即注册
热搜: 合集
查看: 9028|回复: 2

【Zynq】【Lwip】解决使用官方lwip模板时自动协商失败的问题

[复制链接]

该用户从未签到

68

主题

85

帖子

922

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
922
发表于 2022-9-8 18:11:34 | 显示全部楼层 |阅读模式

问题

近期有小伙伴在使用ACZ702开发板尝试官方的lwip模板做实验时,出现自动协商失败或者Phy设置失败的问题

image.png

这个问题可以在bsp中关闭自动协商解决,但治标不治本,因此这里教大家如何一劳永逸的解决这个问题。

备注:使用lwip echo server模板时,关闭自动协商会出现Link up/down反复的Bug,要么根据本帖修改源码,要么更换其它模板关闭自协商。

image.png

原因

使用官方的lwip模板无法自动协商,是因为该模板默认使用Realtek的RTL8211E芯片,而ACZ702开发板上使用的网卡芯片是Realtek的RTL8211FDI芯片,由于两种芯片的PHYSR寄存器有差异,因此需要小小的修改一下

RTL8211E的PHYSR寄存器说明

image.png

RTL8211FDI的PHYSR寄存器说明

image.png

可以看出来两款芯片的PHYSR寄存器的地址和寄存器的位定义都不一样,因此需要在源码中修改这部分

解决方法

(1)打开工程下的bsp文件夹,找到xemacpsif_physpeed.c文件

image.png

(2)在文件的头文件包含后面增加以下代码,重新定义寄存器地址以及掩码等数值

//此处为了兼容RTL8211FDI重定义寄存器地址和掩码
#undef IEEE_SPECIFIC_STATUS_REG
#undef IEEE_SPEED_MASK
#undef IEEE_SPEED_1000
#undef IEEE_SPEED_100

#define IEEE_SPECIFIC_STATUS_REG        0X1A
#define IEEE_SPEED_MASK                 0x30
#define IEEE_SPEED_1000                 0x20
#define IEEE_SPEED_100                  0x10

(3)找到文件里的get_Realtek_phy_speed函数,将下图所示位置由“0x400”修改为“0x4”

image.png

(4)保存并编译,使用网线连接开发板和支持dhcp的路由器,然后下载测试程序,可见自动协商成功,dhcp成功,动态IP为192.168.6.199

image.png

(5)使用网线连接开发板和电脑,将电脑以太网口设置为10M全双工,静态ip为192.168.1.100,然后下载测试程序,可见自动协商成功,静态IP为192.168.1.10

image.png

(6)使用电脑端ping一下试试,也成功(记得关闭网络防火墙)

image.png

(7)使用网络调试助手测试回环功能,也没任何问题

image.png

永久修改

前面讲的方法只能修改当前工程,每次创建新的lwip工程或者更新hdf重新生成BSP之后,都需要修改一次,实在是麻烦,因此这里提供一个一劳永逸的方法,直接修改SDK软件中的源文件(修改前一定要备份),修改之后再新建包含lwip202_v1_2的工程时,导入的就是修改后的文件(在此以前创建的工程仍需手动修改)

(1)找到Vivado安装目录下的Xilinx\SDK\2018.3\data\embeddedsw\ThirdParty\sw_services\lwip202_v1_2\src\contrib\ports\xilinx\netif路径下的xemacpsif_physpeed.c文件

image.png

(2)按照前文中的修改方法来修改它,然后保存

(3)依据lwip模板创建一个新工程试试,果然新工程中的库已经被修改

image.png

扩展

经过上面修改后,已经可以正常使用以太网通信了,但笔者在使用的过程中还发现一些其他小问题:

1、以太网设置固定速率的时候,会频繁打印link up/link down

2、开发板网口与电脑端连接时,会出现绿灯不亮

3、网线先不插,等待自协商结束后,再插上会无反应

这里针对上面3个bug,在这里提供一些解决方法: https://www.corecourse.cn/forum.php?mod=viewthread&tid=29789

详细操作文档

LwIP的官方模板使用.pdf

1.86 MB, 下载次数: 595

回复

使用道具 举报

该用户从未签到

70

主题

99

帖子

1505

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1505
发表于 2024-4-1 16:06:37 | 显示全部楼层
如果电脑无法ping通,需要通过cmd,检查是否出现了该项arp静态绑定
image.png
使用命令删除绑定
[C#] 纯文本查看 复制代码
arp -d 192.168.1.10

image.png

再次尝试ping,成功
image.png

回复 支持 反对

使用道具 举报

  • TA的每日心情
    慵懒
    2021-2-24 10:16
  • 427

    主题

    806

    帖子

    1万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    16080
    QQ
    发表于 2024-8-23 14:40:13 | 显示全部楼层
    实测,对于上述帖子内容,修改后在开启自动协商的情况下,确实能解决问题,但如果有需要一定是关闭自动协商,则还是会出现反复up和down的情况。

    参考github上的说明,对xadapter.c文件中第385行屏蔽,可以解决问题,让程序正常运行,但是也会导致无法自动检测up和down,存在小瑕疵。暂不影响使用。


    image.png

    image.png
    具体的根治方法,有待进一步研究。



    https://github.com/Xilinx/embeddedsw/issues/70
    回复 支持 反对

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|小黑屋|Archiver|芯路恒电子技术论坛 |鄂ICP备2021003648号

    GMT+8, 2024-11-1 07:59 , Processed in 0.124695 second(s), 37 queries .

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc. Template By 【未来科技】【 www.wekei.cn 】

    快速回复 返回顶部 返回列表