[U-Boot] [PATCH] mtd: nand: fix the written length when nand_write_skip_bad failed

htbegin hotforest at gmail.com
Sun Mar 10 02:06:54 CET 2013


Hi, Scott

On Fri, Mar 8, 2013 at 6:27 AM, Scott Wood <scottwood at freescale.com> wrote:

>> >> I just use "*length -= left_to_write - written_size" to tell the upper
>> >> level that what
>> >> had been actually happened. For the current block, "written_size" has
>> >> been written to the NAND Flash yet, so left_to_write should be
>> >> subtracted by "written_size".
>> >
>> >
>> > But left_to_write isn't decreased until after this error return, so
>> > that's
>> > already the case.  Subtracting written_size from left_to_write has the
>> > effect of increasing length by written_size, so the return value will
>> > now
>> > look like the error page has been written.
>> >
>> > -Scott
>> No, the returned value doesn't include the length of the error page.
>> In no-WITH_YAFFS_OOB case,  when nand_write failed,
>> truncated_write_size has been
>> updated by nand_write to the length which has been successfully
>> written , so it's OK to subtract written_size from left_to_write.
>
>
> OK, but that doesn't explain why the change is needed.  You said you wanted
> to find the block with the error.  We only write one block at a time in the
> loop.  Why do you need the specific page within the block that failed?
>
> -Scott

Yes, you are right it's OK to ignore the written length of the
write-failed block, but as I said before I just wanted to tell the
upper level what had been actually written. So if you insist the
subtraction of written_len is unnecessary, it's alright with me.

Thanks.
Hou


More information about the U-Boot mailing list