xavier nx 平台 EQOS LAN端口连接异常问题调试2

free-jdx 2021-07-09 15:20:08 5339
1. 前言

承接上篇
https://www.ebaina.com/articles/140000012768

2. 测试脚本

pe_test.sh

#!/bin/bash

### ENV DEFINITION ###

SERVERIP_ETH0="10.0.0.36"

DATE=`date "+%Y%m%d_%H%M%S"`

LOGFILE=/root/pe_log/petest_log_$DATE.txt

### FUNCTION ###

count=1

function print_usage () {

        echo "ex.)  ./pe_test.sh continue"  2>&1
        echo "ex.)  ./pe_test.sh poweroff"  2>&1
        echo "ex.)  ./pe_test.sh reboot"  2>&1
}

function test_and_check_init () {
        ITEM=$1;
        COMMAND=$2;
        EXPECTED=$3;

        RESULT=`eval $COMMAND`;

        if [[ $RESULT == *$EXPECTED* ]]; then
                echo "[$count] $ITEM [OK]"  2>&1 | tee -a $LOGFILE;
        else
                DATE=`date "+%Y%m%d_%H%M%S"`
                echo "[$count] $ITEM [NG] date=$DATE" 2>&1 | tee -a $LOGFILE;

                echo "arg num=$#"  2>&1 | tee -a $LOGFILE;
                echo "ITEM=$1"  2>&1 | tee -a $LOGFILE;
                echo "COMMAND=$2"  2>&1  | tee -a $LOGFILE;
                echo "EXPECTED=$3"  2>&1 | tee -a $LOGFILE;
                echo "RESULT=$RESULT"  2>&1 | tee -a $LOGFILE;

                # if check error at init, exit test
                exit;
        fi

        count=$(expr $count + 1);
        echo ""  2>&1 | tee -a $LOGFILE;
}

function test_and_check () {
        ITEM=$1;
        COMMAND=$2;
        EXPECTED=$3;

        RESULT=`eval $COMMAND`;

        if [[ $RESULT == *$EXPECTED* ]]; then
                echo "[$count] $ITEM [OK]"  2>&1 | tee -a $LOGFILE;
        else
                DATE=`date "+%Y%m%d_%H%M%S"`
                echo "[$count] $ITEM [NG] date=$DATE" 2>&1 | tee -a $LOGFILE;

                echo "arg num=$#"  2>&1 | tee -a $LOGFILE;
                echo "ITEM=$1"  2>&1 | tee -a $LOGFILE;
                echo "COMMAND=$2"  2>&1  | tee -a $LOGFILE;
                echo "EXPECTED=$3"  2>&1 | tee -a $LOGFILE;
                echo "RESULT=$RESULT"  2>&1 | tee -a $LOGFILE;
        fi

        count=$(expr $count + 1);
        echo ""  2>&1 | tee -a $LOGFILE;
}

