[U-Boot] [PATCH v3] imls: Add support to list images in NAND device
Scott Wood
scottwood at freescale.com
Fri Dec 14 19:10:43 CET 2012
On 12/14/2012 03:32:04 AM, Vipin Kumar wrote:
>>> +
>>> + switch (genimg_get_format(buffer)) {
>>> + case IMAGE_FORMAT_LEGACY:
>>> + header = (const image_header_t *)buffer;
>>> + len = image_get_image_size(header);
>>> +
>>> + ret = nand_imls_legacyimage(nand,
>>> nand_dev,
>>> + off, len);
>>> + if (ret< 0&& ret != -ENOMEM)
>>> + return ret;
>>> + break;
>>> +#if defined(CONFIG_FIT)
>>> + case IMAGE_FORMAT_FIT:
>>> + len = fit_get_size(buffer);
>>> + ret = nand_imls_fitimage(nand, nand_dev,
>>> + off, len);
>>> + if (ret< 0&& ret != -ENOMEM)
>>> + return ret;
>>> + break;
>>> +#endif
>>> + }
>>
>> Do you really mean to return from the main imls function just because
>> one image has an error? By "use return" I meant return from the
>> subfunction.
>>
>
> This return only corresponds to the situation when there is an error
> returned from nand read routine. In that case, I don't think there is
> any use reading the NAND any further.
Just because one page has an uncorrectable error doesn't mean the
entire NAND is bad. Note that this is different from what you
currently do if you get an error on the initial read where you look for
a header.
Might want to bail out if you get an excessive amount of errors
(particularly consecutive), though, suggesting that the NAND might not
be working at all. The user probably doesn't want to wait for
thousands of error messages to scroll by in that case.
-Scott
More information about the U-Boot
mailing list