[网络] 网口大流量传输时插拔网线致网络不通

1、测试环境

硬件:NXP LS1046A ARM64平台 + 88E1548P

软件:linux 4.19.26 + linux 5.10.35

环境说明:88E1548P 是一个QSGMII 的 phy 芯片,LS1046A CPU 提供4个GMAC 与 88E1548P 连接,就是4个千兆网口。在我的板子上,该4个网口分别是eth5, eth6, eth7, eth8.

2、具体现象

  • eth7发包,速度600Mbps , 此时通过eth7 ping对端ip , 不断插拔eth7的网线,几分钟后会出现 无法ping通的情况。(eth7是QSGMII的一个port)

  • QSGMII 4个port 现象一样,都存在此问题。

  • eth7不通时,其余port正常通信

  • 不跑流量,暂未复现。

  • ifconfig eth7 down/up 软复位无法恢复

  • 对整个QSGMII芯片 硬复位,恢复。

  • 修改eth7 为100M/10M FULL 没有恢复,改为100M/10M HALF 恢复。

3、测试步骤

  • 执行命令 tcpreplay -i eth7 -l 2000 -M 600 udp.pcap 向对端发包

(注意修改udp.pcap 目的MAC地址)

  • 通过eth7 ping对端ip , 不断插拔eth7的网线,观察ping的情况

4、问题分析

(1) 遇到像网口不通这种问题,一般要先判断是MAC还是PHY出现了问题,一种简单的方法是复位,一般来说,复位谁可以恢复,大概率就是谁的问题。经过测试,只有下面第一种硬复位有效。看着出问题时phy 挂掉了。

(2)升级内核中的phy驱动,使用最新版本内核linux6.2中的marvell驱动,问题依然存在。

(3)可以通过 各种loopback来定位问题,出现问题时哪种loopback 不通了。一般有 utp 一端的loopback , QSGMII 一端的loopback,不过本次测试,当出现问题时,loopback是正常的,使用phy 发包,无论发给MAC侧还是发给网线对端一侧都是可以收到包的。这就有点奇怪,应该是QSGMII中的一个port 某一块逻辑死掉了。

(4) 查找芯片的勘误手册,看看是否是已知bug。此处注意,手册一定要准确的,应为marvell 88e1548 和 88e1548p 手册和勘误都是不同的,如果看错手册,bug可能就发现不了,我就是犯了这个低级错误,因为没有太关注具体的芯片信号,只是看原理图简单的记下型号,也不知道有两种芯片的区分。查了下区别:

手册上也是有区别的。

根据 MV-S302250-00_88E1548P_Release-Notes.pdf 7.3章节 发现88E1548P MACsec/PTP 功能有个bug 比较相近。经过测试,是它,是它,就是它!

在phy的驱动中,按照上述方式进行修改,测试正常了。

我们工程当中实际用不到这个功能,所以把这个功能禁掉了。测试正常。

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在STM32CubeIDE中使用STM32F407ZG来检测网口插拔网线的状态,您可以遵循以下步骤: 1. 配置GPIO引脚:首先,您需要选择一个GPIO引脚来连接到网口插拔检测引脚。使用STM32CubeIDE打开您的工程,进入"Pinout & Configuration"选项卡,选择合适的GPIO引脚,并将其配置为输入模式。 2. 编写代码:在代码中,您可以使用HAL库提供的GPIO读取功能来检测引脚状态。根据您选择的GPIO引脚,使用相应的HAL库函数读取引脚的状态。 示例代码如下: ```c // 在需要的地方包含相应的头文件 #include "stm32f4xx_hal.h" // 定义用于检测网线插拔的GPIO引脚 #define ETHERNET_CABLE_DETECT_PIN GPIO_PIN_0 #define ETHERNET_CABLE_DETECT_PORT GPIOA int main(void) { // 初始化HAL库 HAL_Init(); // 配置GPIO引脚为输入模式 GPIO_InitTypeDef GPIO_InitStruct; GPIO_InitStruct.Pin = ETHERNET_CABLE_DETECT_PIN; GPIO_InitStruct.Mode = GPIO_MODE_INPUT; GPIO_InitStruct.Pull = GPIO_PULLUP; // 可以根据需要选择上拉或下拉 HAL_GPIO_Init(ETHERNET_CABLE_DETECT_PORT, &GPIO_InitStruct); while (1) { // 读取引脚状态 uint8_t cable_status = HAL_GPIO_ReadPin(ETHERNET_CABLE_DETECT_PORT, ETHERNET_CABLE_DETECT_PIN); // 根据引脚状态执行相应的操作 if (cable_status == GPIO_PIN_SET) { // 网线已插入 // 执行相应的操作 } else { // 网线已拔出 // 执行相应的操作 } } } ``` 在上面的示例代码中,我们使用GPIOA的第0引脚来检测网线插拔状态。根据实际情况,您可能需要调整代码以适应您的硬件连接和需求。 3. 编译和烧录:完成代码编写后,使用STM32CubeIDE进行编译并将程序烧录到STM32F407ZG微控制器中。 请注意,以上代码示例仅提供了一种实现方法,并且可能需要根据您的具体硬件和要求进行调整。另外,确保正确连接网口并且具备正确的电气特性是非常重要的。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值