由于工作的平台也是嵌入式,差不多的平台,所以一直就没有把自己买过来的ok6410板子好好玩玩。以前一直都是sd卡去进行实验的。想着,如果和公司实验室里的开发平台一样的话,那多好啊,既方便,又快捷。磨刀不误砍柴工嘛,好的开发环境可以提高很多效率的。好了,下面开始讲讲怎么去实现的吧。下文很多是参考网上的资料的,很多是雷同,我只是记录自己的过程。

首先是tftp下载内核吧。网上也都说了,ok6410的uboot里面可恶的网卡驱动是cs8900的,而实际网卡是dm9000的,所以导致进入uboot后就没有办法用tftp来下载内核了。不过有人已经实现了这个功能。

下面分几个小标题,各个实现各个说明

一、uboot的修改编译

通过修改uboot可以实现,修改include/configs/smdk6410如下:

接着是drivers/dm9000x.c下了

好了,之后在下面几条命令就可以生成新的uboot了

[html] view plaincopy

 
  1. make clean
  2. make smdk6410_config
  3. make

二、uboot的下载

接着就是下载那个uboot了,用usb可以很快解决,还是贴一下下载过程吧,虽然文档有的,至于那个usb下载的驱动安装什么的,那就不多说了。

好了,现在假设都好了,出来下面这个图了。

1、把mmc.bin通过usb port下的transmit下载好,这里地址是0x57e00000。在下载的时候,要一直按空格键,要不然过了之后,就去起内核了。

2、接着进入U-boot命令行后,输入‘#dnw 50008000’,并回车

3、然后将U-boot映像文件下载到内存:点击DNW菜单“USBPort-->Transmit-->Transmit”

在弹出的文件浏览窗口中选择u-boot.bin。

4、擦除Nandflash,输入命令:

[html] view plaincopy

 
  1. #nand erase 0 100000 擦除Nandflash从0开始的1MB大小的区域。

5、将程序写入到Nandflash,输入命令:

[html] view plaincopy

 
  1. #nand write.uboot 50008000 0 100000

这样uboot就算下载成功了。

三、虚拟机安装tftp

[html] view plaincopy

 
  1. 1.  sudo apt-get install tftp-hpa tftpd-hpa
  2. 2 .  mkdir /tftproot
  3. chmod 777 tftproot
  4. 3.  sudo vim /etc/default/tftpd-hpa

修改如下

4.然后就可以启动这个服务了

[html] view plaincopy

 
  1. sudo service tftpd-hpa restart

5 检测 tftp

[html] view plaincopy

 
  1. 1)> echo hello world > ~/a.txt
  2. 2)> echo tftp test > /tftproot/b.txt
  3. 3)> cd ~
  4. 4)> sudo tftp 127.0.0.1
  5. 5)> tftp> put a.txt
  6. 6)> tftp> get b.txt
  7. 7)> tftp> q

看tftpboot目录下是否有相应的文件就可以判断了。

四、tftp下载内核

首先要准备好内核zImage,在kernel下面

[html] view plaincopy

 
  1. make zImage
  2. cp arch/arm/boot/zImage /tftpboot

准备内核之后,那边是要去下载了,拨码开关拨到nandflash启动,uboot是烧到nandflash中的,然后就是进入smdk6410的uboot了。

接着

[html] view plaincopy

 
  1. setenv bootcmd tftp 0xc0008000 zImage; bootm 0xc0008000
  2. saveenv

然后复位之后,就会通过tftp下载内核了。

五、虚拟机安装nfs

[html] view plaincopy

 
  1. #sudo apt-get install portmap
  2. #sudo apt-get install nfs-kernel-server
  3. #sudo vi /etc/exports

加上你的rootfs的路径

添加的内容意思是:允许 ip地址范围在192.168.5.*的计算机以读写的权限来访问/home/eastmoon/ok6410/rootfs目录,/home/eastmoon/ok6410/rootfs也称为服务器输出共享目录。具体要根据不同的环境来定。

然后就是启动服务了

1)

[html] view plaincopy

 
  1. #sudo exportfs -rv

使/etc/exports 文件生效

2)接着执行如下命令,启动端口映射:

[html] view plaincopy

 
  1. #/etc/init.d/portmap start(或:#sudo service portmap start)

3)最后启动 NFS服务,此时 NFS会激活守护进程,然后就开始监听 Client端的请求:

[html] view plaincopy

 
  1. #/etc/init.d/nfs-kernel-server restart (或: #sudo service nfs-kernel-server restart)

Linux 服务器端 NFS服务器的配置到此就已经配置好了。

六、nfs挂载文件系统

这也是最后一步了,至于文件系统嘛,买板子的时候,店家可定给了资料了,然后就是解压到那个你指定的目录下面的。我的是/home/eastmoon/ok6410/rootfs

[html] view plaincopy

 
  1. #sudo tar –zxf FORLINX_6410_yaffs2_v1.0.tgz就可以了。

然后就是要设置uboot的启动参数了

启动uboot,然后

[html] view plaincopy

 
  1. set bootargs root=/dev/nfs console=ttySAC0,115200
  2. nfsroot=192.168.5. 100:/home/eastmoon/ok6410/rootfs
  3. ip=192.168.5.150:192.168.5.100:192.168.5.1:255.255.255.0::eth0:off
  4. saveenv
  5. <</span>span style="font-size:18px;"><</span>span style="font-family:Times New Roman;font-size:14px;"></</span>span></</span>span>
[html] view plaincopy

 
  1. 192.168.5.100 pc端虚拟机的ip
  2. 192.168.5.150 开发板的ip
  3. 192.168.5.1 网关
  4. 255.255.255.0 子网掩码

