- 论坛徽章:
- 0
|
本帖最后由 xrqun 于 2011-03-23 20:33 编辑
回复 1# xrqun
问题解决了。
查看uboot的代码结果发现问题出现在Nand_uitl.c的
int nand_read_skip_bad(nand_info_t *nand, size_t offset, size_t *length,
u_char *buffer);
查询坏区
len_incl_bad = get_len_incl_bad (nand, offset, *length);
如果没有坏区,则直接读取整个所需的数据区。
if (len_incl_bad == *length) {
rval = nand_read (nand, offset, length, buffer);
if (rval != 0 && -EUCLEAN != rval) {
printf ("NAND read from offset %x failed %d\n",
offset, rval);
return rval;
}
}
问题出现在这边,如果没有坏区直接读取数据后,还继续执行下面的操作。相当于执行了2遍nand read操作,所以时间上差不多是2倍。
while (left_to_read > 0) { ......}
这个问题不知道是不是uboot的问题还是我的理解有什么不合理的地方。
解决方法:
1.直接修改读取数据的大小,直接数据长度加1就可以了。
2.修改代码,如果没有坏区读取数据后就不执行下面的while了。 |
|