问题
近期有小伙伴在使用ACZ702开发板尝试官方的lwip模板做实验时,出现自动协商失败或者Phy设置失败的问题
这个问题可以在bsp中关闭自动协商解决,但治标不治本,因此这里教大家如何一劳永逸的解决这个问题。
备注:使用lwip echo server模板时,关闭自动协商会出现Link up/down反复的Bug,要么根据本帖修改源码,要么更换其它模板关闭自协商。
原因
使用官方的lwip模板无法自动协商,是因为该模板默认使用Realtek的RTL8211E芯片,而ACZ702开发板上使用的网卡芯片是Realtek的RTL8211FDI芯片,由于两种芯片的PHYSR寄存器有差异,因此需要小小的修改一下
RTL8211E的PHYSR寄存器说明
RTL8211FDI的PHYSR寄存器说明
可以看出来两款芯片的PHYSR寄存器的地址和寄存器的位定义都不一样,因此需要在源码中修改这部分
解决方法
(1)打开工程下的bsp文件夹,找到xemacpsif_physpeed.c文件
(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”
(4)保存并编译,使用网线连接开发板和支持dhcp的路由器,然后下载测试程序,可见自动协商成功,dhcp成功,动态IP为192.168.6.199
(5)使用网线连接开发板和电脑,将电脑以太网口设置为10M全双工,静态ip为192.168.1.100,然后下载测试程序,可见自动协商成功,静态IP为192.168.1.10
(6)使用电脑端ping一下试试,也成功(记得关闭网络防火墙)
(7)使用网络调试助手测试回环功能,也没任何问题
永久修改
前面讲的方法只能修改当前工程,每次创建新的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文件
(2)按照前文中的修改方法来修改它,然后保存
(3)依据lwip模板创建一个新工程试试,果然新工程中的库已经被修改
扩展
经过上面修改后,已经可以正常使用以太网通信了,但笔者在使用的过程中还发现一些其他小问题:
1、以太网设置固定速率的时候,会频繁打印link up/link down
2、开发板网口与电脑端连接时,会出现绿灯不亮
3、网线先不插,等待自协商结束后,再插上会无反应
这里针对上面3个bug,在这里提供一些解决方法:
https://www.corecourse.cn/forum.php?mod=viewthread&tid=29789
详细操作文档