在上一章,裁剪uboot以及分區後,本章主要使uboot支持yaffs以及製作補丁 1. 修改uboot支持yaffs 首先,每個命令都會對應一個文件,比如nand命令對應的common/cmd_nand.c 而我們使用nand命令時,便會進入do_nand()函數,位於common/cmd_nan ...
在上一章,裁剪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)
因為MTD_OOB_AUTO,使自動填入OOB,不填入yaffs文件里的數據,從而啟動不了內核
3)將上面第14行if (!rval) 改為if (rval)
因為nand->write_oob()函數裡面,燒寫正確時,是返回的一個非整數.
1.3然後使用nand dump 260000,與yaffs文件對比,可以看到OOB已經燒寫成功
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就此結束了,接下來,下章便來移植3.4內核