S3C2440移植uboot之支持烧写yaffs映像及制作补丁

  上一节S3C2440移植uboot之裁剪和修改默认参数裁剪了uboot,修改了默认的参数,这一节开始制作yaffs映像以及补丁文件

移植Uboot其他文章链接:

S3C2440移植uboot之编译烧写uboot

S3C2440移植uboot之新建单板_时钟_SDRAM_串口

S3C2440移植uboot之启动过程概述

S3C2440移植uboot之支持NAND启动

S3C2440移植uboot之支持NORFLASH

S3C2440移植uboot之支持NANDFLASH操作

S3C2440移植uboot之支持DM9000

S3C2440移植uboot之裁剪和修改默认参数

S3C2440移植uboot之支持烧写yaffs映像及制作补丁

烧写文件系统

  尝试使用如下命令烧写JFFS2文件系统

tftp 30000000 fs_mini_mdev.jffs2
nand erase.part rootfs
nand write.jffs2 30000000 0x00260000 5b89a8

  修改启动参数

set bootargs console=ttySAC0 root=/dev/mtdblock3 rootfstype=jffs2

  烧写JFFS2文件系统没问题
  尝试使用如下命令烧写YAFFS文件系统

tftp 30000000 fs_mini_mdev.yaffs2
nand erase.part rootfs
nand write.yaffs 30000000 260000  889bc0

  报错
在这里插入图片描述
  搜索.yaffs,发现位于Cmd_nand.c文件中。
在这里插入图片描述
  缺少了相关宏定义
  在smdk2440.h中添加如下代码

#define CONFIG_CMD_NAND_YAFFS

  使用如下命令重新编译烧写

tftp 30000000 u-boot_new.bin; protect off all; erase 0 3ffff; cp.b 30000000 0 40000

tftp 30000000 fs_mini_mdev.yaffs2
nand erase.part rootfs
nand write.yaffs 30000000 260000  889bc0

烧写一瞬间完成,不太正常。而且最后启动文件系统报错如下
在这里插入图片描述
通过对比烧写的fs_mini_mdev_yaffs2文件内容和nand dump 260000显示的内容,发现OOB区的内容不同。
在这里插入图片描述

分析源码

  首先,每个命令都会对应一个文件,比如nand命令对应的common/cmd_nand.c
  而我们使用nand命令时,便会进入do_nand()函数,位于common/cmd_nand.c
  (1)do_nand()函数代码如下所示:

