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'.\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 %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; } } ... ... }

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文件系統

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM