Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp247228pxj; Tue, 18 May 2021 02:22:39 -0700 (PDT) X-Google-Smtp-Source: ABdhPJypy0xp2fKGPirw7S7DMtoxLgIQUkFIemiAvwPODLu3V5Vywk72Ms8r2ACvPtQhqN7Uz6ES X-Received: by 2002:a05:6638:3290:: with SMTP id f16mr4527676jav.49.1621329758953; Tue, 18 May 2021 02:22:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1621329758; cv=none; d=google.com; s=arc-20160816; b=P0X/7v2HaIlyJ0xMk6WAYA5a3zB9l+YgJDignlLMaJGKP9KA6L25XHaAOTLfmS4XbK dqJmhlEY7UXXmg0ZvEdHOCxZUHLrEVRCAkg4Q2eB3d6OqdPYFT3rcfDwmfidoYk6Onxa 5u3uVa+VO0IFBQygo5TrgKmlqknGiQVS0jXXWA51OnFms9YC0UILO7BLHnOJpbyYgoat y2q5M/gW20/HqwodUWdjy9OuIo5BhmrtpBkc37vHmBlXjthqaS9idbnw46nmyUJXV07y o806NJnLiUl5CEAsymmqlBxxHEn6uWdfhciUMBdUYoqFqusaDtrkshtguQGQ9+SNqakR IACQ== 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=1HwqYTNM+ES/kvBgAIh6i996VD/d+14TR8z1v1DTDmQ=; b=n+IfUvx0624FlVOwyI1sgKYIvSKsiSgyYBePhvnVBluZtmvKNwCzRaFT4fKoMIYljR p/mAE/+WSSzSS79jg/Z8DvaGFdr1cez1uJ6MIiB1MLiWYN8IA34M5IIPA4xbGDXF/DjI 5ALc8kPtkXsflKcMdd2QUeLTSLkD1dc1J/l1rW7VB5G3DL/SnqqBc0v5NxqKUurp76Zv cuhyqr1VGd2In3Gh+yDpu6hPkScxFsAA6WqD84qkRsL9OvSiJVJKEk5h2exTFHPUdODz eImViTUFHWGCj4QxzOKccdbBhroHvG9mYHKQla4YNI4SmWD0bIuxO+61O4jfY/Gdst/V g/7w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=FKUaMRNF; 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 o2si7751237jaa.70.2021.05.18.02.22.26; Tue, 18 May 2021 02:22:38 -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=FKUaMRNF; 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 S241735AbhEQPFg (ORCPT + 99 others); Mon, 17 May 2021 11:05:36 -0400 Received: from mail.kernel.org ([198.145.29.99]:51050 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S240818AbhEQOz6 (ORCPT ); Mon, 17 May 2021 10:55:58 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 83981613D8; Mon, 17 May 2021 14:25:05 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1621261506; bh=BmOhuDCWBLzQHymnRt/ytTMCtdRVbbIQJQLAJR27aVo=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=FKUaMRNF0OTCMq84MVPO+pcaH6QnUMJzKtK23vyS3C/i+XfiiunqUPXx7AVBnV3H5 hPzZHbRoM4bjaJtS4rKx8LjYv2olwb70FnzvyaZkHiISy82oyWP0/f8PwdIGWiwZPY ZbE0fm5/UwiW2H5+CTJVpAmgR31L0AfjNoN1TaPQ= 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.11 123/329] f2fs: fix to update last i_size if fallocate partially succeeds Date: Mon, 17 May 2021 16:00:34 +0200 Message-Id: <20210517140306.270294002@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210517140302.043055203@linuxfoundation.org> References: <20210517140302.043055203@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 00e89f45ccde..42563d7c442d 100644 --- a/fs/f2fs/file.c +++ b/fs/f2fs/file.c @@ -1616,9 +1616,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)); @@ -1631,11 +1632,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++; @@ -1645,7 +1647,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: @@ -1653,10 +1654,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); @@ -1670,24 +1669,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