移植uboot-支持yaffs烧写,打补丁

发布者:科技革新者最新更新时间:2021-07-30 来源: eefocus 手机看文章 扫描二维码
随时随地手机看文章

1. 修改uboot支持yaffs


首先,每个命令都会对应一个文件,比如nand命令对应的common/cmd_nand.c


而我们使用nand命令时,便会进入do_nand()函数,位于common/cmd_nand.c


1.1do_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宏定义.


1.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 %dn",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;

            }

      }

    ... ...

}


1)将上面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) 语句


2)将上面的MTD_OOB_AUTO改为MTD_OOB_RAW (表示支持烧写OOB数据,用来存放yaffs参数)


因为MTD_OOB_AUTO,使自动填入OOB,不填入yaffs文件里的数据,从而启动不了内核


3)将上面第14行if (!rval) 改为if (rval)


因为nand->write_oob()函数里面,烧写正确时,是返回的一个非整数.


1.3然后使用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全局结构体变量


1.4 然后烧写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,内核是否正确)         


2. 使用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  //生成补丁


引用地址:移植uboot-支持yaffs烧写,打补丁

上一篇:15. 从0开始学ARM-位置无关码
下一篇:移植uboot-设置默认环境变量,裁剪,并分区

小广播
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved