Received: by 2002:ab2:3141:0:b0:1ed:23cc:44d1 with SMTP id i1csp1721650lqg; Mon, 4 Mar 2024 01:27:09 -0800 (PST) X-Forwarded-Encrypted: i=3; AJvYcCXvjEBI6pGdt8sHqSuRd4sNCXLgZ67jqIGEC33SIvy3/ctn305lBghvjSvfYxH1JZcrqW4UDd2oHeUUU0ahpDkVAR2XVflkofnmaJMjdQ== X-Google-Smtp-Source: AGHT+IHssoFgXHAshLwCoykqESZ8hB8Wl4cPQlGpfU4zimy8eb6gdlgTpWcuViYV0ZrPt/qOzYAS X-Received: by 2002:a05:6a00:4613:b0:6e5:5857:6691 with SMTP id ko19-20020a056a00461300b006e558576691mr9181456pfb.17.1709544429222; Mon, 04 Mar 2024 01:27:09 -0800 (PST) ARC-Seal: i=2; a=rsa-sha256; t=1709544429; cv=pass; d=google.com; s=arc-20160816; b=I8fxoP6mY8fcX0f0aCeRiwtmJKUQDH6ObJAevgrJPBWaUJEJpSyVvZu00zMUqqlb40 vLh6MCUJsm9mnPMkCjs9R24BmDqIOWDNcwwt/57tevmjoUxA44/QK1wfivaZg6gjAyXv yjTJJPF7LvaN4Zswp/MtKzMyVzGLvImuSr068Ai+SqAlWzcz8UdJNw30HbagchgDSIh2 lfFbU34FBaOHtFglcAisLeRWxclm/fOeS03NfnxJ7q3SWhSQ7hZZ04sqbU+LgHg/Qe5L 4tiSI2WQFcJ5wHtLBFIRaTeVNMJlOc5ArhSMGFqOoRgJY7O4dfFH5+RdvUXZ7ObxKDHC 0IhQ== ARC-Message-Signature: i=2; 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=G51exwU2Wdegs2KTdccrTBJy4CrHy8FgHppVQA3lnk0=; fh=bmJMP5ZABTubPEgidfBiEdusydDuNG0BjCBCe+D3FK0=; b=RBRJwknqbk2XZbIjbIHAQKJH/Pxo5vLv7tTfOdSNCy3B9JGcKYx68v3pdu4cZg8zx+ ythWaVQXYLPZKPPVTh8HujzoKOMjVZfxteBXIfSThcovubDBHuhX/w45jrzUSAg9tgPs w1Z3D9URZyy41jgiiCXs4mQWaoD2w6t9NBWqipxlt7QTnNdrOYr8KzoOw0bzdAxy6PM9 mEjX6Y+q3jqYYdQ/dSq1g/v2xE+jetcpWhnpSsWS0A5I5GYzIIv9Eg+oNni6xRbmQti6 uaGBu/iy0Dr7kjLprTavuwvSMy4VxC1eF5Vzs/7RW/jiTNxjugCTpNQHvYK+Y5bGRgjI 48sg==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=UNJvdlyq; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-90298-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.48.161 as permitted sender) smtp.mailfrom="linux-kernel+bounces-90298-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 c11-20020aa781cb000000b006e53435b435si7616729pfn.391.2024.03.04.01.27.08 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 04 Mar 2024 01:27:09 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-90298-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=UNJvdlyq; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-90298-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.48.161 as permitted sender) smtp.mailfrom="linux-kernel+bounces-90298-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 5C724B2323D for ; Mon, 4 Mar 2024 09:20:09 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id C8F841DA5E; Mon, 4 Mar 2024 09:19:31 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b="UNJvdlyq" 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 2CEC512E73 for ; Mon, 4 Mar 2024 09:19:29 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=10.30.226.201 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1709543970; cv=none; b=X3lEoj9LhpNeOoeuMHc2qsKckIUvVz4UgxeiLRfQjsodKGGVCc4l4KTHBH1OVkuYtaxsJsnaVaW6G8UT+lTyDYgiHHOpmV7SnmWrCflpCFCaMq1TjFM5jmbsvMi6qLnYW+gsuqWi+ShzHPJh32wMdgzbEufClteB22z/SacWxi8= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1709543970; c=relaxed/simple; bh=JNlgBk51Owrz+9wcCIEhG6A3fzFqztbOy64rlJzeI/o=; h=Message-ID:Date:MIME-Version:Subject:To:Cc:References:From: In-Reply-To:Content-Type; b=HwWh4+vMqM4+/xTxivhXSbjAOMfFo1x74Cz61XfNTUM5SluGoMqGmdEGq4eXoFOXTQkywDML/K7sfhfAaHc5GtQR7lp1TlQHUEev0rYJsUh/xUZXroiUrpfBPPdfWtG8vMr1O9+ZpnQryGjRwiFuEGwctVWhBTHBUrf5mtWWC54= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=UNJvdlyq; arc=none smtp.client-ip=10.30.226.201 Received: by smtp.kernel.org (Postfix) with ESMTPSA id 84528C43394; Mon, 4 Mar 2024 09:19:26 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1709543969; bh=JNlgBk51Owrz+9wcCIEhG6A3fzFqztbOy64rlJzeI/o=; h=Date:Subject:To:Cc:References:From:In-Reply-To:From; b=UNJvdlyqW+CCxxtDPBP4kuooxlw4AzWFHOWV3vbc9A4J6lnNX21sMNmI4DVRLoCow i1KoooVZPs+1QVOPJd7soYdqKTZ/87f0ymw0ICCOC+W0PfKUc4Y3+mzUiAkCO20RpR lIiCCI10KYZQvd5qLRPNDsGyfw5WDxyGsNskEgRmpeTM+IQ2eMETGfO/YbuVjY6X4r z5wWtDRDCeaD3EmUspVEe1MeTng1EEl0m4wwHBAiGbT4+qqNSp64I8Fw1HNmcHtp8i vp7Vlo5b/O9gA+G/9zE6rUyCmsX7WjSFrIe5TnEL4tXu/zlJ/8qd6N6z8jZ4+ohBbn KzYf8sTpcBGFQ== Message-ID: Date: Mon, 4 Mar 2024 17:19:22 +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] f2fs: fix to check result of new_curseg in f2fs_allocate_segment_for_resize Content-Language: en-US To: Zhiguo Niu Cc: Zhiguo Niu , jaegeuk@kernel.org, linux-f2fs-devel@lists.sourceforge.net, linux-kernel@vger.kernel.org, ke.wang@unisoc.com, hongyu.jin@unisoc.com References: <1709292976-13118-1-git-send-email-zhiguo.niu@unisoc.com> <7dc371ad-2448-4dd4-9551-8caef0a00d48@kernel.org> <73197f36-4962-4a3d-a56c-8fd3494af7e5@kernel.org> From: Chao Yu In-Reply-To: Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit On 2024/3/4 15:52, Zhiguo Niu wrote: > On Mon, Mar 4, 2024 at 3:17 PM Chao Yu wrote: >> >> On 2024/3/4 11:33, Zhiguo Niu wrote: >>> On Mon, Mar 4, 2024 at 11:19 AM Chao Yu wrote: >>>> >>>> On 2024/3/1 19:36, Zhiguo Niu wrote: >>>>> new_curseg may return error if get_new_segment fail, so its result >>>>> should be check in its caller f2fs_allocate_segment_for_resize, >>>>> alos pass this results to free_segment_range. >>>> >>>> Zhiguo, >>>> >>>> What about handling all error paths of new_curseg() and change_curseg() >>>> in one patch? >>> Dear Chao, >>> >>> Do you mean to merge it with the previous patch “f2fs: fix to check >>> return value of f2fs_gc_range”? >>> Because in addition to new_curseg/change_curseg error handling, there >>> are some other changes in the previous patch. >>> besides, I searched for new related codes, and there should be the >>> only place left without error handling about new_curseg/ >>> change_curseg . >> >> Zhiguo, I meant something like this? >> >> Subject: [PATCH] f2fs: fix to handle error paths of {new,change}_curseg() > Dear Chao, > I got your meaning and I think this patch looks good. > Please ignore my patch and use your version:). Zhiguo, This is a raw patch, can you please write commit message for it, and resend it once you've tested it. Thanks, > thanks! >> >> --- >> fs/f2fs/f2fs.h | 4 +-- >> fs/f2fs/gc.c | 7 +++-- >> fs/f2fs/segment.c | 67 +++++++++++++++++++++++++++++++---------------- >> fs/f2fs/super.c | 4 ++- >> 4 files changed, 54 insertions(+), 28 deletions(-) >> >> diff --git a/fs/f2fs/f2fs.h b/fs/f2fs/f2fs.h >> index 80789255bf68..03927f1b2ea1 100644 >> --- a/fs/f2fs/f2fs.h >> +++ b/fs/f2fs/f2fs.h >> @@ -3702,10 +3702,10 @@ int f2fs_disable_cp_again(struct f2fs_sb_info *sbi, block_t unusable); >> void f2fs_release_discard_addrs(struct f2fs_sb_info *sbi); >> int f2fs_npages_for_summary_flush(struct f2fs_sb_info *sbi, bool for_ra); >> bool f2fs_segment_has_free_slot(struct f2fs_sb_info *sbi, int segno); >> -void f2fs_init_inmem_curseg(struct f2fs_sb_info *sbi); >> +int f2fs_init_inmem_curseg(struct f2fs_sb_info *sbi); >> void f2fs_save_inmem_curseg(struct f2fs_sb_info *sbi); >> void f2fs_restore_inmem_curseg(struct f2fs_sb_info *sbi); >> -void f2fs_allocate_segment_for_resize(struct f2fs_sb_info *sbi, int type, >> +int f2fs_allocate_segment_for_resize(struct f2fs_sb_info *sbi, int type, >> unsigned int start, unsigned int end); >> int f2fs_allocate_new_section(struct f2fs_sb_info *sbi, int type, bool force); >> int f2fs_allocate_pinning_section(struct f2fs_sb_info *sbi); >> diff --git a/fs/f2fs/gc.c b/fs/f2fs/gc.c >> index f8314765246a..854ad0a3f6ea 100644 >> --- a/fs/f2fs/gc.c >> +++ b/fs/f2fs/gc.c >> @@ -2033,8 +2033,11 @@ static int free_segment_range(struct f2fs_sb_info *sbi, >> mutex_unlock(&DIRTY_I(sbi)->seglist_lock); >> >> /* Move out cursegs from the target range */ >> - for (type = CURSEG_HOT_DATA; type < NR_CURSEG_PERSIST_TYPE; type++) >> - f2fs_allocate_segment_for_resize(sbi, type, start, end); >> + for (type = CURSEG_HOT_DATA; type < NR_CURSEG_PERSIST_TYPE; type++) { >> + err = f2fs_allocate_segment_for_resize(sbi, type, start, end); >> + if (err) >> + goto out; >> + } >> >> /* do GC to move out valid blocks in the range */ >> err = f2fs_gc_range(sbi, start, end, dry_run, 0); >> diff --git a/fs/f2fs/segment.c b/fs/f2fs/segment.c >> index 22241aba6564..2bcf01fde143 100644 >> --- a/fs/f2fs/segment.c >> +++ b/fs/f2fs/segment.c >> @@ -2863,7 +2863,7 @@ bool f2fs_segment_has_free_slot(struct f2fs_sb_info *sbi, int segno) >> * This function always allocates a used segment(from dirty seglist) by SSR >> * manner, so it should recover the existing segment information of valid blocks >> */ >> -static void change_curseg(struct f2fs_sb_info *sbi, int type) >> +static int change_curseg(struct f2fs_sb_info *sbi, int type) >> { >> struct dirty_seglist_info *dirty_i = DIRTY_I(sbi); >> struct curseg_info *curseg = CURSEG_I(sbi, type); >> @@ -2888,21 +2888,24 @@ static void change_curseg(struct f2fs_sb_info *sbi, int type) >> if (IS_ERR(sum_page)) { >> /* GC won't be able to use stale summary pages by cp_error */ >> memset(curseg->sum_blk, 0, SUM_ENTRY_SIZE); >> - return; >> + return PTR_ERR(sum_page); >> } >> sum_node = (struct f2fs_summary_block *)page_address(sum_page); >> memcpy(curseg->sum_blk, sum_node, SUM_ENTRY_SIZE); >> f2fs_put_page(sum_page, 1); >> + >> + return 0; >> } >> >> static int get_ssr_segment(struct f2fs_sb_info *sbi, int type, >> int alloc_mode, unsigned long long age); >> >> -static void get_atssr_segment(struct f2fs_sb_info *sbi, int type, >> +static int get_atssr_segment(struct f2fs_sb_info *sbi, int type, >> int target_type, int alloc_mode, >> unsigned long long age) >> { >> struct curseg_info *curseg = CURSEG_I(sbi, type); >> + int ret; >> >> curseg->seg_type = target_type; >> >> @@ -2910,38 +2913,45 @@ static void get_atssr_segment(struct f2fs_sb_info *sbi, int type, >> struct seg_entry *se = get_seg_entry(sbi, curseg->next_segno); >> >> curseg->seg_type = se->type; >> - change_curseg(sbi, type); >> + ret = change_curseg(sbi, type); >> } else { >> /* allocate cold segment by default */ >> curseg->seg_type = CURSEG_COLD_DATA; >> - new_curseg(sbi, type, true); >> + ret = new_curseg(sbi, type, true); >> } >> stat_inc_seg_type(sbi, curseg); >> + >> + return ret; >> } >> >> -static void __f2fs_init_atgc_curseg(struct f2fs_sb_info *sbi) >> +static int __f2fs_init_atgc_curseg(struct f2fs_sb_info *sbi) >> { >> struct curseg_info *curseg = CURSEG_I(sbi, CURSEG_ALL_DATA_ATGC); >> + int ret; >> >> if (!sbi->am.atgc_enabled) >> - return; >> + return 0; >> >> f2fs_down_read(&SM_I(sbi)->curseg_lock); >> >> mutex_lock(&curseg->curseg_mutex); >> down_write(&SIT_I(sbi)->sentry_lock); >> >> - get_atssr_segment(sbi, CURSEG_ALL_DATA_ATGC, CURSEG_COLD_DATA, SSR, 0); >> + ret = get_atssr_segment(sbi, CURSEG_ALL_DATA_ATGC, >> + CURSEG_COLD_DATA, SSR, 0); >> >> up_write(&SIT_I(sbi)->sentry_lock); >> mutex_unlock(&curseg->curseg_mutex); >> >> f2fs_up_read(&SM_I(sbi)->curseg_lock); >> >> + return ret; >> + >> } >> -void f2fs_init_inmem_curseg(struct f2fs_sb_info *sbi) >> + >> +int f2fs_init_inmem_curseg(struct f2fs_sb_info *sbi) >> { >> - __f2fs_init_atgc_curseg(sbi); >> + return __f2fs_init_atgc_curseg(sbi); >> } >> >> static void __f2fs_save_inmem_curseg(struct f2fs_sb_info *sbi, int type) >> @@ -3069,11 +3079,12 @@ static bool need_new_seg(struct f2fs_sb_info *sbi, int type) >> return false; >> } >> >> -void f2fs_allocate_segment_for_resize(struct f2fs_sb_info *sbi, int type, >> +int f2fs_allocate_segment_for_resize(struct f2fs_sb_info *sbi, int type, >> unsigned int start, unsigned int end) >> { >> struct curseg_info *curseg = CURSEG_I(sbi, type); >> unsigned int segno; >> + int ret = 0; >> >> f2fs_down_read(&SM_I(sbi)->curseg_lock); >> mutex_lock(&curseg->curseg_mutex); >> @@ -3084,9 +3095,9 @@ void f2fs_allocate_segment_for_resize(struct f2fs_sb_info *sbi, int type, >> goto unlock; >> >> if (f2fs_need_SSR(sbi) && get_ssr_segment(sbi, type, SSR, 0)) >> - change_curseg(sbi, type); >> + ret = change_curseg(sbi, type); >> else >> - new_curseg(sbi, type, true); >> + ret = new_curseg(sbi, type, true); >> >> stat_inc_seg_type(sbi, curseg); >> >> @@ -3100,6 +3111,8 @@ void f2fs_allocate_segment_for_resize(struct f2fs_sb_info *sbi, int type, >> >> mutex_unlock(&curseg->curseg_mutex); >> f2fs_up_read(&SM_I(sbi)->curseg_lock); >> + >> + return ret; >> } >> >> static int __allocate_new_segment(struct f2fs_sb_info *sbi, int type, >> @@ -3107,6 +3120,7 @@ static int __allocate_new_segment(struct f2fs_sb_info *sbi, int type, >> { >> struct curseg_info *curseg = CURSEG_I(sbi, type); >> unsigned int old_segno; >> + int ret; >> >> if (type == CURSEG_COLD_DATA_PINNED && !curseg->inited) >> goto allocate; >> @@ -3119,8 +3133,9 @@ static int __allocate_new_segment(struct f2fs_sb_info *sbi, int type, >> >> allocate: >> old_segno = curseg->segno; >> - if (new_curseg(sbi, type, true)) >> - return -EAGAIN; >> + ret = new_curseg(sbi, type, true); >> + if (ret) >> + return ret; >> stat_inc_seg_type(sbi, curseg); >> locate_dirty_segment(sbi, old_segno); >> return 0; >> @@ -3480,14 +3495,17 @@ int f2fs_allocate_data_block(struct f2fs_sb_info *sbi, struct page *page, >> bool from_gc = (type == CURSEG_ALL_DATA_ATGC); >> struct seg_entry *se = NULL; >> bool segment_full = false; >> + int ret = 0; >> >> f2fs_down_read(&SM_I(sbi)->curseg_lock); >> >> mutex_lock(&curseg->curseg_mutex); >> down_write(&sit_i->sentry_lock); >> >> - if (curseg->segno == NULL_SEGNO) >> + if (curseg->segno == NULL_SEGNO) { >> + ret = -ENOSPC; >> goto out_err; >> + } >> >> if (from_gc) { >> f2fs_bug_on(sbi, GET_SEGNO(sbi, old_blkaddr) == NULL_SEGNO); >> @@ -3541,17 +3559,17 @@ int f2fs_allocate_data_block(struct f2fs_sb_info *sbi, struct page *page, >> } >> >> if (from_gc) { >> - get_atssr_segment(sbi, type, se->type, >> + ret = get_atssr_segment(sbi, type, se->type, >> AT_SSR, se->mtime); >> } else { >> if (need_new_seg(sbi, type)) >> - new_curseg(sbi, type, false); >> + ret = new_curseg(sbi, type, false); >> else >> - change_curseg(sbi, type); >> + ret = change_curseg(sbi, type); >> stat_inc_seg_type(sbi, curseg); >> } >> >> - if (curseg->segno == NULL_SEGNO) >> + if (ret) >> goto out_err; >> } >> >> @@ -3594,7 +3612,7 @@ int f2fs_allocate_data_block(struct f2fs_sb_info *sbi, struct page *page, >> up_write(&sit_i->sentry_lock); >> mutex_unlock(&curseg->curseg_mutex); >> f2fs_up_read(&SM_I(sbi)->curseg_lock); >> - return -ENOSPC; >> + return ret; >> >> } >> >> @@ -3824,7 +3842,8 @@ void f2fs_do_replace_block(struct f2fs_sb_info *sbi, struct f2fs_summary *sum, >> /* change the current segment */ >> if (segno != curseg->segno) { >> curseg->next_segno = segno; >> - change_curseg(sbi, type); >> + if (change_curseg(sbi, type)) >> + goto out_unlock; >> } >> >> curseg->next_blkoff = GET_BLKOFF_FROM_SEG0(sbi, new_blkaddr); >> @@ -3850,12 +3869,14 @@ void f2fs_do_replace_block(struct f2fs_sb_info *sbi, struct f2fs_summary *sum, >> if (recover_curseg) { >> if (old_cursegno != curseg->segno) { >> curseg->next_segno = old_cursegno; >> - change_curseg(sbi, type); >> + if (change_curseg(sbi, type)) >> + goto out_unlock; >> } >> curseg->next_blkoff = old_blkoff; >> curseg->alloc_type = old_alloc_type; >> } >> >> +out_unlock: >> up_write(&sit_i->sentry_lock); >> mutex_unlock(&curseg->curseg_mutex); >> f2fs_up_write(&SM_I(sbi)->curseg_lock); >> diff --git a/fs/f2fs/super.c b/fs/f2fs/super.c >> index 0676c2dcbbf7..8c69257db8cc 100644 >> --- a/fs/f2fs/super.c >> +++ b/fs/f2fs/super.c >> @@ -4691,7 +4691,9 @@ static int f2fs_fill_super(struct super_block *sb, void *data, int silent) >> if (err) >> goto free_meta; >> >> - f2fs_init_inmem_curseg(sbi); >> + err = f2fs_init_inmem_curseg(sbi); >> + if (err) >> + goto sync_free_meta; >> >> /* f2fs_recover_fsync_data() cleared this already */ >> clear_sbi_flag(sbi, SBI_POR_DOING); >> -- >> 2.40.1 >> >> >> >>> >>> thanks! >>>> >>>> Thanks, >>>> >>>>> >>>>> Signed-off-by: Zhiguo Niu >>>>> --- >>>>> fs/f2fs/f2fs.h | 2 +- >>>>> fs/f2fs/gc.c | 7 +++++-- >>>>> fs/f2fs/segment.c | 9 +++++++-- >>>>> 3 files changed, 13 insertions(+), 5 deletions(-) >>>>> >>>>> diff --git a/fs/f2fs/f2fs.h b/fs/f2fs/f2fs.h >>>>> index 4331012..39dda7d 100644 >>>>> --- a/fs/f2fs/f2fs.h >>>>> +++ b/fs/f2fs/f2fs.h >>>>> @@ -3701,7 +3701,7 @@ void f2fs_clear_prefree_segments(struct f2fs_sb_info *sbi, >>>>> void f2fs_init_inmem_curseg(struct f2fs_sb_info *sbi); >>>>> void f2fs_save_inmem_curseg(struct f2fs_sb_info *sbi); >>>>> void f2fs_restore_inmem_curseg(struct f2fs_sb_info *sbi); >>>>> -void f2fs_allocate_segment_for_resize(struct f2fs_sb_info *sbi, int type, >>>>> +int f2fs_allocate_segment_for_resize(struct f2fs_sb_info *sbi, int type, >>>>> unsigned int start, unsigned int end); >>>>> int f2fs_allocate_new_section(struct f2fs_sb_info *sbi, int type, bool force); >>>>> int f2fs_allocate_pinning_section(struct f2fs_sb_info *sbi); >>>>> diff --git a/fs/f2fs/gc.c b/fs/f2fs/gc.c >>>>> index c60b747..7a458fa 100644 >>>>> --- a/fs/f2fs/gc.c >>>>> +++ b/fs/f2fs/gc.c >>>>> @@ -2037,8 +2037,11 @@ static int free_segment_range(struct f2fs_sb_info *sbi, >>>>> mutex_unlock(&DIRTY_I(sbi)->seglist_lock); >>>>> >>>>> /* Move out cursegs from the target range */ >>>>> - for (type = CURSEG_HOT_DATA; type < NR_CURSEG_PERSIST_TYPE; type++) >>>>> - f2fs_allocate_segment_for_resize(sbi, type, start, end); >>>>> + for (type = CURSEG_HOT_DATA; type < NR_CURSEG_PERSIST_TYPE; type++) { >>>>> + err = f2fs_allocate_segment_for_resize(sbi, type, start, end); >>>>> + if (err) >>>>> + goto out; >>>>> + } >>>>> >>>>> /* do GC to move out valid blocks in the range */ >>>>> err = f2fs_gc_range(sbi, start, end, dry_run, 0); >>>>> diff --git a/fs/f2fs/segment.c b/fs/f2fs/segment.c >>>>> index 1bb3019..2a07b9d 100644 >>>>> --- a/fs/f2fs/segment.c >>>>> +++ b/fs/f2fs/segment.c >>>>> @@ -3071,11 +3071,12 @@ static bool need_new_seg(struct f2fs_sb_info *sbi, int type) >>>>> return false; >>>>> } >>>>> >>>>> -void f2fs_allocate_segment_for_resize(struct f2fs_sb_info *sbi, int type, >>>>> +int f2fs_allocate_segment_for_resize(struct f2fs_sb_info *sbi, int type, >>>>> unsigned int start, unsigned int end) >>>>> { >>>>> struct curseg_info *curseg = CURSEG_I(sbi, type); >>>>> unsigned int segno; >>>>> + int err = 0; >>>>> >>>>> f2fs_down_read(&SM_I(sbi)->curseg_lock); >>>>> mutex_lock(&curseg->curseg_mutex); >>>>> @@ -3089,7 +3090,10 @@ void f2fs_allocate_segment_for_resize(struct f2fs_sb_info *sbi, int type, >>>>> change_curseg(sbi, type); >>>>> else >>>>> new_curseg(sbi, type, true); >>>>> - >>>>> + if (curseg->segno == NULL_SEGNO) { >>>>> + err = -ENOSPC; >>>>> + goto unlock; >>>>> + } >>>>> stat_inc_seg_type(sbi, curseg); >>>>> >>>>> locate_dirty_segment(sbi, segno); >>>>> @@ -3102,6 +3106,7 @@ void f2fs_allocate_segment_for_resize(struct f2fs_sb_info *sbi, int type, >>>>> >>>>> mutex_unlock(&curseg->curseg_mutex); >>>>> f2fs_up_read(&SM_I(sbi)->curseg_lock); >>>>> + return err; >>>>> } >>>>> >>>>> static int __allocate_new_segment(struct f2fs_sb_info *sbi, int type,