然后配合刚才的tftp下载,接着复位下板子。然后就可以即通过tftp下载内核也可以nfs挂载文件系统了,之后的开发就方便多了。

终于写完了,心也静下来了,睡觉了,明天继续公司学习,晚上回来学习板子。以后陆续会把自己调通的驱动都写写博客和大家一起分享下。

转载]OK6410之tftp下载内核,nfs挂载文件系统全过程详解[转]的更多相关文章

  1. OK6410之tftp下载内核,nfs…

    原文地址:OK6410之tftp下载内核,nfs挂载文件系统全过程详解[转]作者:千山我独行 由于工作的平台也是嵌入式,差不多的平台,所以一直就没有把自己买过来的ok6410板子好好玩玩.以前一直都是 ...

  2. OK6410&nbsp;tftp下载内核、文件系…

    飞凌官方提供了一键下载烧写linux的方式,相对来说比较方便,但是对于开发来说不够灵活,因此这篇文章把tftp相关的点介绍一下,整理下其中遇到的一些问题. 一键烧写本质上是启动位于SD卡中的Uboot ...

  3. 文件系统管理 之 Linux 创建文件系统及挂载文件系统流程详解

    阅读此文,必须具备知识点:<Linux 查看磁盘分区.文件系统.使用情况的命令和相关工具介绍><实例解说 fdisk 使用方法><合理规划您的硬盘分区><Fe ...

  4. Linux 创建文件系统及挂载文件系统流程详解(转)

    作者:北南南北 来自: LinuxSir.Org 摘要:本文对新增硬盘,切割硬盘,创建硬盘分区,为硬盘分区创建文件系统,以及加载文件系统的流程做总结性论述:主要是为初学者弄清楚这一操作过程:本文涉及f ...

  5. 转 -- OK6410 tftp下载内核、文件系统以及nand flash地址相关整理、总结

    转载地址:http://emouse.cnblogs.com/ 飞凌官方提供了一键下载烧写linux的方式,相对来说比较方便,但是对于开发来说不够灵活,因此这篇文章把tftp相关的点介绍一下,整理下其 ...

  6. linux下使用NFS挂载文件系统

    转自linux如何使用NFS挂载文件系统 设备:一台服务器和一台客户端,这里我们把装在PC机上的RedHat作为服务器,而客户端则是嵌入式linux开发板. 环境:开发板已启动,连接好串口和网线,串口 ...

  7. ZT linux的mount(挂载)命令详解

    linux的mount(挂载)命令详解   来源:互联网 作者:佚名 时间:09-08 17:02:27 [大 中 小] 点评:linux下挂载(mount)光盘镜像文件.移动硬盘.U盘.Window ...

  8. linux-2.6.26内核中ARM中断实现详解(转)

    转载:http://www.cnblogs.com/leaven/archive/2010/08/06/1794293.html 更多文档参见:http://pan.baidu.com/s/1dDvJ ...

  9. [转载,感觉写的非常详细]DUBBO配置方式详解

    [转载,感觉写的非常详细]DUBBO配置方式详解 原文链接:http://www.cnblogs.com/chanshuyi/p/5144288.html DUBBO 是一个分布式服务框架,致力于提供 ...

随机推荐

  1. 02-19 k近邻算法(鸢尾花分类)

    [TOC] 更新.更全的<机器学习>的更新网站,更有python.go.数据结构与算法.爬虫.人工智能教学等着你:https://www.cnblogs.com/nickchen121/ ...

  2. 小游戏:200行python代码手写2048

    #-*- coding: utf-8 -*- import curses from random import randrange, choice from collections import de ...

  3. JDK1.7中HashMap死环问题及JDK1.8中对HashMap的优化源码详解

    一.JDK1.7中HashMap扩容死锁问题 我们首先来看一下JDK1.7中put方法的源码 我们打开addEntry方法如下,它会判断数组当前容量是否已经超过的阈值,例如假设当前的数组容量是16,加 ...

  4. java之ReentrantLock详解

    前言 如果一个代码块被synchronized修饰了,当一个线程获取了相应的锁,并执行该代码块时,其他线程便只能一直等待,等待获取锁的释放,现在有这么一种情况,这个获取锁的线程由于要等待IO或者其他原 ...

  5. PowerUp攻击模块实战

    PowerUp攻击模块实战   1.将PowerUp.ps1脚本上传至目标服务器,然后在本地执行 2.使用IEX在内存中加载此脚本,执行以下命令,脚本将进行所有的检查. powershell.exe ...

  6. Windows渗透测试中wmi的利用

    0x01 关于WMI WMI可以描述为一组管理Windows系统的方法和功能.我们可以把它当作API来与Windows系统进行相互交流.WMI在渗透测试中的价值在于它不需要下载和安装, 因为WMI是W ...

  7. web安全之php中常见的INI文件配置

    php.ini 在 PHP 启动时被读取.对于服务器模块版本的 PHP,仅在 web 服务器启动时读取 一次.对于 CGI 和 CLI 版本,每次调用都会读取. * Apache web 服务器在启动 ...

  8. CTF-SSH服务渗透

    环境 Kali ip 192.168.56.102 Smb 靶机ip 192.168.56.101 0x01信息探测 首页发现有类似用户名的信息 先记录下来 Martin N Hadi M Jimmy ...

  9. PHP array_slice

    1.函数的作用:返回数组中的部分区间的元素 2.函数的参数: @params  array  $array @params  int      $offset @params  int      $l ...

  10. LeetCode初级算法--树02:验证二叉搜索树

    LeetCode初级算法--树02:验证二叉搜索树 搜索微信公众号:'AI-ming3526'或者'计算机视觉这件小事' 获取更多算法.机器学习干货 csdn:https://blog.csdn.ne ...