主题 : [转载]TFTP Unsupported option(s) requested 问题详细分析及解决 复制链接 | 浏览器收藏 | 打印
*無鈳取玳
级别: 论坛版主
UID: 27
精华: 12
发帖: 5398
金钱: 40120 两
威望: 17929 点
贡献值: 71 点
综合积分: 11036 分
注册时间: 2008-01-16
最后登录: 2014-11-22
楼主  发表于: 2009-11-15 22:09

 [转载]TFTP Unsupported option(s) requested 问题详细分析及解决

管理提醒: 本帖被 qq2440 从 Linux技术交流专区 移动到本区(2010-02-08)
原文由Apollo5520发表于风雨无阻博客http://blog.chinaunix.net/u3/105764/showart.php?id=2091464

【原】TFTP Unsupported option(s) requested 问题详细分析及解决
    昨天在移植u-boot-2009.08 到utu2440开发板时(移植文档在:http://blog.chinaunix.net/u3/105764/showart_2091132.html),出现“TFTP error: 'Unsupported option(s) requested (8)‘”,今天花时间详细跟踪了一下,具体原因及解决方案如下:

一、问题原因分析:
    1、下载与我操作系统版本(fedora 10)一致的tftp server源代码tftp-hpa-0.48.tar.bz2,编译通过后,替换系统的tftpd程序,通过在源代码中添加调试信息,发现是由于 Uboot 端 tftp 程序传过来的Timeout参数不符合服务器端定义引起的:


Nov 11 10:46:12 HardWare in.tftpd[18275]: client timeout = 7810 , server timeout = 1-255


    tftp客户端传过来的timeout是7810,而服务器端定义的范围在1-255秒之间,不是服务器的问题,而是uboot中tftp参数设置的问题。

二、解决方案

    可以有两种方式解决:

    1、修改服务器端源代码(此种方案修改较为繁琐,因为fedora 发行版中不包含tftp源代码,需要自己下载、编译、替换,所以不建议采用此方案)

    2、修改Uboot端tftp代码

    在U-boot 1.3.4源代码中定义的是5秒

#define TIMEOUT        5UL        /* Seconds to timeout for a lost pkt    */


    u-boot-2009.08 中定义如下

#define TIMEOUT        (CONFIG_SYS_HZ/1000*5000UL)


    TIMEOUT 的值是跟据板子配置文件中的 CONFIG_SYS_HZ 值计算出来的,我的配置文件时从 Uboot目录 include/configs/smdk2410.h 复制过来的,值为 1562500,算出来后就等于7810

    可以直接修改 uboot 目录 net/tftp.c 中 TIMEOUT 定义为5000(注意是5000而不是5,因为u-boot.2009.08版本该宏定义改为以毫秒为单位了)

#define TIMEOUT 5000UL  /*UBOOT 2009.08 定义为毫秒值*/

    另外还一种方法是修改开发板对应的配置文件 include/configs/utu2440.h(未详细测试此修改是否会影响Uboot其他功能,所以不建议采用此方案,有兴趣的兄弟姐妹可以详细测试一下,^_^)

#define    CONFIG_SYS_HZ            1000


    经过以上修改 Uboot tftp功能正常

U-Boot 2009.08 for utu2440 by Apollo5520 (http://Apollo5520.cublog.cn)

I2C: ready

DRAM: 64 MB

Flash: 0 kB

NAND: 64 MiB

Video: 240x320x16 20kHz 62Hz

In: serial

Out: serial

Err: serial

Net: CS8900A

Hit any key to stop autoboot: 0

utu2440 #

utu2440 # tftp 33008000 font.bin

TFTP from server 192.168.0.9; our IP address is 192.168.0.11

Filename 'font.bin'.

Load address: 0x33008000

Loading: ################################################################# ############

done

Bytes transferred = 1123240 (1123a8 hex)

utu2440 #
"If you have an apple and I have an apple and we exchange apples, then you and I will
still each have one apple. But if you have an idea and I have an idea and we exchange
these ideas, then each of us will have two ideas."