Fedora13 中 tftp配置

    技术2022-05-19  31

    TFTP需求背景

          在嵌入式linux开发中,交叉编译环境是必须的,那么如何把宿主机编译的结果放到目标机上面去运行呢?有很多种不同的方法可以实现,一种方法是在目标机ARM端挂载宿主机的网络文件系统,即NFS,这样就可以直接访问交叉编译的结果;但是在宿主机端编译的linux内核要想下载到arm端,必须通过tftp。

          回想下读书的时候,有很多原始的办法下载内核和编译的模块,内核都是通过串口终端从USB下载到内存中,烧写到flash,驱动模块和应用程序都是通过在linux下挂载U盘去运行,现在看来那时的调试手段还是很原始的。

           根据我在Fedora13上实践的情况,在一位高手的文章基础上修改。

    TFTP简单介绍

    TFTP是用来下载远程文件的最简单网络协议,它基于UDP协议而实现。嵌入式linux的tftp开发环境包括两个方面:一是嵌入式linux宿主机的 tftp-server支持,二是嵌入式linux目标机的tftp-client支持。因为u-boot本身内置支持tftp-client,所以嵌入式目标机就不用配置了。下面就详细介绍一下linux宿主机tftp-server的安装配置。TFTP开启步骤   (1)安装tftp-server

    yum install xinetd tftp tftp-server

             保持网络畅通,在root权限下,运行yum install tftp-server  即可安装tftp-server,这个过程会自动安装xinetd

       (2)修改文件         在linux 下,不管使用的是哪一种super-server,inetd或者xinetd,默认情况下TFTP服务是禁用的,所以要修改文件来开启服务。根据(1) 的安装方法,可以修改文件/etc/xinetd.d/tftp。主要是设置TFTP服务器的根目录,开启服务。修改后的文件如下:        service tftp        {             socket_type = dgram             protocol = udp             wait = yes             user = root             server = /usr/sbin/in.tftpd             server_args = -s /tftpboot  //建议设置在根目录下             disable = no             per_source = 11             cps = 100 2             flags = IPv4       }

     

    service tftp

          {

                disable = no

                socket_type = dgram

                protocol = udp

                wait = yes

                user = root

                server = /usr/sbin/in.tftpd

                server_args = -s /tftpboot -c

                per_source = 11

                cps = 100 2

                flags = IPv4

            }

    说明:修改项server_args= -s <path> -c,其中<path>处可以改为你的tftp-server的根目录,参数-s指定chroot。    (3)创建tftp根目录,启动tftp-server。 #mkdir /tftpboot #chmod o+w /tftpboot #service xinetd restart 这样,tftp-server就启动了。     (4)配置防火墙 TFTP (Trivial File Transfer Protocol),中译简单文件传输协议或小型文件传输协议. 大家一定记得在2003年8月12日全球爆发冲击波(Worm.Blaster)病毒,这种病毒会监听端口69,模拟出一个TFTP服务器,并启动一个攻 击传播线程,不断地随机生成攻击地址,进行入侵。另外tftp被认为是一种不安全的协议而将其关闭,同时也是防火墙打击的对象,这也是有道理的。tftp 在嵌入式linux还是有用武之地的。 打开防火墙,允许tftp访问网络。 运 行了system-config-securitylevel,发现有个设置SElinux强制,允许,禁止。把它设置成允许。这段要感谢MSN的朋友: http://windowzs.spaces.live.com/blog/cns!5413BC4DA2E8E5B9!122.entry     (5)然后就成功啦,进入minicom开发板操作      $tftp a0080000 led.bin   (FS-PXA255开发板)


    最新回复(0)