Received: by 2002:a17:90a:9103:0:0:0:0 with SMTP id k3csp11787126pjo; Thu, 2 Jan 2020 14:16:30 -0800 (PST) X-Google-Smtp-Source: APXvYqy0xE7kiTguBe1ej7O+U825aim3W0E/4Vpa5C7J2/eiew2p0Q5xzk553Oh9WZpkAbRdIQuN X-Received: by 2002:a9d:7cd9:: with SMTP id r25mr88359543otn.326.1578003390421; Thu, 02 Jan 2020 14:16:30 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1578003390; cv=none; d=google.com; s=arc-20160816; b=AynHRuBpfgrCowrzvSGQvI6q7gaSa9V/ON/rSN660kSjYwoO3Uxj59+MeVlekb8vG4 2KQX9TYWq5v4CP9i1PearFtqV4FguN/ODa5u+bbyXvJasgivxA8BaMjtYU7oguOeKKpW 0DvNBvaOb+/YE+nH41UAwI/QdXCrFkT/N4pn0/UxKKoxBDDtgfOdvcZ0iZE1MJJpYhBg 8jseWoKtp5epTKBKLcXrJFNS2jg8/Ld59T5/noxB40d9kf20l+P9wtDKFiNP0sRL0tSS VoBBXfPlg4K0Qbssf/1kiAcNgiRj1E55De9Eje5cDBUckqnTQVldxUgr+0NOiSyjQcVU ZL0w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=tSkk9JffkI4uq26c/7XLCXdckmLIuZ4Qh1B2kJkBoxk=; b=evlzZPh+k9GnkGf7LbQpyWmO2n174GjPOQORSe6JsPT8spsllqHdtsU2igZ7Dhnlg6 DMPUAOk8LEUjq7r7wfVjh9+dopnYfHuCkMhN80QWC7i6PPEbAsfeVwYd7qsbf8zuX45A 8oZf4c8MsyL0XiYE4pJOVBUBaSutIGXIBRBnpUtgj76CGAAGHu26LK36ucpWlcQt2Ieh Vy8LuEU45Rm5K5UeGp1hnpr1v6fAUwd10+NgC1z9nocfmN9gs7pKVyud4elp75aIITrD ftlwVeeLW7JVMCfR5woiT4BskzBzPB78Q1bmiBUdQf2Bbf0h0nKT0WfZdLc32wuuhyF2 GrsA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=CLvMV+lj; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id t25si18699417oth.246.2020.01.02.14.16.18; Thu, 02 Jan 2020 14:16:30 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=CLvMV+lj; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728043AbgABWPR (ORCPT + 99 others); Thu, 2 Jan 2020 17:15:17 -0500 Received: from mail.kernel.org ([198.145.29.99]:55950 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728021AbgABWPO (ORCPT ); Thu, 2 Jan 2020 17:15:14 -0500 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 0C72E2253D; Thu, 2 Jan 2020 22:15:12 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1578003313; bh=V0fFlgsZEjywMSvwazLJJImMQhrXkl4rvnE6M1h6jak=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=CLvMV+ljIDWD/fXdbe4Z3/1oXzt/BSKZHQwC7MZ3mW43rkKqzDZ0nOVtKfPQKqux9 0r6p2f7IgNp6vD6WfO/L+KXlQh9mYqVPWGcjiN4yoNVkbgLk6b/QJtMszANlZqoSN5 oJqd0knzEfzX10xuEnR8cJAnJXUdrYwKRzhQoggE= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Chengguang Xu , Chao Yu , Jaegeuk Kim , Sasha Levin Subject: [PATCH 5.4 108/191] f2fs: choose hardlimit when softlimit is larger than hardlimit in f2fs_statfs_project() Date: Thu, 2 Jan 2020 23:06:30 +0100 Message-Id: <20200102215841.487559565@linuxfoundation.org> X-Mailer: git-send-email 2.24.1 In-Reply-To: <20200102215829.911231638@linuxfoundation.org> References: <20200102215829.911231638@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Chengguang Xu [ Upstream commit 909110c060f22e65756659ec6fa957ae75777e00 ] Setting softlimit larger than hardlimit seems meaningless for disk quota but currently it is allowed. In this case, there may be a bit of comfusion for users when they run df comamnd to directory which has project quota. For example, we set 20M softlimit and 10M hardlimit of block usage limit for project quota of test_dir(project id 123). [root@hades f2fs]# repquota -P -a *** Report for project quotas on device /dev/nvme0n1p8 Block grace time: 7days; Inode grace time: 7days Block limits File limits Project used soft hard grace used soft hard grace ---------------------------------------------------------------------- 0 -- 4 0 0 1 0 0 123 +- 10248 20480 10240 2 0 0 The result of df command as below: [root@hades f2fs]# df -h /mnt/f2fs/test Filesystem Size Used Avail Use% Mounted on /dev/nvme0n1p8 20M 11M 10M 51% /mnt/f2fs Even though it looks like there is another 10M free space to use, if we write new data to diretory test(inherit project id), the write will fail with errno(-EDQUOT). After this patch, the df result looks like below. [root@hades f2fs]# df -h /mnt/f2fs/test Filesystem Size Used Avail Use% Mounted on /dev/nvme0n1p8 10M 10M 0 100% /mnt/f2fs Signed-off-by: Chengguang Xu Reviewed-by: Chao Yu Signed-off-by: Jaegeuk Kim Signed-off-by: Sasha Levin --- fs/f2fs/super.c | 20 ++++++++++++++------ 1 file changed, 14 insertions(+), 6 deletions(-) diff --git a/fs/f2fs/super.c b/fs/f2fs/super.c index 1443cee15863..a2af155567b8 100644 --- a/fs/f2fs/super.c +++ b/fs/f2fs/super.c @@ -1213,9 +1213,13 @@ static int f2fs_statfs_project(struct super_block *sb, return PTR_ERR(dquot); spin_lock(&dquot->dq_dqb_lock); - limit = (dquot->dq_dqb.dqb_bsoftlimit ? - dquot->dq_dqb.dqb_bsoftlimit : - dquot->dq_dqb.dqb_bhardlimit) >> sb->s_blocksize_bits; + limit = 0; + if (dquot->dq_dqb.dqb_bsoftlimit) + limit = dquot->dq_dqb.dqb_bsoftlimit; + if (dquot->dq_dqb.dqb_bhardlimit && + (!limit || dquot->dq_dqb.dqb_bhardlimit < limit)) + limit = dquot->dq_dqb.dqb_bhardlimit; + if (limit && buf->f_blocks > limit) { curblock = dquot->dq_dqb.dqb_curspace >> sb->s_blocksize_bits; buf->f_blocks = limit; @@ -1224,9 +1228,13 @@ static int f2fs_statfs_project(struct super_block *sb, (buf->f_blocks - curblock) : 0; } - limit = dquot->dq_dqb.dqb_isoftlimit ? - dquot->dq_dqb.dqb_isoftlimit : - dquot->dq_dqb.dqb_ihardlimit; + limit = 0; + if (dquot->dq_dqb.dqb_isoftlimit) + limit = dquot->dq_dqb.dqb_isoftlimit; + if (dquot->dq_dqb.dqb_ihardlimit && + (!limit || dquot->dq_dqb.dqb_ihardlimit < limit)) + limit = dquot->dq_dqb.dqb_ihardlimit; + if (limit && buf->f_files > limit) { buf->f_files = limit; buf->f_ffree = -- 2.20.1