|
@@ -332,6 +332,9 @@ struct gfs2_rgrpd *gfs2_blk2rgrpd(struct gfs2_sbd *sdp, u64 blk, bool exact)
|
|
|
struct rb_node *n, *next;
|
|
|
struct gfs2_rgrpd *cur;
|
|
|
|
|
|
+ if (gfs2_rindex_update(sdp))
|
|
|
+ return NULL;
|
|
|
+
|
|
|
spin_lock(&sdp->sd_rindex_spin);
|
|
|
n = sdp->sd_rindex_tree.rb_node;
|
|
|
while (n) {
|
|
@@ -917,10 +920,6 @@ int gfs2_fitrim(struct file *filp, void __user *argp)
|
|
|
if (!blk_queue_discard(q))
|
|
|
return -EOPNOTSUPP;
|
|
|
|
|
|
- ret = gfs2_rindex_update(sdp);
|
|
|
- if (ret)
|
|
|
- return ret;
|
|
|
-
|
|
|
if (argp == NULL) {
|
|
|
r.start = 0;
|
|
|
r.len = ULLONG_MAX;
|
|
@@ -1671,13 +1670,8 @@ int gfs2_check_blk_type(struct gfs2_sbd *sdp, u64 no_addr, unsigned int type)
|
|
|
{
|
|
|
struct gfs2_rgrpd *rgd;
|
|
|
struct gfs2_holder rgd_gh;
|
|
|
- int error;
|
|
|
-
|
|
|
- error = gfs2_rindex_update(sdp);
|
|
|
- if (error)
|
|
|
- return error;
|
|
|
+ int error = -EINVAL;
|
|
|
|
|
|
- error = -EINVAL;
|
|
|
rgd = gfs2_blk2rgrpd(sdp, no_addr, 1);
|
|
|
if (!rgd)
|
|
|
goto fail;
|