背景
网卡使用的是sigmastar的SSD202D芯片,该芯片有两个网口,其中一个网口需要外部的phy,方案图如下:

那么两个网口的mac地址是怎么存储的呢?如果是存储在mac模块内的flash是最理想的,烧录一次后就跟硬件走,芯片出厂前厂家烧录到芯片内更好。然而并不是。查看资料和代码后知道芯片并不会存储,每次上电后需要写入到mac寄存器。厂家的文档可以印证:

意思是厂家提供一个脚本,开机进入系统后自动读取eth0的mac地址,+1后写到eth1去。
问题
本来我也是用厂家这个脚本的,直到测试提几个问题单才发现有缺陷:
- 通过dhcp获取ip地址,每次重启后ip地址都会变;
- 在路由上看设备会占用好几个ip;
- 用非ifconfig列表的ip地址也能访问网关;
这些问题现象看起来很诡异的,每次都怀疑是不是测试搞错了。专门花时间分析了一下网络相关,原因也慢慢知道了。通过厂家的脚本写mac地址的方案在我们项目这里有个问题,这个脚本在dhcp之后才被执行! 就是说开机启动后eth1拿的一个不可预知的mac地址(跟eth0同一个默认mac地址)通过dhcp获取到了ip地址,然后再通过脚本配置了一个新的mac地址,然后再dhcp一个新的ip地址,所以导致了上面这些问题。
解决
这个问题可以通过把设置mac地址的脚本提前来解决,脚本目录如下:

探讨了sigmastar SSD202D芯片双网口MAC地址管理的问题,包括使用脚本自动设置MAC地址带来的缺陷及解决方案,最终通过修改uboot源码确保MAC地址正确配置。
最低0.47元/天 解锁文章


被折叠的 条评论
为什么被折叠?



