aboutsummaryrefslogtreecommitdiffstats
path: root/fs/gfs2/rgrp.c
diff options
context:
space:
mode:
authorSteven Whitehouse <swhiteho@redhat.com>2012-08-23 08:43:40 -0400
committerSteven Whitehouse <swhiteho@redhat.com>2012-09-24 05:47:19 -0400
commit137834a696fd51ef8c710a0ad854b585027c7df0 (patch)
tree0da5dec3a8b95ac287de39038bbcd903673461e4 /fs/gfs2/rgrp.c
parent2b9731e8bb1bdc6b9da149f4e482a071747207f3 (diff)
GFS2: Fall back to ignoring reservations, if there are no other blocks left
When we get to the stage of allocating blocks, we know that the resource group in question must contain enough free blocks, otherwise gfs2_inplace_reserve() would have failed. So if we are left with only free blocks which are reserved, then we must use those. This can happen if another node has sneeked in and use some blocks reserved on this node, for example. Generally this will happen very rarely and only when the resouce group is nearly full. Signed-off-by: Steven Whitehouse <swhiteho@redhat.com>
Diffstat (limited to 'fs/gfs2/rgrp.c')
-rw-r--r--fs/gfs2/rgrp.c5
1 files changed, 5 insertions, 0 deletions
diff --git a/fs/gfs2/rgrp.c b/fs/gfs2/rgrp.c
index 55a2651666c9..30c864e70298 100644
--- a/fs/gfs2/rgrp.c
+++ b/fs/gfs2/rgrp.c
@@ -2012,6 +2012,11 @@ int gfs2_alloc_blocks(struct gfs2_inode *ip, u64 *bn, unsigned int *nblocks,
2012 gfs2_rbm_from_block(&rbm, goal); 2012 gfs2_rbm_from_block(&rbm, goal);
2013 error = gfs2_rbm_find(&rbm, GFS2_BLKST_FREE, ip, false); 2013 error = gfs2_rbm_find(&rbm, GFS2_BLKST_FREE, ip, false);
2014 2014
2015 if (error == -ENOSPC) {
2016 gfs2_rbm_from_block(&rbm, goal);
2017 error = gfs2_rbm_find(&rbm, GFS2_BLKST_FREE, NULL, false);
2018 }
2019
2015 /* Since all blocks are reserved in advance, this shouldn't happen */ 2020 /* Since all blocks are reserved in advance, this shouldn't happen */
2016 if (error) { 2021 if (error) {
2017 fs_warn(sdp, "error=%d, nblocks=%u, full=%d\n", error, *nblocks, 2022 fs_warn(sdp, "error=%d, nblocks=%u, full=%d\n", error, *nblocks,