UBI: fix error code in ubi_io_read()
authorArtem Bityutskiy <Artem.Bityutskiy@nokia.com>
Thu, 18 Oct 2007 17:09:41 +0000 (20:09 +0300)
committerArtem Bityutskiy <Artem.Bityutskiy@nokia.com>
Wed, 26 Dec 2007 17:15:13 +0000 (19:15 +0200)
commit2362a53ec59f286495307e0e0d8ef2401e8c5c49
treea7913ce0ed7c28c7f4543c875ded5716147a4b6d
parent235d6200ea63372935e097cb82e6a8c133d51cad
UBI: fix error code in ubi_io_read()

When NAND detects an ECC error, it returns -EBADMSG. It does not
stop reading requested data if one page has an ECC error, it keeps
going and reads all the requested data. If it fails to read all
the data, it does not return -EBADMSG, but returns the error code
which reflects the reason of the failure.

But some drivers may have bugs (e.g., OneNAND had) and stop reading
after the first ECC error, so it returns -EBADMSG. In turn, UBI
propagates this up to the caller. The caller will treat this as
"all the requested data was read, but there was an ECC error".

So we change the error code to -EIO if it is -EBADMSG and the read
length is less then the requested length. We also add an assertion,
so if UBI debugging is enabled, UBI will bug.

Pointed-to-by: Adrian Hunter <ext-adrian.hunter@nokia.com>
Signed-off-by: Artem Bityutskiy <Artem.Bityutskiy@nokia.com>
drivers/mtd/ubi/io.c