详解linux平台芯片烧写流程
详解将持续更新!
连接好开发板,重新启动,进入u-boot交互界面,执行如下操作:
一、配置网络
# pri
# setenv ipaddr 192.168.64.11 (注:ipaddr 为开发板IP)
# setenv serverip 192.168.64.12 (注:serverip 为Windows主机IP)
# setenv gatewayip 192.168.64.1 (注:gatewayip 为网关)
# saveenv
# ping 192.168.64.12 (如果能通,则继续往下做)
二、烧写系统文件(先由tftp下载到ddr,再由ddr烧写到nandflash)
首先,启动tftp服务,选择好待下载目标文件的路径,执行如下动作:
注意:可以先tftp到内存,然后用“bootm 地址”启动测试,不用去擦写nandflash
1)烧写kernel
// 将内核镜像下载到内存
# tftp 0x40000000 uImage
//可以用此命令验证内核是否能正常启动,免得当前的有问题又把原来正常的擦了
# bootm 0x40000000
// 从地址0x600000开始擦除0x500000字节大小的nandflash空间
# nand erase 0x600000 0x500000
// 将内存里的内核镜像烧写到nandflash
# nand write 0x40000000 0x600000 0x500000
2)烧写fs
# tftp 0x40000000 rootfs.img
# nand erase 0xe00000 0xf200000
# nand write.yaffs 0x40000000 0xe00000 0xxxxx(0xxxxx根据执行tftp 0x40000000 rootfs.img下载的大小确定)
3)烧写u-boot
# tftp 0x40000000 u-boot.bin
# nand erase 0x0 0x600000
# nand write 0x40000000 0x0 0x600000
三、重启进入u-boot交互界面,配置uboot的启动参数
测试1(启动内核):
// 设置启动命令:先从nandflash里读到内存,再从内存启动内核
# setenv bootcmd nand read 0x40000000 0x600000 0x500000\; bootm 0x40000000
// 保存以上设置参数
# saveenv
重启,观察效果。
测试2(设置机器码):
# setenv machid 0xXXX(根据自己情况而定)
# saveenv
重启,观察效果。
测试3(启动本地文件系统):
# setenv bootargs root=/dev/mtdblock4 init=/sbin/init console=ttySAC0,115200 rootfstype=yaffs rw
# saveenv
重启,观察效果。
四、若要实现nfs挂载文件系统则进行如下操作:
1、确保虚拟机virtualbox里的网卡为有线网卡(因为是通过网线挂载的)
2、设置ip地址
# setenv serverip 192.168.64.13
# setenv ipaddr 192.168.64.11
# setenv gatewayip 192.168.64.1
# saveenv
注:serverip为Windows里virtualbox里的ubuntu的IP
测试4(挂载ubuntu里的根文件系统):
# setenv bootargs root=/dev/nfs nfsroot=192.168.64.13:/mini_rootfs ip=192.168.64.11:192.168.64.1::255.255.255.0::eth0:off init=/linuxrc
console=ttySAC0,115200
# saveenv
重启,观察效果。
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。