f2fs: fix miscounted block limit in f2fs_statfs_project()
authorChengguang Xu <cgxu519@mykernel.net>
Sat, 4 Jan 2020 14:20:03 +0000 (22:20 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 11 Feb 2020 12:35:24 +0000 (04:35 -0800)
commit acdf2172172a511f97fa21ed0ee7609a6d3b3a07 upstream.

statfs calculates Total/Used/Avail disk space in block unit,
so we should translate soft/hard prjquota limit to block unit
as well.

Below testing result shows the block/inode numbers of
Total/Used/Avail from df command are all correct afer
applying this patch.

[root@localhost quota-tools]\# ./repquota -P /dev/sdb1

fs/f2fs/super.c

index a2af155..3df83c1 100644 (file)
@@ -1219,6 +1219,8 @@ static int f2fs_statfs_project(struct super_block *sb,
        if (dquot->dq_dqb.dqb_bhardlimit &&
                        (!limit || dquot->dq_dqb.dqb_bhardlimit < limit))
                limit = dquot->dq_dqb.dqb_bhardlimit;
+       if (limit)
+               limit >>= sb->s_blocksize_bits;
 
        if (limit && buf->f_blocks > limit) {
                curblock = dquot->dq_dqb.dqb_curspace >> sb->s_blocksize_bits;