移植u-boot-2012.04.01到JZ2440(七:修改源码之烧写JFFS2、烧写YAFFS与制作补丁)

目录

        7. 修改源码之烧写JFFS2、烧写YAFFS与制作补丁
            7.1 烧写JFFS2

            7.2 烧写YAFFS
                7.2.1 分析nand write.yaffs
                7.2.2 修改代码
                7.2.3 测试
            7.3 制作补丁


7. 修改源码之烧写JFFS2、烧写YAFFS与制作补丁

7.1 烧写JFFS2

    该uboot已经支持JFFS2文件格式的烧写,启动进入命令行,使用如下命令:
      tftp 30000000 fs_mini.jffs2    (下载fs_mini.jffs2文件系统到30000000地址)
      nand erase.part rootfs    (擦除rootfs分区)
      nand write.jffs2 30000000 rootfs $filesize    (使用nand write.jffs2将30000000地址的大小为filesize的文件写到rootfs分区)
      set bootargs console=ttySAC0 root=/dev/mtdblock3 rootfstype=jffs2    (设置启动参数)
      save   
     如果NAND Flash没有内核再使用移植u-boot-2012.04.01到JZ2440(六:修改源码之环境变量、裁剪uboot与设置分区)6.2.2 使用分区名烧写文件方式烧写uImage。重启uboot或者执行bootm 30000000命令就能启动内核运行fs_mini.jffs2文件系统了。

7.2 烧写YAFFS

7.2.1 分析nand write.yaffs

    当前uboot不支持烧写YAFFS文件系统,在uboot下执行:
   
    在源码查找“Unknown nand command suffix”定位到common/cmd_nand.c文件的do_nand()函数,部分代码如下:

int do_nand(cmd_tbl_t * cmdtp, int flag, int argc, char * const argv[])
{
        ... ...
        	read = strncmp(cmd, "read", 4) == 0; /* 1 = read, 0 = write */
		printf("\nNAND %s: ", read ? "read" : "write");
                ... ...
		if (!s || !strcmp(s, ".jffs2") ||
		    !strcmp(s, ".e") || !strcmp(s, ".i")) {
#ifdef CONFIG_CMD_NAND_TRIMFFS
		} else if (!strcmp(s, ".trimffs")) {
                ... ...
#endif
#ifdef CONFIG_CMD_NAND_YAFFS
        	} else if (!strcmp(s, ".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);
#endif
		} else if (!strcmp(s, ".oob")) {
                ... ...
		} 
        ... ...
}

    可以看到很多nand操作都是在该函数里完成的,例如之前的nand write.jffs2,这里想要实现nand write.yaffs操作首先要定义宏CONFIG_CMD_NAND_YAFFS,这样当执行nand write.yaffs操作就会进入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;
            }
      }
    ... ...
}

7.2.2 修改代码

    1. 在include/configs/jz2440.h中定义宏CONFIG_CMD_NAND_YAFFS
     

    2. 修改nand_write_skip_bad()函数,如下:
  
    改为(避免输入nand write.yaffs时直接进入该判断):

	if (!need_skip && !(flags & WITH_DROP_FFS) && !(flags & WITH_YAFFS_OOB)) {
		rval = nand_write (nand, offset, length, buffer);
		if (rval == 0)
			return 0;

    3. 修改nand_write_skip_bad()函数,如下:
   
    改为(表示支持烧写OOB数据,用来存放yaffs参数):

ops.mode = MTD_OOB_RAW;

    4. 修改nand_write_skip_bad()函数,如下:
   
    改为(烧写正确返回的是非0值):
       

7.2.3 测试

    重新编译烧写uboot,启动进入命令行,输入如下命令:
      tftp 30000000 fs_mini.yaffs2    (下载fs_mini.jffs2文件系统到30000000地址)
      nand erase.part rootfs    (擦除rootfs分区)
      nand write.yaffs 30000000 rootfs $filesize    (使用nand write.jffs2将30000000地址的大小为filesize的文件写到rootfs分区)
      set bootargs console=ttySAC0 root=/dev/mtdblock3 rootfstype=yaffs    (设置启动参数)
      save
   

    再输入nand dump 260000命令,如下:
   
    fs_mini.yaffs2文件部分内容如下:
   
    可以看到fs_mini.yaffs2文件里的OOB数据正确写入NAND FlashOOB区域了。

对于64ByteOOB而言,数据定义如下所示:
    Byte0:表示该块的数据是否为坏,若为0xFF表示好的,0x00则是坏的;
    Byte1:暂时没用到;
    Byte2~39:表示用来存放oob数据,若是yaffs文件,则会存放yaffs参数;
    Byte40~63:存放ecc校验值,该页的每256字节,就会生成3字节数据存放到ecc里。

    如果NAND Flash没有内核再使用移植u-boot-2012.04.01到JZ2440(六:修改源码之环境变量、裁剪uboot与设置分区)6.2.2 使用分区名烧写文件方式烧写uImage。重启uboot或者执行bootm 30000000命令就能启动内核运行fs_mini.yaffs2文件系统了。

7.3 制作补丁

    在uboot根目录执行如下命令:
    make distclean    (清除之前编译生成的所有文件)
    rm u-boot.dis
    cd ..
    mv u-boot-2012.04.01 u-boot-2012.04.01_jz2440   
(重命名)
    tar xjf u-boot-2012.04.01.tar.bz2    (解压得到源码)
    diff -urN u-boot-2012.04.01 u-boot-2012.04.01_jz2440 > u-boot-2012.04.01_jz2440.patch    (这就是补丁文件名)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值