AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 669340
Accepted
PF4Public
PF4Public
Asked: 2015-02-18 07:59:06 +0800 CST2015-02-18 07:59:06 +0800 CST 2015-02-18 07:59:06 +0800 CST

使用 U-Boot 的 tftp 下载随机超时

  • 772

我有一个带有 TI OMAP SoC 的定制板。我正在尝试通过 U-Boot 的 tftp 从 linux 机器下载 uImage。它在几个超时(大多数尝试超时限制超过并且很少通过)失败,但在其他人上成功。然而,任何其他不涉及 U-Boot 的组合都是完美的。即使有问题的主板已经启动内核。比较网络设置(包括 sysctl)在运行 Linux 的服务机器之间没有显着差异。

进行了以下测试:

  • u-boot <-> i686-pae Linux
  • u-boot <-> i686-pae Linux kvm guest
  • u-boot <-> x86_64 windows 7

结果如下:

  1. u-boot <-> i686-pae Linux
使用 DaVinci-EMAC 设备
来自服务器 192.168.100.254 的 TFTP;我们的 IP 地址是 192.168.100.88
文件名“uImage”。
加载地址:0xc0700000
正在加载:############T ##############################T ### #######T ############
              #######T ######################################### ######T ##########
              #########################T ####################### ################
              ##########################T ##################### ################
              ###############################T ################# ################
    ################################################# ###############
              ########T ######################################## ################
              ##################
              11.7 KB/秒
完毕
传输的字节数 = 2418464(24e720 十六进制)

相应的流量转储可以在这里找到:http: //pastebin.com/hBBwe9bL

  1. u-boot <-> i686-pae Linux kvm guest
使用 DaVinci-EMAC 设备
来自服务器 192.168.100.112 的 TFTP;我们的 IP 地址是 192.168.100.88
文件名“uImage”。
加载地址:0xc0700000
正在加载:################################################ #################
################################################# ###############
################################################# ###############
################################################# ###############
################################################# ###############
################################################# ###############
################################################# ###############
          ##################
          795.9 KB/秒
完毕
传输的字节数 = 2418464(24e720 十六进制)

相应的流量转储可以在这里找到:http: //pastebin.com/ZXYdpmSe

  1. u-boot <-> x86_64 windows 7
使用 DaVinci-EMAC 设备
来自服务器 192.168.100.86 的 TFTP;我们的 IP 地址是 192.168.100.88
文件名“uImage”。
加载地址:0xc0700000
正在加载:################################################ #################
################################################# ###############
          ##################################
          173.8 KB/秒
完毕
传输的字节数 = 2418464(24e720 十六进制)

相应的流量转储可以在这里找到:http: //pastebin.com/UWFEZjTz

在这一点上,我不知道是什么导致 u-boot 超时,我也没有更多关于如何解决这个问题的线索。非常感谢任何帮助。

它当然与 U-Boot 网络堆栈有关,但我相信这是提出这个问题的正确地方。

我已经阅读了这篇文章: http: //www.denx.de/wiki/view/DULG/TFTPTimeout,但是那里描述的内容与我的情况无关,因为结果不依赖于中间的开关。

我已经尝试过的:tftpd/ tftpd-hpa; tftpblocksize=512; x86_64 linux内核(tftp服务器);将交换机端口设置更改为不是 aeg,而是显式full-双工;以及half-;添加/删除中间的开关;在发球机上更改 MTU;从源代码构建最新的 U-Boot;内变化的服务器IP地址/24;换sysctl网。内存设置;向 U-Boot 邮件列表发送消息,但没有得到回复;为 U-Boot MAC 制作静态 arp。

tftp
  • 2 2 个回答
  • 3549 Views

2 个回答

  • Voted
  1. Best Answer
    PF4Public
    2016-05-29T09:15:04+08:002016-05-29T09:15:04+08:00

    正如进一步的实验表明的那样,这种特殊情况下的问题是因为 u-boot 丢失传入的数据包与--- NetLoop timeout handler setand巧合--- NetLoop timeout,我认为这是由 u-boot 中的 mac 驱动程序实现或 u-boot 网络处理本身引起的。由于快速的数据包处理,上游 Cisco 交换机的高 pps 可能会导致此问题。

    从 Windows 主机成功传输的事实证明,选择的 tftp 实现的超时时间少于 u-boot 的超时时间,因此再次重新发送数据包,而这些数据包恰好在其时间限制内被 u-boot 捕获。

    测试还表明,#define TIMEOUT 8000UL在编译时或tftptimeout 1000运行时设置允许 tftp 服务器有足够的时间重新传输丢失的数据包,从而继续传输。这正是从 Windows 主机下载所观察到的。

    更多的测试表明,将上游交换机端口(不是同一个端口,面向有问题的板的 u-boot)设置为 10 Mbit/s 半双工可以解决传输问题,但这会显着降低可用带宽。

    • 0
  2. Pat
    2015-03-03T09:05:49+08:002015-03-03T09:05:49+08:00

    问题:

    1. 董事会投注能力肯定比主机对手慢得多。那么 TFTP 客户端在发送 ACK N 后可能会立即收到 Data Packet N+1,而此时板子可能还无法接收数据包(即没有全双工)

    2. 丢失数据包后,双方进入“等待超时”模式。

    要做的事情:

    1. 在非常轻的网络上尝试测试,甚至更好的背靠背连接
    2. 如果您的链接是 1Gb/100Mb,请尽可能慢一点。
    3. 尝试在“服务器端”设置较低的超时时间;这将迫使服务器在重新发送丢失的数据包之前等待更少的时间,这可能会避免客户端超时。
    4. 如果您有一个能够控制“数据包间延迟”的 TFTP 服务器,请使其更高。

    如果您仍然遇到问题,请尝试使用 Wireshark 捕获流量并分析超时流量序列

    • -1

相关问题

  • Debian 网络引导通过 PXE 所需文件

  • EFI pxe 网络启动错误

  • MAC OS X的TFTP服务器[关闭]

  • PXE Boot - Linux 服务器和 OpenBSD 客户端

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve