Received: by 2002:a05:7412:b995:b0:f9:9502:5bb8 with SMTP id it21csp4018309rdb; Thu, 28 Dec 2023 07:34:12 -0800 (PST) X-Google-Smtp-Source: AGHT+IEfLNBNXx/kK5SsV4MYYD3hzwEPYKUdco4JzSikrmVpAmtiVGPlONZT8vrXAhvhORC39Hg5 X-Received: by 2002:a05:6a00:b55:b0:6d9:bb2f:3a69 with SMTP id p21-20020a056a000b5500b006d9bb2f3a69mr3602338pfo.28.1703777651947; Thu, 28 Dec 2023 07:34:11 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1703777651; cv=none; d=google.com; s=arc-20160816; b=G+fFXu2aSQTKEPrzLyCvIf5g+0T7MH7k+fLoc9kUYFfg7UH7UT52UCD8gNTp8I5DVf boOm57aXeBWY+EINRfIlQa0aKrUynlZhFnVphA8GTBU7+HvOC6IHCY3pgFJn7ZCV8wpF EtKx8BBNwfa13Zo2wUQ/ixfQTlMvB6CTpAKsdeBNcB/i6fD7Lgs790up0i8W2UQRmvwA W9Kpg9uJZEdMhB8mJKMLcNT6ChusOinwFcanpK+crnp1dhQk1ExDKT6rLOFkHyKMx4C+ 5q8fzN5pA1YsLpp7H9Yh/F7D9Ih43pb88v8obR/mNc8iLy1ekBM9TnDvW9hOz6b+3FEu G24w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:in-reply-to:from:references:cc:to :content-language:subject:user-agent:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:date:message-id:dkim-signature; bh=fnbK6e3V1ZIOGu8FV/t/V29FKn/SP7f6pz3s+PrwkD8=; fh=1D7eQ/0rc+iU6BAcs/KVKWP4G7WgjJ9VzUdfNwtKJ+I=; b=F4pd+eaMWJjCbP9oz8GO/1QwUlAmcpu2J8FUvKL7GnWJ16zVW+XBg10xeMpodfyNMh mav0+tA38HgIfikvc+eXu4HZj07YV6Y5uDwxo0RndIUy7PcGmRAGDQzOunSKjqSrLZay /JsvSdZJL3hyzgN7g6PqLeF5Rvy1nPOVpYPgJpT9rZ7+R5Txh4QXAke2mB466rsfifY3 p5QW+x3D8UUYHBMEx0L5Eoj5QY9FRAdEvesulifEN6jAiBSxfQi874IzrQPB6zMH8H/x SjLCrAyeJxAZVMAKtjPogsvmNWJcwa/5JyLJrCL8l/VARMD8mAXuqLhjoviCuHmsMMF3 qp0A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b="ipbAH/Wr"; spf=pass (google.com: domain of linux-kernel+bounces-12761-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.48.161 as permitted sender) smtp.mailfrom="linux-kernel+bounces-12761-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from sy.mirrors.kernel.org (sy.mirrors.kernel.org. [147.75.48.161]) by mx.google.com with ESMTPS id l5-20020a632505000000b005ce021fec42si9576530pgl.589.2023.12.28.07.34.11 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 28 Dec 2023 07:34:11 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-12761-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.48.161 as permitted sender) client-ip=147.75.48.161; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b="ipbAH/Wr"; spf=pass (google.com: domain of linux-kernel+bounces-12761-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.48.161 as permitted sender) smtp.mailfrom="linux-kernel+bounces-12761-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sy.mirrors.kernel.org (Postfix) with ESMTPS id 77D37B23833 for ; Thu, 28 Dec 2023 15:33:50 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 319DFF9D7; Thu, 28 Dec 2023 15:33:43 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b="ipbAH/Wr" X-Original-To: linux-kernel@vger.kernel.org Received: from smtp.kernel.org (aws-us-west-2-korg-mail-1.web.codeaurora.org [10.30.226.201]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 6D648F9C5 for ; Thu, 28 Dec 2023 15:33:42 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id E9075C433C8; Thu, 28 Dec 2023 15:33:40 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1703777622; bh=5yDsdWwaOqkj18xvk96SZBr48BQYi9xMppuyMIAULmU=; h=Date:Subject:To:Cc:References:From:In-Reply-To:From; b=ipbAH/Wrp+ob6Xz/zB6i7pWjWD21xpgwi8d2rw2pVIqCBvEHGuX4I8jd+DJs0lhKG h2BBoxE8exC0WvB1G47rLd1XRlQ0YFDzg7Do22yyNTMQ7S9bsXy8UCTTPKZe+f2zmC 0qmK9RaswodQXcH8JIraTOjvkOkhnDSM8UishL/tahB1aKFDWu8P2U2vxqqRP9XYJs OXE46j+jQDiLFoZ3KxrEF/TP9wU73NL2vZW/RsrfDfs4V23kbES0utEbpLxQ7m0eig qO/xhxNmiPib6F1CFcxs2wAwaPt7SLC4H6Hi19Hl+mW+s2ZvKbFvaHJLFC/WivTuS8 BYL6quMrgPTfw== Message-ID: <19a1340f-0a0d-40a0-9d00-0faf171480f2@kernel.org> Date: Thu, 28 Dec 2023 23:33:37 +0800 Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH 5/6] f2fs: fix to restrict condition of compress inode conversion Content-Language: en-US To: Jaegeuk Kim Cc: linux-f2fs-devel@lists.sourceforge.net, linux-kernel@vger.kernel.org References: <20231210113547.3412782-1-chao@kernel.org> <20231210113547.3412782-5-chao@kernel.org> <5884e300-5384-4a49-9f8d-8cced50f4e6d@kernel.org> From: Chao Yu In-Reply-To: Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit On 2023/12/13 6:21, Jaegeuk Kim wrote: > On 12/12, Chao Yu wrote: >> On 2023/12/12 6:11, Jaegeuk Kim wrote: >>> On 12/10, Chao Yu wrote: >>>> This patch adds i_size check during compress inode conversion in order >>>> to avoid .page_mkwrite races w/ conversion. >>> >>> Which race condition do you see? >> >> Something like: >> >> - f2fs_setflags_common >> - check S_ISREG && F2FS_HAS_BLOCKS >> - mkwrite >> - f2fs_get_block_locked >> : update metadata in old inode's disk layout > > Don't we need to prevent setting this for mmapped file? Oh, we have used i_sem lock to prevent such race case, however we missed f2fs_disable_compressed_file(): - f2fs_disable_compressed_file - check inode_has_data - f2fs_file_mmap - mkwrite - f2fs_get_block_locked : update metadata in compressed inode's disk layout - fi->i_flags &= ~F2FS_COMPR_FL - clear_inode_flag(inode, FI_COMPRESSED_FILE); Thanks, > >> - set_compress_context >> >> Thanks, >> >>> >>>> >>>> Fixes: 4c8ff7095bef ("f2fs: support data compression") >>>> Signed-off-by: Chao Yu >>>> --- >>>> fs/f2fs/f2fs.h | 8 +++++++- >>>> fs/f2fs/file.c | 5 ++--- >>>> 2 files changed, 9 insertions(+), 4 deletions(-) >>>> >>>> diff --git a/fs/f2fs/f2fs.h b/fs/f2fs/f2fs.h >>>> index 65294e3b0bef..c9b8a1953913 100644 >>>> --- a/fs/f2fs/f2fs.h >>>> +++ b/fs/f2fs/f2fs.h >>>> @@ -4397,13 +4397,19 @@ static inline int set_compress_context(struct inode *inode) >>>> #endif >>>> } >>>> +static inline bool inode_has_data(struct inode *inode) >>>> +{ >>>> + return (S_ISREG(inode->i_mode) && >>>> + (F2FS_HAS_BLOCKS(inode) || i_size_read(inode))); >>>> +} >>>> + >>>> static inline bool f2fs_disable_compressed_file(struct inode *inode) >>>> { >>>> struct f2fs_inode_info *fi = F2FS_I(inode); >>>> if (!f2fs_compressed_file(inode)) >>>> return true; >>>> - if (S_ISREG(inode->i_mode) && F2FS_HAS_BLOCKS(inode)) >>>> + if (inode_has_data(inode)) >>>> return false; >>>> fi->i_flags &= ~F2FS_COMPR_FL; >>>> diff --git a/fs/f2fs/file.c b/fs/f2fs/file.c >>>> index 1a3c29a9a6a0..8af4b29c3e1a 100644 >>>> --- a/fs/f2fs/file.c >>>> +++ b/fs/f2fs/file.c >>>> @@ -1922,8 +1922,7 @@ static int f2fs_setflags_common(struct inode *inode, u32 iflags, u32 mask) >>>> f2fs_down_write(&F2FS_I(inode)->i_sem); >>>> if (!f2fs_may_compress(inode) || >>>> - (S_ISREG(inode->i_mode) && >>>> - F2FS_HAS_BLOCKS(inode))) { >>>> + inode_has_data(inode)) { >>>> f2fs_up_write(&F2FS_I(inode)->i_sem); >>>> return -EINVAL; >>>> } >>>> @@ -3996,7 +3995,7 @@ static int f2fs_ioc_set_compress_option(struct file *filp, unsigned long arg) >>>> goto out; >>>> } >>>> - if (F2FS_HAS_BLOCKS(inode)) { >>>> + if (inode_has_data(inode)) { >>>> ret = -EFBIG; >>>> goto out; >>>> } >>>> -- >>>> 2.40.1