int do_nand(cmd_tbl_t * cmdtp, int flag, int argc, char * const argv[])
{
 ... ...

 if (strncmp(cmd, "read", 4) == 0 || strncmp(cmd, "write", 5) == 0)
{
      ... ...
#ifdef CONFIG_CMD_NAND_YAFFS                   //是否支持YAFFS烧写else if (!strcmp(s, ".yaffs")) 
        {                             //若是nand write.yaffs ... ... ,则进入该判断
               if (read) {              
                           printf("Unknown nand command suffix '%s'.\n", s);
                           return 1;          }

              ret = nand_write_skip_bad(nand, off, &rwsize, (u_char *)addr, WITH_YAFFS_OOB);
                                                //进入nand_write_skip_bad,烧写

#endif
      ... ...

}

  所以需要在smdk2440.h里,添加CONFIG_CMD_NAND_YAFFS宏定义.
  (2)然后进入nand_write_skip_bad(),位于drivers/mtd/nand/nand_util.c

int nand_write_skip_bad(nand_info_t *nand, loff_t offset, size_t *length,u_char *buffer, int flags)
{
       ... ...
       if (!need_skip && !(flags & WITH_DROP_FFS))             //这里需要修改
      {
        rval = nand_write (nand, offset, length, buffer);             //正常拷贝,不考虑OOB问题
              if (rval == 0)  
                     return 0;                                                 //拷贝完后,return
              *length = 0;
              printf ("NAND write to offset %llx failed %d\n",offset, rval);
              return rval;
      }

       while (left_to_write > 0)       //需要烧写的块数
     {             
       #ifdef CONFIG_CMD_NAND_YAFFS
              if (flags & WITH_YAFFS_OOB)
           {
              ... ...
              ops.mode = MTD_OOB_AUTO;  //这里需要修改
              ... ...
              for (page = 0; page < pages; page++) //for循环烧写每一页
             {
               ... ...  

               rval = nand->write_oob(nand, offset, &ops);   //调用nand_write_oob()函数烧写OOB
               if (!rval)                             //这里需要修改
                 break;           //烧写失败,退出for循环
               offset += pagesize;
               p_buffer += pagesize_oob;
            }
      }
    ... ...
}

  将上面if (!need_skip && !(flags & WITH_DROP_FFS))改为if (!need_skip && !(flags & WITH_DROP_FFS) &&!(flags & WITH_YAFFS_OOB))
  因为避免输入nand write.yaffs时,直接进入该判断,然后不执行下面的while (left_to_write > 0) 语句
  将上面的MTD_OOB_AUTO改为MTD_OOB_RAW (表示支持烧写OOB数据,用来存放yaffs参数)
  因为MTD_OOB_AUTO,使自动填入OOB,不填入yaffs文件里的数据,从而启动不了内核
  将上面if (!rval) 改为if (rval)
  因为nand->write_oob()函数里面,烧写正确时,是返回的一个非整数.
  然后使用nand dump 260000,与yaffs文件对比,可以看到OOB已经烧写成功
在这里插入图片描述
  对于64B的OOB而言,数据定义如下所示:
  bit0:表示该块的数据是否为坏,若为0xFF表示好的,0x00则是坏的 (一块=64页)
  bit1:暂时没用到
  bit2~39:表示用来存放oob数据,若是yaffs文件,则会存放yaffs参数,所以才要修改1.2小节的代码
  bit40~63:存放ecc校验值,该页的每256B字节,就会生成3字节数据存放到ecc里
具体参考nand_oob_64全局结构体变量

烧写yaffs试验

tftp 30000000 fs_mini_mdev.yaffs2

nand erase.part rootfs

nand write.yaffs 30000000 260000  $filesize    
      //文件系统太大,所以输入$filesize,来根据文件系统真正大小来烧写 

tftp 30000000 fs_mini_mdev.jffs2

boot

(PS:若启动文件系统失败,考虑下环境变量,OOB,内核是否正确)
启动成功
在这里插入图片描述

使用part制作补丁

  打补丁之前,首先需要清除make后的编译文件,以及自己编译出的反汇编文件等

make distclean           //清除生成的所有文件
rm u-boot.dis             

cd ..
mv u-boot-2012.04.01 u-boot-2012.04.01_new  //重新命名
tar -xjf u-boot-2012.04.01.tar.bz2                       //创建原文件
diff -urN u-boot-2012.04.01 u-boot-2012.04.01_new > u-boot-2012.04.01_new.patch  //生成补丁
  • 39
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 16
    评论
fh8626v100是一款嵌入式系统,我们可以使用U-Boot来进行烧写。U-Boot是一种开源的引导加载程序,它可以在系统启动时进行一系列的初始化和配置。 首先,我们需要准备一个TF卡或者USB存储设备作为烧写介质。将TF卡或USB设备插入到计算机中,并登录到计算机的操作系统。 接下来,我们需要下载并编译U-Boot源码。在终端中使用Git命令将U-Boot的源码库克隆到本地目录: ``` git clone https://github.com/u-boot/u-boot.git ``` 然后,进入U-Boot的源码目录,并进行配置和编译: ``` cd u-boot make distclean make fh8626v100_config make ``` 编译完成后,会生成一个u-boot.bin文件,这就是我们需要烧写到目标设备的文件。 接下来,我们需要将u-boot.bin文件烧写到目标设备中。具体烧写方法可以根据目标设备不同而有所差异,但一般有以下几种方式: 1. 使用烧写工具:将目标设备连接到计算机,通过专用的烧写工具将u-boot.bin文件烧写到设备的存储中。 2. 使用JTAG或SWD接口:将目标设备通过JTAG或SWD接口连接到计算机,并使用相关的调试工具将u-boot.bin文件烧写到设备的存储中。 3. 使用TF卡或USB设备:将TF卡或USB设备插入到目标设备中,并将u-boot.bin文件拷贝到设备中的存储设备中。 烧写完成后,重启目标设备,系统会从U-Boot引导加载程序开始启动。 需要注意的是,具体的烧写方法可能会根据不同的目标设备和烧写工具而有所不同,请根据实际情况进行操作。同时,在进行烧写操作时一定要小心,避免误操作导致设备损坏。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 16
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

嵌入式与Linux那些事

您的鼓励将使我写出更好的文章

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值