Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp2116475ybt; Mon, 15 Jun 2020 19:25:52 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyp8B/TtnaPoF6fV1XEOt4H+noRtNSV7uUa4OM68/5ophCUgu4cTLGbX/moLkyOxqcyjJGD X-Received: by 2002:a17:906:7e5a:: with SMTP id z26mr702311ejr.263.1592274352361; Mon, 15 Jun 2020 19:25:52 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1592274352; cv=none; d=google.com; s=arc-20160816; b=G0JhlqREvsDiA9j0yRNlsq2nAikVq6S7eyBQtVyipbII1/frpLf3aVwg5fyYaxJ7zs yD0W2qF+Y3oblmp8OS41dcCtFuywjpcKqD3VYmlyXqit0BqyTaMCfEuZx/WOFoklGVN9 SCbNBfqMRB4n5aBzCLDAhCfUwuJGfJuZMi1XW2kapCu7n7B8sYCUWWLwstrcq6nxSr2u n11KUXNPuQ6Oj18KHACEy/veXaSWJY0ovZ+GRs54TneaKX6tuh/rZsaTbrUTxyezNylT eNgzVskG8/DOvPCsI2m/qBP0b4AhkW8cFFXoLxGymAeryPRfDKR7CCa7JCUgeQZ0oGXx bk/Q== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature; bh=zdSInKb96WROn1ZDvTb+Jk2VVDBFoWMwvWe43mu8U3E=; b=aeQNEL0prvRZ4OhhUFvW3+DFniuNEAcZfn9Bj/C3d391KBmq3OetmQHcMYU1CJM53l QzQF+2ASjc8hgi6Gd2DSugIUSeZO5b3Qi65IubOt4Cdqd0NBAotptSyc5+4PxzR27JIS k5vAFXeCKVf/fpOOcf9+l3eTu8fbSVAdGz6XYbBDJbGxJQU1rSFBhC0I/QXkTTnpU7Kh mK0hFHhgOG2pqCD49QXLi13RN4fbTnu9xs+nI3/2KYWiVDq99YN9833/HuyCDjE6bcwd /aON+uOGlQM5H5JwJL9JTfsEYkYxwwk0b8fDgpoyBabgqSeVZu6s1LmnE7G/oGVOnIEb s0iA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=IW1zKN4y; 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=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id pw8si10429406ejb.83.2020.06.15.19.25.29; Mon, 15 Jun 2020 19:25:52 -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=@gmail.com header.s=20161025 header.b=IW1zKN4y; 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=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726486AbgFPCXi (ORCPT + 99 others); Mon, 15 Jun 2020 22:23:38 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:35262 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725984AbgFPCXg (ORCPT ); Mon, 15 Jun 2020 22:23:36 -0400 Received: from mail-pg1-x542.google.com (mail-pg1-x542.google.com [IPv6:2607:f8b0:4864:20::542]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 28F44C061A0E; Mon, 15 Jun 2020 19:23:36 -0700 (PDT) Received: by mail-pg1-x542.google.com with SMTP id l63so6275408pge.12; Mon, 15 Jun 2020 19:23:36 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-language:content-transfer-encoding; bh=zdSInKb96WROn1ZDvTb+Jk2VVDBFoWMwvWe43mu8U3E=; b=IW1zKN4ysIKMSTXMzqNeZ2Qkn+iF7A36JvvbjhxrvCLDy1+ZmwfzGitTU5agPMrlAw 9wBPhESagkJqswYKA2vVAQ5umRaoVlXQs66nDYsA07E6g179AAuc14IiXq0J/2x6ALtj xplRJtUcUmvrkwdo6pFrG9jac5u287Gp1/+FcQlEF5dhOEJhsbedsVFYjWff4b2GKBjV hirWnQxcjaz9Pa1WjJwKx2hOvfRCz+nQK1KLI56IfDQ9KrOwD9enAyFzbqu22d5PJImZ 37bDtPfCnq69DKnva9HuyLy4BYqYicXQsAJJY++sWdkPoeJPmzcIfaUmpkAo+3LXq8fQ 0f3A== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=zdSInKb96WROn1ZDvTb+Jk2VVDBFoWMwvWe43mu8U3E=; b=YidSGuYvUeL/5CFnpu4WibXTtE3kOss7EYPjKDwbbtgQ74PvFq5HkMwG+Nq9IH0rdQ ACKibBBywz+cPHaL7SwBTdkoU9kCiJ6962sE4oOI5f+hNcptwbIwrTbxA7ju+dRzelsv P65vfIH3X6qC2lScTsT0JUEFT66jXqsOecpPAhN6foiyxgaZRoGJs68XMl/24wrPkJm6 Cv9t/+3d4TLJjgrIP2pUwPWRQ5j0RMUMGIrMB2sOSpydbjT4+RWGvGfnaatq7IgGvAAj vdKu4Y/NFzI2c4/KMaewHuG3grZr8b1jFptqUua/RWym1IfgvhOeGgzN4x0Y6LhKEHPU wRFQ== X-Gm-Message-State: AOAM530vnvJ1IIskfIEyMgdcPv7rmbGhBWd2cecwe5GRKVavSzf/ko3S 3L/592LCtX0h6xAyCUwvfqDSbsYOOuY= X-Received: by 2002:a65:5949:: with SMTP id g9mr417682pgu.220.1592274215203; Mon, 15 Jun 2020 19:23:35 -0700 (PDT) Received: from ?IPv6:2404:7a87:83e0:f800:b8ad:8a8d:fa4d:221e? ([2404:7a87:83e0:f800:b8ad:8a8d:fa4d:221e]) by smtp.gmail.com with ESMTPSA id q186sm15211448pfc.166.2020.06.15.19.23.32 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Mon, 15 Jun 2020 19:23:34 -0700 (PDT) Subject: Re: [PATCH v2] exfat: remove EXFAT_SB_DIRTY flag To: Sungjong Seo Cc: kohada.tetsuhiro@dc.mitsubishielectric.co.jp, mori.takahiro@ab.mitsubishielectric.co.jp, motai.hirotaka@aj.mitsubishielectric.co.jp, 'Namjae Jeon' , linux-fsdevel@vger.kernel.org, linux-kernel@vger.kernel.org References: <20200616002450.2522-1-kohada.t2@gmail.com> <2c3a01d64382$62b44880$281cd980$@samsung.com> From: Tetsuhiro Kohada Message-ID: Date: Tue, 16 Jun 2020 11:23:32 +0900 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:68.0) Gecko/20100101 Thunderbird/68.9.0 MIME-Version: 1.0 In-Reply-To: <2c3a01d64382$62b44880$281cd980$@samsung.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2020/06/16 11:03, Sungjong Seo wrote: >> remove EXFAT_SB_DIRTY flag and related codes. >> >> This flag is set/reset in exfat_put_super()/exfat_sync_fs() to avoid >> sync_blockdev(). >> However ... >> - exfat_put_super(): >> Before calling this, the VFS has already called sync_filesystem(), so sync >> is never performed here. >> - exfat_sync_fs(): >> After calling this, the VFS calls sync_blockdev(), so, it is meaningless >> to check EXFAT_SB_DIRTY or to bypass sync_blockdev() here. >> Not only that, but in some cases can't clear VOL_DIRTY. >> ex: >> VOL_DIRTY is set when rmdir starts, but when non-empty-dir is detected, >> return error without setting EXFAT_SB_DIRTY. >> If performe 'sync' in this state, VOL_DIRTY will not be cleared. >> >> Remove the EXFAT_SB_DIRTY check to ensure synchronization. >> And, remove the code related to the flag. >> >> Suggested-by: Sungjong Seo >> Signed-off-by: Tetsuhiro Kohada >> --- >> Changes in v2: >> - exfat_sync_fs() avoids synchronous processing when wait=0 >> >> fs/exfat/balloc.c | 4 ++-- >> fs/exfat/dir.c | 16 ++++++++-------- >> fs/exfat/exfat_fs.h | 5 +---- >> fs/exfat/fatent.c | 7 ++----- >> fs/exfat/misc.c | 3 +-- >> fs/exfat/namei.c | 12 ++++++------ >> fs/exfat/super.c | 14 ++++++-------- >> 7 files changed, 26 insertions(+), 35 deletions(-) >> >> diff --git a/fs/exfat/balloc.c b/fs/exfat/balloc.c index >> 4055eb00ea9b..a987919686c0 100644 >> --- a/fs/exfat/balloc.c >> +++ b/fs/exfat/balloc.c >> @@ -158,7 +158,7 @@ int exfat_set_bitmap(struct inode *inode, unsigned int >> clu) >> b = BITMAP_OFFSET_BIT_IN_SECTOR(sb, ent_idx); >> >> set_bit_le(b, sbi->vol_amap[i]->b_data); >> - exfat_update_bh(sb, sbi->vol_amap[i], IS_DIRSYNC(inode)); >> + exfat_update_bh(sbi->vol_amap[i], IS_DIRSYNC(inode)); >> return 0; >> } >> >> @@ -180,7 +180,7 @@ void exfat_clear_bitmap(struct inode *inode, unsigned >> int clu) >> b = BITMAP_OFFSET_BIT_IN_SECTOR(sb, ent_idx); >> >> clear_bit_le(b, sbi->vol_amap[i]->b_data); >> - exfat_update_bh(sb, sbi->vol_amap[i], IS_DIRSYNC(inode)); >> + exfat_update_bh(sbi->vol_amap[i], IS_DIRSYNC(inode)); >> >> if (opts->discard) { >> int ret_discard; >> diff --git a/fs/exfat/dir.c b/fs/exfat/dir.c index >> 8e775bd5d523..02acbb6ddf02 100644 >> --- a/fs/exfat/dir.c >> +++ b/fs/exfat/dir.c >> @@ -470,7 +470,7 @@ int exfat_init_dir_entry(struct inode *inode, struct >> exfat_chain *p_dir, >> &ep->dentry.file.access_date, >> NULL); >> >> - exfat_update_bh(sb, bh, IS_DIRSYNC(inode)); >> + exfat_update_bh(bh, IS_DIRSYNC(inode)); >> brelse(bh); >> >> ep = exfat_get_dentry(sb, p_dir, entry + 1, &bh, §or); @@ - >> 480,7 +480,7 @@ int exfat_init_dir_entry(struct inode *inode, struct >> exfat_chain *p_dir, >> exfat_init_stream_entry(ep, >> (type == TYPE_FILE) ? ALLOC_FAT_CHAIN : ALLOC_NO_FAT_CHAIN, >> start_clu, size); >> - exfat_update_bh(sb, bh, IS_DIRSYNC(inode)); >> + exfat_update_bh(bh, IS_DIRSYNC(inode)); >> brelse(bh); >> >> return 0; >> @@ -516,7 +516,7 @@ int exfat_update_dir_chksum(struct inode *inode, >> struct exfat_chain *p_dir, >> } >> >> fep->dentry.file.checksum = cpu_to_le16(chksum); >> - exfat_update_bh(sb, fbh, IS_DIRSYNC(inode)); >> + exfat_update_bh(fbh, IS_DIRSYNC(inode)); >> release_fbh: >> brelse(fbh); >> return ret; >> @@ -538,7 +538,7 @@ int exfat_init_ext_entry(struct inode *inode, struct >> exfat_chain *p_dir, >> return -EIO; >> >> ep->dentry.file.num_ext = (unsigned char)(num_entries - 1); >> - exfat_update_bh(sb, bh, sync); >> + exfat_update_bh(bh, sync); >> brelse(bh); >> >> ep = exfat_get_dentry(sb, p_dir, entry + 1, &bh, §or); @@ - >> 547,7 +547,7 @@ int exfat_init_ext_entry(struct inode *inode, struct >> exfat_chain *p_dir, >> >> ep->dentry.stream.name_len = p_uniname->name_len; >> ep->dentry.stream.name_hash = cpu_to_le16(p_uniname->name_hash); >> - exfat_update_bh(sb, bh, sync); >> + exfat_update_bh(bh, sync); >> brelse(bh); >> >> for (i = EXFAT_FIRST_CLUSTER; i < num_entries; i++) { @@ -556,7 >> +556,7 @@ int exfat_init_ext_entry(struct inode *inode, struct exfat_chain >> *p_dir, >> return -EIO; >> >> exfat_init_name_entry(ep, uniname); >> - exfat_update_bh(sb, bh, sync); >> + exfat_update_bh(bh, sync); >> brelse(bh); >> uniname += EXFAT_FILE_NAME_LEN; >> } >> @@ -580,7 +580,7 @@ int exfat_remove_entries(struct inode *inode, struct >> exfat_chain *p_dir, >> return -EIO; >> >> exfat_set_entry_type(ep, TYPE_DELETED); >> - exfat_update_bh(sb, bh, IS_DIRSYNC(inode)); >> + exfat_update_bh(bh, IS_DIRSYNC(inode)); >> brelse(bh); >> } >> >> @@ -610,7 +610,7 @@ void exfat_free_dentry_set(struct >> exfat_entry_set_cache *es, int sync) >> >> for (i = 0; i < es->num_bh; i++) { >> if (es->modified) >> - exfat_update_bh(es->sb, es->bh[i], sync); >> + exfat_update_bh(es->bh[i], sync); >> brelse(es->bh[i]); >> } >> kfree(es); >> diff --git a/fs/exfat/exfat_fs.h b/fs/exfat/exfat_fs.h index >> 595f3117f492..84664024e51e 100644 >> --- a/fs/exfat/exfat_fs.h >> +++ b/fs/exfat/exfat_fs.h >> @@ -13,8 +13,6 @@ >> #define EXFAT_SUPER_MAGIC 0x2011BAB0UL >> #define EXFAT_ROOT_INO 1 >> >> -#define EXFAT_SB_DIRTY 0 >> - >> #define EXFAT_CLUSTERS_UNTRACKED (~0u) >> >> /* >> @@ -238,7 +236,6 @@ struct exfat_sb_info { >> unsigned int clu_srch_ptr; /* cluster search pointer */ >> unsigned int used_clusters; /* number of used clusters */ >> >> - unsigned long s_state; >> struct mutex s_lock; /* superblock lock */ >> struct exfat_mount_options options; >> struct nls_table *nls_io; /* Charset used for input and display */ >> @@ -514,7 +511,7 @@ void exfat_set_entry_time(struct exfat_sb_info *sbi, >> struct timespec64 *ts, >> u8 *tz, __le16 *time, __le16 *date, u8 *time_cs); >> u16 exfat_calc_chksum16(void *data, int len, u16 chksum, int type); >> u32 exfat_calc_chksum32(void *data, int len, u32 chksum, int type); -void >> exfat_update_bh(struct super_block *sb, struct buffer_head *bh, int sync); >> +void exfat_update_bh(struct buffer_head *bh, int sync); >> void exfat_chain_set(struct exfat_chain *ec, unsigned int dir, >> unsigned int size, unsigned char flags); void >> exfat_chain_dup(struct exfat_chain *dup, struct exfat_chain *ec); diff -- >> git a/fs/exfat/fatent.c b/fs/exfat/fatent.c index >> 4e5c5c9c0f2d..82ee8246c080 100644 >> --- a/fs/exfat/fatent.c >> +++ b/fs/exfat/fatent.c >> @@ -75,7 +75,7 @@ int exfat_ent_set(struct super_block *sb, unsigned int >> loc, >> >> fat_entry = (__le32 *)&(bh->b_data[off]); >> *fat_entry = cpu_to_le32(content); >> - exfat_update_bh(sb, bh, sb->s_flags & SB_SYNCHRONOUS); >> + exfat_update_bh(bh, sb->s_flags & SB_SYNCHRONOUS); >> exfat_mirror_bh(sb, sec, bh); >> brelse(bh); >> return 0; >> @@ -174,7 +174,6 @@ int exfat_free_cluster(struct inode *inode, struct >> exfat_chain *p_chain) >> return -EIO; >> } >> >> - set_bit(EXFAT_SB_DIRTY, &sbi->s_state); >> clu = p_chain->dir; >> >> if (p_chain->flags == ALLOC_NO_FAT_CHAIN) { @@ -274,7 +273,7 @@ int >> exfat_zeroed_cluster(struct inode *dir, unsigned int clu) >> goto release_bhs; >> } >> memset(bhs[n]->b_data, 0, sb->s_blocksize); >> - exfat_update_bh(sb, bhs[n], 0); >> + exfat_update_bh(bhs[n], 0); >> >> n++; >> blknr++; >> @@ -358,8 +357,6 @@ int exfat_alloc_cluster(struct inode *inode, unsigned >> int num_alloc, >> } >> } >> >> - set_bit(EXFAT_SB_DIRTY, &sbi->s_state); >> - >> p_chain->dir = EXFAT_EOF_CLUSTER; >> >> while ((new_clu = exfat_find_free_bitmap(sb, hint_clu)) != diff -- >> git a/fs/exfat/misc.c b/fs/exfat/misc.c index 17d41f3d3709..8a3dde59052b >> 100644 >> --- a/fs/exfat/misc.c >> +++ b/fs/exfat/misc.c >> @@ -163,9 +163,8 @@ u32 exfat_calc_chksum32(void *data, int len, u32 >> chksum, int type) >> return chksum; >> } >> >> -void exfat_update_bh(struct super_block *sb, struct buffer_head *bh, int >> sync) >> +void exfat_update_bh(struct buffer_head *bh, int sync) >> { >> - set_bit(EXFAT_SB_DIRTY, &EXFAT_SB(sb)->s_state); >> set_buffer_uptodate(bh); >> mark_buffer_dirty(bh); >> >> diff --git a/fs/exfat/namei.c b/fs/exfat/namei.c index >> edd8023865a0..5eef2217fcf2 100644 >> --- a/fs/exfat/namei.c >> +++ b/fs/exfat/namei.c >> @@ -387,7 +387,7 @@ static int exfat_find_empty_entry(struct inode *inode, >> ep->dentry.stream.valid_size = cpu_to_le64(size); >> ep->dentry.stream.size = > ep->dentry.stream.valid_size; >> ep->dentry.stream.flags = p_dir->flags; >> - exfat_update_bh(sb, bh, IS_DIRSYNC(inode)); >> + exfat_update_bh(bh, IS_DIRSYNC(inode)); >> brelse(bh); >> if (exfat_update_dir_chksum(inode, &(ei->dir), >> ei->entry)) >> @@ -1071,7 +1071,7 @@ static int exfat_rename_file(struct inode *inode, >> struct exfat_chain *p_dir, >> epnew->dentry.file.attr |= > cpu_to_le16(ATTR_ARCHIVE); >> ei->attr |= ATTR_ARCHIVE; >> } >> - exfat_update_bh(sb, new_bh, sync); >> + exfat_update_bh(new_bh, sync); >> brelse(old_bh); >> brelse(new_bh); >> >> @@ -1087,7 +1087,7 @@ static int exfat_rename_file(struct inode *inode, >> struct exfat_chain *p_dir, >> } >> >> memcpy(epnew, epold, DENTRY_SIZE); >> - exfat_update_bh(sb, new_bh, sync); >> + exfat_update_bh(new_bh, sync); >> brelse(old_bh); >> brelse(new_bh); >> >> @@ -1104,7 +1104,7 @@ static int exfat_rename_file(struct inode *inode, >> struct exfat_chain *p_dir, >> epold->dentry.file.attr |= > cpu_to_le16(ATTR_ARCHIVE); >> ei->attr |= ATTR_ARCHIVE; >> } >> - exfat_update_bh(sb, old_bh, sync); >> + exfat_update_bh(old_bh, sync); >> brelse(old_bh); >> ret = exfat_init_ext_entry(inode, p_dir, oldentry, >> num_new_entries, p_uniname); >> @@ -1159,7 +1159,7 @@ static int exfat_move_file(struct inode *inode, >> struct exfat_chain *p_olddir, >> epnew->dentry.file.attr |= cpu_to_le16(ATTR_ARCHIVE); >> ei->attr |= ATTR_ARCHIVE; >> } >> - exfat_update_bh(sb, new_bh, IS_DIRSYNC(inode)); >> + exfat_update_bh(new_bh, IS_DIRSYNC(inode)); >> brelse(mov_bh); >> brelse(new_bh); >> >> @@ -1175,7 +1175,7 @@ static int exfat_move_file(struct inode *inode, >> struct exfat_chain *p_olddir, >> } >> >> memcpy(epnew, epmov, DENTRY_SIZE); >> - exfat_update_bh(sb, new_bh, IS_DIRSYNC(inode)); >> + exfat_update_bh(new_bh, IS_DIRSYNC(inode)); >> brelse(mov_bh); >> brelse(new_bh); >> >> diff --git a/fs/exfat/super.c b/fs/exfat/super.c index >> e650e65536f8..49804d369b51 100644 >> --- a/fs/exfat/super.c >> +++ b/fs/exfat/super.c >> @@ -45,9 +45,6 @@ static void exfat_put_super(struct super_block *sb) >> struct exfat_sb_info *sbi = EXFAT_SB(sb); >> >> mutex_lock(&sbi->s_lock); >> - if (test_and_clear_bit(EXFAT_SB_DIRTY, &sbi->s_state)) >> - sync_blockdev(sb->s_bdev); >> - exfat_set_vol_flags(sb, VOL_CLEAN); >> exfat_free_bitmap(sbi); >> brelse(sbi->boot_bh); >> mutex_unlock(&sbi->s_lock); >> @@ -60,13 +57,14 @@ static int exfat_sync_fs(struct super_block *sb, int >> wait) >> struct exfat_sb_info *sbi = EXFAT_SB(sb); >> int err = 0; >> >> + if (!wait) >> + return; > > Need to return 0. I'm sorry. Reconsider the check before posting. >> + >> /* If there are some dirty buffers in the bdev inode */ >> mutex_lock(&sbi->s_lock); >> - if (test_and_clear_bit(EXFAT_SB_DIRTY, &sbi->s_state)) { >> - sync_blockdev(sb->s_bdev); >> - if (exfat_set_vol_flags(sb, VOL_CLEAN)) >> - err = -EIO; >> - } >> + sync_blockdev(sb->s_bdev); >> + if (exfat_set_vol_flags(sb, VOL_CLEAN)) >> + err = -EIO; >> mutex_unlock(&sbi->s_lock); >> return err; >> } >> -- >> 2.25.1 > >