if [ $# -ne 1 ]; then
  print_usage;
  exit 1
fi

if [ $1 != "continue" ] && [ $1 != "poweroff" ] && [ $1 != "reboot" ]; then
  print_usage;
  exit 1
fi

if [ ! -e /root/pe_log ];then
  mkdir /root/pe_log
fi

sleep 10

echo "### INIT CHECK ### " 2>&1 | tee -a $LOGFILE;

test_and_check_init "VERSION" "uname -a" "4.9.140"

test_and_check_init "EQOS" "dmesg | grep eqos" "eqos 2490000.ether_qos eth0: Link is Up"

test_and_check_init "ifconfig eth0" "ifconfig -a" "eth0"

test_and_check_init "usb storage" "lsusb -t" "Mass Storage, Driver=usb-storage, 480M"
#test_and_check_init "usb storage" "lsusb -t ; sleep 1" "Mass Storage, Driver=usb-storage, 5000M"

sleep 3

echo "###  EXECUTE CONTINUOUS TEST ###" 2>&1 | tee -a $LOGFILE;

testnum=0

while :
do

DATE=`date "+%Y%m%d_%H%M%S"`
echo "## TEST:$testnum START DATE=$DATE ##" 2>&1 | tee -a $LOGFILE;

test_and_check "PING from eth0" "ping -I eth0 $SERVERIP_ETH0 -c 4 -i 0.2" "4 packets transmitted, 4 received, 0% packet loss,"

sleep 1

testnum=$(expr $testnum + 1);

if [ $1 == "continue" ];then
  echo ""
elif [ $1 == "poweroff" ];then
  poweroff -f
elif [ $1 == "reboot" ];then
  reboot -f
else
  echo "Not continue/poweroff/reboot : Unexpected err" 2>&1 | tee -a $LOGFILE;
  exit
fi

done
3. 使用最新版本jetpack测试

用jetpack4.5.1再次构建了环境,并确认它可以复现
复现频率约为1/422
复现过程如下

1. 从https://developer.nvidia.com/jetpack-sdk-451-archive下载NX DEVELOPER KIT的SD卡镜像
2. 提取jetson-nx-jp451-sd-card-image.zip并写入sd-blob。img到micro SDCard
3.使用SD Boot, Setup和login引导NX DEVELOPER KIT
4. 从GUI关闭Wifi和蓝牙
5. 从界面中将eth0 IPv4设置为10.0.0.77/8
6. HostPC通过Gbit Ether HUB连接到EVK,如下所示
NX DEVELOPER KIT <=> NETGEAR:GS-105E <=> HostPC
10.0.0.77/8                              10.0.0.36/8

7. 在NX DEVELOPER KIT中部署以下shell脚本、服务并设置自动化测试
/root/pe_test.sh
/lib/systemd/system/pe_test.service

8. 在USB插槽中插入一个USB记忆棒,以防你有意中断测试
当USB闪存驱动器被拔出或问题重现时,重新启动测试停止
9. 从UART控制台重新启动并开始持续测试。

复现后的情况几乎与jetpack4.4.1相同
“Link is Up”事件不会从内核引发,IP地址也不会被分配
这不是定制板设计的问题

4. 开启CONFIG_EQOS_DISABLE_EEE

jetpack4.4.1/4.5.1中没有默认设置CONFIG_EQOS_DISABLE_EEE。
如果想禁用EEE, CONFIG_EQOS_DISABLE_EEE应该是Y

# uname -a
Linux contec-desktop 4.9.201-tegra #1 SMP PREEMPT Fri Feb 19 08:42:04 PST 2021 aarch64 aarch64 aarch64 GNU/Linux

# zcat /proc/config.gz | grep EQOS
# CONFIG_EQOS_APE_HWDEP is not set
CONFIG_EQOS=y
# CONFIG_EQOS_DISABLE_EEE is not set
# CONFIG_DISABLE_EQOS_CTRL_TRISTATE is not set

用CONFIG_EQOS_DISABLE_EEE=y测试了的定制板,但是问题仍然发生了
还没有尝试过EVK,应该先试用NVIDIA的原始内核映像

5. 测试标准

启用CONFIG_EQOS_DISABLE_EEE将有助于增强这个问题

因为测试条件不同

这是在板运行中连续的ifconfig down/up测试(没有重新启动),PHY_AN连续发生了三天
但在避免重启测试中,即使使用CONFIG_EQOS_DISABLE_EEE=y,有时也没有发生PHY_AN

测试标准是连续重启两天,大约1500次开机,没有任何问题
与Jetson Nano相比,PHY_AN的错误率有明显的差异
而且,作为Gbit以太网的规范,自动协商不应该以如此高的错误率失败

6. 使用路由器连接

问题在下列配置中复现
中间加一个路由器

NX DEVELOPER KIT <=> NETGEAR:GS-105E <=> HostPC
10.0.0.77/8                              10.0.0.36/8

如果不想怀疑连接到路由器的其他节点和数据包的影响
认为最好是将节点直接连接在一起

7. 恢复正常状态

以下手动操作将恢复正常操作
注意,停机后需要等待大约5秒钟

ifconfig eth0 down

sleep 5

ifconfig eth0 up

这可能是因为自动协商序列将再次运行

声明:本文内容由易百纳平台入驻作者撰写,文章观点仅代表作者本人,不代表易百纳立场。如有内容侵权或者其他问题,请联系本站进行删除。
free-jdx
红包 94 4 评论 打赏
评论
0个
内容存在敏感词
手气红包
    易百纳技术社区暂无数据
相关专栏
置顶时间设置
结束时间
删除原因
  • 广告/SPAM
  • 恶意灌水
  • 违规内容
  • 文不对题
  • 重复发帖
打赏作者
易百纳技术社区
free-jdx
您的支持将鼓励我继续创作!
打赏金额:
¥1易百纳技术社区
¥5易百纳技术社区
¥10易百纳技术社区
¥50易百纳技术社区
¥100易百纳技术社区
支付方式:
微信支付
支付宝支付
易百纳技术社区微信支付
易百纳技术社区
打赏成功!

感谢您的打赏,如若您也想被打赏,可前往 发表专栏 哦~

举报反馈

举报类型

  • 内容涉黄/赌/毒
  • 内容侵权/抄袭
  • 政治相关
  • 涉嫌广告
  • 侮辱谩骂
  • 其他

详细说明

审核成功

发布时间设置
发布时间:
是否关联周任务-专栏模块

审核失败

失败原因
备注
拼手气红包 红包规则
祝福语
恭喜发财,大吉大利!
红包金额
红包最小金额不能低于5元
红包数量
红包数量范围10~50个
余额支付
当前余额:
可前往问答、专栏板块获取收益 去获取
取 消 确 定

小包子的红包

恭喜发财,大吉大利

已领取20/40,共1.6元 红包规则

    易百纳技术社区