项目开源地址:https://github.com/Mculover666/uboot-jz2440
启动时内核先会进行倒数计时,如果没有操作,就会执行图中的命令,从nand flash中的kernel 分区处读取内核到内存中的0x30000000处,也就是SDRAM起始地址,然后从0x30000000处启动内核。
所以,我们只需要将JZ2440官方提供的内核文件复制到TFTP服务器目录,然后将该内核文件提前烧写到nand flash的kernel分区即可,烧写方法如下:
tftp 30000000 uImage_4.3
nand erase.part kernel
nand write 30000000 kernel
但是因为nand flash中还没有烧写文件系统,所以系统会停止在挂载文件系统的地方,接下来烧写文件系统。
将JZ2440官方提供的 yaffs2 文件系统文件拷贝到TFTP服务器目录,按照下面的过程进行烧写:
tftp 30000000 fs_mini_mdev.yaffs2
然后擦除nand flash文件系统分区:
nand erase.part filesystem
烧写yaffs 文件系统:
nand write.yaffs 30000000 260000 889bc0
特别注意:烧写大小要填写十六进制具体大小(可以从tftp 命令的执行结果看到),不能直接填写mtd分区名称filesystem。
接下来定位这个问题,在 common/cmd_nand.c
文件中查看该命令的代码,可以看到,只有开启了宏定义 CONFIG_CMD_NAND_YAFFS
,这段代码才会加入工程中编译:
在单板配置文件 include/configs/smdk2440.h
中开启该宏定义:
接下来编译uoot,烧写到开发板中,再次进行yaffs烧写测试,烧写成功后重启开发板:
经过对比原始文件系统文件内容和烧写到nand flash中的内容,发现烧写的 nand flash 第一页的oob数据不一致,导致往后全部没有烧写进去,根据 nand write.yaffs 命令执行过程,进入在文件drivers/mtd/nand/nand_util.c
中的nand_write_skip_bad 函数,改正uboot中的bug:
第一个bug:
第二个bug:
重新编译,烧写uboot到开发板中,进行yaffs烧写测试,重启之后了可以看到文件系统成功挂载,进入到linux系统:
接收更多精彩文章及资源推送,欢迎订阅我的微信公众号:『mculover666』。