diff options
author | Joe Thornber <ejt@redhat.com> | 2018-09-24 22:19:30 +0200 |
---|---|---|
committer | Mike Snitzer <snitzer@redhat.com> | 2018-10-04 21:20:51 +0200 |
commit | 4561ffca88c546f96367f94b8f1e4715a9c62314 (patch) | |
tree | 2143e12ead2aacd17d73d9ea90af991b13c5d032 /drivers/md/dm-cache-metadata.c | |
parent | dm raid: remove bogus const from decipher_sync_action() return type (diff) | |
download | linux-4561ffca88c546f96367f94b8f1e4715a9c62314.tar.xz linux-4561ffca88c546f96367f94b8f1e4715a9c62314.zip |
dm cache metadata: ignore hints array being too small during resize
Commit fd2fa9541 ("dm cache metadata: save in-core policy_hint_size to
on-disk superblock") enabled previously written policy hints to be
used after a cache is reactivated. But in doing so the cache
metadata's hint array was left exposed to out of bounds access because
on resize the metadata's on-disk hint array wasn't ever extended.
Fix this by ignoring that there are no on-disk hints associated with the
newly added cache blocks. An expanded on-disk hint array is later
rewritten upon the next clean shutdown of the cache.
Fixes: fd2fa9541 ("dm cache metadata: save in-core policy_hint_size to on-disk superblock")
Cc: stable@vger.kernel.org
Signed-off-by: Joe Thornber <ejt@redhat.com>
Signed-off-by: Mike Snitzer <snitzer@redhat.com>
Diffstat (limited to 'drivers/md/dm-cache-metadata.c')
-rw-r--r-- | drivers/md/dm-cache-metadata.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/drivers/md/dm-cache-metadata.c b/drivers/md/dm-cache-metadata.c index 69dddeab124c..5936de71883f 100644 --- a/drivers/md/dm-cache-metadata.c +++ b/drivers/md/dm-cache-metadata.c @@ -1455,8 +1455,8 @@ static int __load_mappings(struct dm_cache_metadata *cmd, if (hints_valid) { r = dm_array_cursor_next(&cmd->hint_cursor); if (r) { - DMERR("dm_array_cursor_next for hint failed"); - goto out; + dm_array_cursor_end(&cmd->hint_cursor); + hints_valid = false; } } |