来源:http://www.armchina.cn/article.asp?id=64
经过分析(参见我上一篇日志),一切都变得很明晰了!终于搞定了YAFFS IMAGE烧写在新内核linux2.6.23.9上。
新的yaffs2代码是通过nandmtd1_WriteChunkWithTagsToNAND写NAND的,写入nand的oob不再是调整的yaffs_spare结构,而是yaffs_PackedTags1结构!
在mkyaffsimage中却还是没有改过来。这也是为什么好多人反应,烧写的yaffs image在mount之后只能看见lost +found,其他什么都没有。
所以简单的修改一下mkyaffsimage.c就行拉,可以参考nandmtd1_WriteChunkWithTagsToNAND这个函数。
把修改mkyaffsimage的关键代码贴出来
static int write_chunk(__u8 *data, __u32 objId, __u32 chunkId, __u32 nBytes)
{
yaffs_Tags t;
yaffs_Spare s;
yaffs_PackedTags1 pt1; //add by hiboy
yaffs_ExtendedTags etags;
__u8 oobdata[16];
error = write(outFile,data,512);
if(error < 0) return error;
etags.chunkId = chunkId;
etags.serialNumber=0;
etags.byteCount=nBytes;
etags.objectId=objId;
yaffs_PackTags1(&pt1, &etags);
yaffs_CalcTagsECC((yaffs_Tags *)&pt1);
((__u8 *)&pt1)[8] = 0xff;
memset(oobdata,0xff,16);
memcpy(oobdata+8,&pt1,8);
nPages++;
//return write(outFile,&s,sizeof(yaffs_Spare));
return write(outFile,oobdata,16); //YTAG1_SIZE
}
这里的16字节oob符合nand mtd的要求,低8字节保留0xFF给MTD,高8字节yaffs_PackedTags1结构,符合目前yaffs2的代码。
这样通过mkyaffsimage制作的yaffsimage通过mtd_util烧到nand中就正确了:
./flasheraseall /dev/mtdX
./nandwrite -a -o /dev/mtdX YAFFSIMAGE
让uboot烧写yaffs也很简单了,因为先前我发布过能够烧写YAFFS的uboot,他使用nand而不是nand legacy,关于代码的修改就留给读者自行完成了。我回头也再试一下