diff options
author | Andreas Gruenbacher <agruenba@redhat.com> | 2024-06-03 20:04:09 +0300 |
---|---|---|
committer | Andreas Gruenbacher <agruenba@redhat.com> | 2024-06-08 03:34:57 +0300 |
commit | 4b4b6374dc6134849f2bdca81fa2945b6ed6d9fc (patch) | |
tree | 7f1e5e167d2a68634b88bc6cd22f2c08b79f8cf6 /fs/gfs2/quota.c | |
parent | 59ebc33201237bf38e5adca3794716100660c5b4 (diff) | |
download | linux-4b4b6374dc6134849f2bdca81fa2945b6ed6d9fc.tar.xz |
gfs2: Revert "ignore negated quota changes"
Commit 4c6a08125f22 ("gfs2: ignore negated quota changes") skips quota
changes with qd_change == 0 instead of writing them back, which leaves
behind non-zero qd_change values in the affected slots. The kernel then
assumes that those slots are unused, while the qd_change values on disk
indicate that they are indeed still in use. The next time the
filesystem is mounted, those invalid slots are read in from disk, which
will cause inconsistencies.
Revert that commit to avoid filesystem corruption.
This reverts commit 4c6a08125f2249531ec01783a5f4317d7342add5.
Signed-off-by: Andreas Gruenbacher <agruenba@redhat.com>
Diffstat (limited to 'fs/gfs2/quota.c')
-rw-r--r-- | fs/gfs2/quota.c | 11 |
1 files changed, 0 insertions, 11 deletions
diff --git a/fs/gfs2/quota.c b/fs/gfs2/quota.c index bbd66adaec3d..f0aaae07a598 100644 --- a/fs/gfs2/quota.c +++ b/fs/gfs2/quota.c @@ -470,17 +470,6 @@ static bool qd_grab_sync(struct gfs2_sbd *sdp, struct gfs2_quota_data *qd, qd->qd_sync_gen >= sync_gen) return false; - /* - * If qd_change is 0 it means a pending quota change was negated. - * We should not sync it, but we still have a qd reference and slot - * reference taken by gfs2_quota_change -> do_qc that need to be put. - */ - if (!qd->qd_change && test_and_clear_bit(QDF_CHANGE, &qd->qd_flags)) { - slot_put(qd); - qd_put(qd); - return false; - } - if (!lockref_get_not_dead(&qd->qd_lockref)) return false; |