dm thin: allow metadata commit if pool is in PM_OUT_OF_DATA_SPACE mode
authorJoe Thornber <ejt@redhat.com>
Tue, 6 May 2014 15:28:14 +0000 (16:28 +0100)
committerMike Snitzer <snitzer@redhat.com>
Wed, 14 May 2014 20:11:36 +0000 (16:11 -0400)
Commit 3e1a0699 ("dm thin: fix out of data space handling") introduced
a regression in the metadata commit() method by returning an error if
the pool is in PM_OUT_OF_DATA_SPACE mode.  This oversight caused a thin
device to return errors even if the default queue_if_no_space ENOSPC
handling mode is used.

Fix commit() to only fail if pool is in PM_READ_ONLY or PM_FAIL mode.

Reported-by: qindehua@163.com
Signed-off-by: Joe Thornber <ejt@redhat.com>
Signed-off-by: Mike Snitzer <snitzer@redhat.com>
Cc: stable@vger.kernel.org # 3.14+
drivers/md/dm-thin.c

index 13abade76ad9bbd65c83c67d35f075506b17b63f..15f748ba6754f56a7e571d7ed9940533a298bd66 100644 (file)
@@ -935,7 +935,7 @@ static int commit(struct pool *pool)
 {
        int r;
 
-       if (get_pool_mode(pool) != PM_WRITE)
+       if (get_pool_mode(pool) >= PM_READ_ONLY)
                return -EINVAL;
 
        r = dm_pool_commit_metadata(pool->pmd);