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


    在上一章,裁剪uboot以及分区后,本章主要使uboot支持yaffs以及制作补丁

     


    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'. ", 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 %d ",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就此结束了,接下来学习:

    1.移植3.4内核-分析内核启动过程,重新分区,烧写jffs2文件系统

     

  • 相关阅读:
    java+selenium+new——同一个标签窗口里 ,访问多个网页的后退driver.navigate().back()、前进driver.navigate().forward()、刷新driver.navigate().refresh()等功能 。以及获取当前页面的title属性driver.getTitle()和获取当前页面的url地址driver.getCurrentUrl()
    SoapUI接口测试——关联——参数化
    SoapUI接口测试——添加测试套件——new TestSuite——(类似于postman里面的集合)——添加测试步骤——teststeps(测试步骤)
    java+selenium+new——获取网页源代码driver.getPageSource()
    g++命令行详解
    hdoj_1503Advanced Fruits
    指针遍历vector向量
    最长公共子序列
    hdoj_1087Super Jumping! Jumping! Jumping!
    pcc32应用1
  • 原文地址:https://www.cnblogs.com/lifexy/p/8316591.html
Copyright © 2020-2023  润新知