转载]OK6410之tftp下载内核,nfs挂载文件系统全过程详解[转]
由于工作的平台也是嵌入式,差不多的平台,所以一直就没有把自己买过来的ok6410板子好好玩玩。以前一直都是sd卡去进行实验的。想着,如果和公司实验室里的开发平台一样的话,那多好啊,既方便,又快捷。磨刀不误砍柴工嘛,好的开发环境可以提高很多效率的。好了,下面开始讲讲怎么去实现的吧。下文很多是参考网上的资料的,很多是雷同,我只是记录自己的过程。
首先是tftp下载内核吧。网上也都说了,ok6410的uboot里面可恶的网卡驱动是cs8900的,而实际网卡是dm9000的,所以导致进入uboot后就没有办法用tftp来下载内核了。不过有人已经实现了这个功能。
下面分几个小标题,各个实现各个说明
一、uboot的修改编译
通过修改uboot可以实现,修改include/configs/smdk6410如下:

接着是drivers/dm9000x.c下了

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

- make clean
- make smdk6410_config
- 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,输入命令:
- #nand erase 0 100000 擦除Nandflash从0开始的1MB大小的区域。
5、将程序写入到Nandflash,输入命令:
- #nand write.uboot 50008000 0 100000
这样uboot就算下载成功了。
三、虚拟机安装tftp
- 1. sudo apt-get install tftp-hpa tftpd-hpa
- 2 . mkdir /tftproot
- chmod 777 tftproot
- 3. sudo vim /etc/default/tftpd-hpa
修改如下

4.然后就可以启动这个服务了
- sudo service tftpd-hpa restart
5 检测 tftp
- 1)> echo hello world > ~/a.txt
- 2)> echo tftp test > /tftproot/b.txt
- 3)> cd ~
- 4)> sudo tftp 127.0.0.1
- 5)> tftp> put a.txt
- 6)> tftp> get b.txt
- 7)> tftp> q
看tftpboot目录下是否有相应的文件就可以判断了。
四、tftp下载内核
首先要准备好内核zImage,在kernel下面
- make zImage
- cp arch/arm/boot/zImage /tftpboot
准备内核之后,那边是要去下载了,拨码开关拨到nandflash启动,uboot是烧到nandflash中的,然后就是进入smdk6410的uboot了。
接着
- setenv bootcmd tftp 0xc0008000 zImage; bootm 0xc0008000
- saveenv
然后复位之后,就会通过tftp下载内核了。
五、虚拟机安装nfs
- #sudo apt-get install portmap
- #sudo apt-get install nfs-kernel-server
- #sudo vi /etc/exports
加上你的rootfs的路径

