diff options
author | Adrian Hunter <ext-adrian.hunter@nokia.com> | 2008-07-18 18:56:37 +0400 |
---|---|---|
committer | Artem Bityutskiy <Artem.Bityutskiy@nokia.com> | 2008-08-13 12:24:00 +0400 |
commit | 2fb42b11f61cbcef7dfc225c1d26c4511436583d (patch) | |
tree | 2eb3dd34c8e9a191bd8d9ed84b4605c8afc5c611 /fs/ubifs | |
parent | 16dfd804b44ef7156d1c201f100bd0d9dc6b7c4b (diff) | |
download | linux-2fb42b11f61cbcef7dfc225c1d26c4511436583d.tar.xz |
UBIFS: ensure UBIFS switches to read-only on error
UBI transparently handles write errors by automatically copying
and remapping the affected eraseblock. If UBI is unable to do
that, for example its pool of eraseblocks reserved for bad block
handling is empty, then the error is propagated to UBIFS. UBIFS
must protect the media from falling into an inconsistent state
by immediately switching to read-only mode. In the case of log
updates, this was not being done.
Signed-off-by: Adrian Hunter <ext-adrian.hunter@nokia.com>
Diffstat (limited to 'fs/ubifs')
-rw-r--r-- | fs/ubifs/log.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/fs/ubifs/log.c b/fs/ubifs/log.c index 36857b9ed59e..e14829e50693 100644 --- a/fs/ubifs/log.c +++ b/fs/ubifs/log.c @@ -317,6 +317,8 @@ int ubifs_add_bud_to_log(struct ubifs_info *c, int jhead, int lnum, int offs) return 0; out_unlock: + if (err != -EAGAIN) + ubifs_ro_mode(c, err); mutex_unlock(&c->log_mutex); kfree(ref); kfree(bud); |