Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp3059208pxj; Mon, 17 May 2021 16:43:04 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzoaAAuRFhqNBbPVUIgKEU4DoRekUp47d8O3ws75rimhd1NXKM2i1lsbEJfwaVX3P1YZMy0 X-Received: by 2002:a17:906:6d43:: with SMTP id a3mr2693148ejt.142.1621294984123; Mon, 17 May 2021 16:43:04 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1621294984; cv=none; d=google.com; s=arc-20160816; b=HtH2BvNgpd68lVmPJdC54d82p3tqe6M5AVm9EXk2g/VWOkX9WK6susgaLGegX0wtIp wnHpQ9wc9DohoewjgY1xFCQEHv9ZHhgMJ9JYPV8pVwM/wbg0nwO+ag4Nxpd1xhqbnT+Y Nw1W1WaUe30koTYPXzQmeraMOqouPPsFsA6/CVRneL9VCiKxTwa10eXTBtDdSNwJWuOg DBynT9lhrhXBG1LvFD9KweL0sOpfGEGFKneWb1L+J7q4KESmKQ8soF6VjHapRyKLYJxO DzvomOF1KbtGnKJKjAH2i/LuKCWX/RyeIU9p6lLxbBX74KrB4jNn1s5I0MaF5Clj8wI7 l98w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=rUApINtm2EfY3Tuom84k61lwot5EuiizOJbKcog9y8o=; b=Vth1gAxmdnoWFiFZSSEOGKt797mI4ExkHHfFZvmktUu1jk1uRm21g5YMuRtTcXK1DK g2hkNs2SINqcZFNOg/Gc96sReb3H43Abbbsq9UCyIHrZQia0/WMWH3lfqG20JzhNDOje rx+gYqYK6FfvvnuOMddUttlBS4AUFQT4n10Sk8t0Q4eohPUY8RbwDvi7fiKB2Z18QUI+ wInupWhCwryrDRr3N+PK1EMRJPPPdAwzVpQQkGfx+KoATKMHh7Y22CAPioE8Vx4NGLka Hcu0JA1Qv2G450qcdtVqJos3r1Q8ODbqPRo67vyCvP0nDDFoaEMMRkyRNZdPNOH7OV/b ViTg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b="x/ZVRPCY"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id ds10si20092090ejc.415.2021.05.17.16.42.40; Mon, 17 May 2021 16:43:04 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b="x/ZVRPCY"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S239329AbhEQOXU (ORCPT + 99 others); Mon, 17 May 2021 10:23:20 -0400 Received: from mail.kernel.org ([198.145.29.99]:33820 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S239368AbhEQOTi (ORCPT ); Mon, 17 May 2021 10:19:38 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id EE8C661428; Mon, 17 May 2021 14:11:01 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1621260662; bh=2zKF5yk+chBbwlvm5tpQgR474AM+FppCpfAxKQjzlTQ=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=x/ZVRPCY4ZgQ9MRcIYvjaBp9raROZPKEwxg1w9VblbiQhbV6dOwg2jeGrcWqdCX77 83t2Uz/6jHKkiN9ZhZxWtk6Q3KtIdIJZzjwpoQsU0CMI2PscRpPa95GjDA4zEGBddh h3b0P9lBhgSJw2w1DkH3Xv4bkoWDf3ptsrdBC6M4= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Chao Yu , Jaegeuk Kim , Sasha Levin Subject: [PATCH 5.12 138/363] f2fs: fix to update last i_size if fallocate partially succeeds Date: Mon, 17 May 2021 16:00:04 +0200 Message-Id: <20210517140307.287808352@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210517140302.508966430@linuxfoundation.org> References: <20210517140302.508966430@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Chao Yu [ Upstream commit 88f2cfc5fa90326edb569b4a81bb38ed4dcd3108 ] In the case of expanding pinned file, map.m_lblk and map.m_len will update in each round of section allocation, so in error path, last i_size will be calculated with wrong m_lblk and m_len, fix it. Fixes: f5a53edcf01e ("f2fs: support aligned pinned file") Signed-off-by: Chao Yu Signed-off-by: Jaegeuk Kim Signed-off-by: Sasha Levin --- fs/f2fs/file.c | 22 +++++++++++----------- 1 file changed, 11 insertions(+), 11 deletions(-) diff --git a/fs/f2fs/file.c b/fs/f2fs/file.c index bd5a77091d23..dc79694e512c 100644 --- a/fs/f2fs/file.c +++ b/fs/f2fs/file.c @@ -1619,9 +1619,10 @@ static int expand_inode_data(struct inode *inode, loff_t offset, struct f2fs_map_blocks map = { .m_next_pgofs = NULL, .m_next_extent = NULL, .m_seg_type = NO_CHECK_TYPE, .m_may_create = true }; - pgoff_t pg_end; + pgoff_t pg_start, pg_end; loff_t new_size = i_size_read(inode); loff_t off_end; + block_t expanded = 0; int err; err = inode_newsize_ok(inode, (len + offset)); @@ -1634,11 +1635,12 @@ static int expand_inode_data(struct inode *inode, loff_t offset, f2fs_balance_fs(sbi, true); + pg_start = ((unsigned long long)offset) >> PAGE_SHIFT; pg_end = ((unsigned long long)offset + len) >> PAGE_SHIFT; off_end = (offset + len) & (PAGE_SIZE - 1); - map.m_lblk = ((unsigned long long)offset) >> PAGE_SHIFT; - map.m_len = pg_end - map.m_lblk; + map.m_lblk = pg_start; + map.m_len = pg_end - pg_start; if (off_end) map.m_len++; @@ -1648,7 +1650,6 @@ static int expand_inode_data(struct inode *inode, loff_t offset, if (f2fs_is_pinned_file(inode)) { block_t sec_blks = BLKS_PER_SEC(sbi); block_t sec_len = roundup(map.m_len, sec_blks); - block_t done = 0; map.m_len = sec_blks; next_alloc: @@ -1656,10 +1657,8 @@ next_alloc: GET_SEC_FROM_SEG(sbi, overprovision_segments(sbi)))) { down_write(&sbi->gc_lock); err = f2fs_gc(sbi, true, false, false, NULL_SEGNO); - if (err && err != -ENODATA && err != -EAGAIN) { - map.m_len = done; + if (err && err != -ENODATA && err != -EAGAIN) goto out_err; - } } down_write(&sbi->pin_sem); @@ -1673,24 +1672,25 @@ next_alloc: up_write(&sbi->pin_sem); - done += map.m_len; + expanded += map.m_len; sec_len -= map.m_len; map.m_lblk += map.m_len; if (!err && sec_len) goto next_alloc; - map.m_len = done; + map.m_len = expanded; } else { err = f2fs_map_blocks(inode, &map, 1, F2FS_GET_BLOCK_PRE_AIO); + expanded = map.m_len; } out_err: if (err) { pgoff_t last_off; - if (!map.m_len) + if (!expanded) return err; - last_off = map.m_lblk + map.m_len - 1; + last_off = pg_start + expanded - 1; /* update new size to the failed position */ new_size = (last_off == pg_end) ? offset + len : -- 2.30.2