添加的内容意思是:允许 ip地址范围在192.168.5.*的计算机以读写的权限来访问/home/eastmoon/ok6410/rootfs目录,/home/eastmoon/ok6410/rootfs也称为服务器输出共享目录。具体要根据不同的环境来定。
然后就是启动服务了
1)
- #sudo exportfs -rv
使/etc/exports 文件生效
2)接着执行如下命令,启动端口映射:
- #/etc/init.d/portmap start(或:#sudo service portmap start)
3)最后启动 NFS服务,此时 NFS会激活守护进程,然后就开始监听 Client端的请求:
- #/etc/init.d/nfs-kernel-server restart (或: #sudo service nfs-kernel-server restart)
Linux 服务器端 NFS服务器的配置到此就已经配置好了。
六、nfs挂载文件系统
这也是最后一步了,至于文件系统嘛,买板子的时候,店家可定给了资料了,然后就是解压到那个你指定的目录下面的。我的是/home/eastmoon/ok6410/rootfs
- #sudo tar –zxf FORLINX_6410_yaffs2_v1.0.tgz就可以了。
然后就是要设置uboot的启动参数了
启动uboot,然后
- set bootargs root=/dev/nfs console=ttySAC0,115200
- nfsroot=192.168.5. 100:/home/eastmoon/ok6410/rootfs
- ip=192.168.5.150:192.168.5.100:192.168.5.1:255.255.255.0::eth0:off
- saveenv
- <</span>span style="font-size:18px;"><</span>span style="font-family:Times New Roman;font-size:14px;"></</span>span></</span>span>
- 192.168.5.100 pc端虚拟机的ip
- 192.168.5.150 开发板的ip
- 192.168.5.1 网关
- 255.255.255.0 子网掩码
然后配合刚才的tftp下载,接着复位下板子。然后就可以即通过tftp下载内核也可以nfs挂载文件系统了,之后的开发就方便多了。
终于写完了,心也静下来了,睡觉了,明天继续公司学习,晚上回来学习板子。以后陆续会把自己调通的驱动都写写博客和大家一起分享下。
转载]OK6410之tftp下载内核,nfs挂载文件系统全过程详解[转]的更多相关文章
- OK6410之tftp下载内核,nfs…
原文地址:OK6410之tftp下载内核,nfs挂载文件系统全过程详解[转]作者:千山我独行 由于工作的平台也是嵌入式,差不多的平台,所以一直就没有把自己买过来的ok6410板子好好玩玩.以前一直都是 ...
- OK6410 tftp下载内核、文件系…
飞凌官方提供了一键下载烧写linux的方式,相对来说比较方便,但是对于开发来说不够灵活,因此这篇文章把tftp相关的点介绍一下,整理下其中遇到的一些问题. 一键烧写本质上是启动位于SD卡中的Uboot ...
- 文件系统管理 之 Linux 创建文件系统及挂载文件系统流程详解
阅读此文,必须具备知识点:<Linux 查看磁盘分区.文件系统.使用情况的命令和相关工具介绍><实例解说 fdisk 使用方法><合理规划您的硬盘分区><Fe ...
- Linux 创建文件系统及挂载文件系统流程详解(转)
作者:北南南北 来自: LinuxSir.Org 摘要:本文对新增硬盘,切割硬盘,创建硬盘分区,为硬盘分区创建文件系统,以及加载文件系统的流程做总结性论述:主要是为初学者弄清楚这一操作过程:本文涉及f ...
- 转 -- OK6410 tftp下载内核、文件系统以及nand flash地址相关整理、总结
转载地址:http://emouse.cnblogs.com/ 飞凌官方提供了一键下载烧写linux的方式,相对来说比较方便,但是对于开发来说不够灵活,因此这篇文章把tftp相关的点介绍一下,整理下其 ...
- linux下使用NFS挂载文件系统
转自linux如何使用NFS挂载文件系统 设备:一台服务器和一台客户端,这里我们把装在PC机上的RedHat作为服务器,而客户端则是嵌入式linux开发板. 环境:开发板已启动,连接好串口和网线,串口 ...
- ZT linux的mount(挂载)命令详解
linux的mount(挂载)命令详解 来源:互联网 作者:佚名 时间:09-08 17:02:27 [大 中 小] 点评:linux下挂载(mount)光盘镜像文件.移动硬盘.U盘.Window ...
- linux-2.6.26内核中ARM中断实现详解(转)
转载:http://www.cnblogs.com/leaven/archive/2010/08/06/1794293.html 更多文档参见:http://pan.baidu.com/s/1dDvJ ...
- [转载,感觉写的非常详细]DUBBO配置方式详解
[转载,感觉写的非常详细]DUBBO配置方式详解 原文链接:http://www.cnblogs.com/chanshuyi/p/5144288.html DUBBO 是一个分布式服务框架,致力于提供 ...
随机推荐
- 02-19 k近邻算法(鸢尾花分类)
[TOC] 更新.更全的<机器学习>的更新网站,更有python.go.数据结构与算法.爬虫.人工智能教学等着你:https://www.cnblogs.com/nickchen121/ ...
- 小游戏:200行python代码手写2048
#-*- coding: utf-8 -*- import curses from random import randrange, choice from collections import de ...
- JDK1.7中HashMap死环问题及JDK1.8中对HashMap的优化源码详解
一.JDK1.7中HashMap扩容死锁问题 我们首先来看一下JDK1.7中put方法的源码 我们打开addEntry方法如下,它会判断数组当前容量是否已经超过的阈值,例如假设当前的数组容量是16,加 ...
- java之ReentrantLock详解
前言 如果一个代码块被synchronized修饰了,当一个线程获取了相应的锁,并执行该代码块时,其他线程便只能一直等待,等待获取锁的释放,现在有这么一种情况,这个获取锁的线程由于要等待IO或者其他原 ...
- PowerUp攻击模块实战
PowerUp攻击模块实战 1.将PowerUp.ps1脚本上传至目标服务器,然后在本地执行 2.使用IEX在内存中加载此脚本,执行以下命令,脚本将进行所有的检查. powershell.exe ...
- Windows渗透测试中wmi的利用
0x01 关于WMI WMI可以描述为一组管理Windows系统的方法和功能.我们可以把它当作API来与Windows系统进行相互交流.WMI在渗透测试中的价值在于它不需要下载和安装, 因为WMI是W ...
- web安全之php中常见的INI文件配置
php.ini 在 PHP 启动时被读取.对于服务器模块版本的 PHP,仅在 web 服务器启动时读取 一次.对于 CGI 和 CLI 版本,每次调用都会读取. * Apache web 服务器在启动 ...
- CTF-SSH服务渗透
环境 Kali ip 192.168.56.102 Smb 靶机ip 192.168.56.101 0x01信息探测 首页发现有类似用户名的信息 先记录下来 Martin N Hadi M Jimmy ...
- PHP array_slice
1.函数的作用:返回数组中的部分区间的元素 2.函数的参数: @params array $array @params int $offset @params int $l ...
- LeetCode初级算法--树02:验证二叉搜索树
LeetCode初级算法--树02:验证二叉搜索树 搜索微信公众号:'AI-ming3526'或者'计算机视觉这件小事' 获取更多算法.机器学习干货 csdn:https://blog.csdn.ne ...