Received: by 2002:a5d:925a:0:0:0:0:0 with SMTP id e26csp730110iol; Thu, 9 Jun 2022 12:43:14 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxRLdBHiXoVQKbjy4kt6/W6SBhGPmUS1h0AQUNuVt5mLEXl36wNujT6bWrzAzDIdTFzEg4D X-Received: by 2002:aa7:c444:0:b0:42d:d1d9:e4d8 with SMTP id n4-20020aa7c444000000b0042dd1d9e4d8mr47526737edr.145.1654803794132; Thu, 09 Jun 2022 12:43:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1654803794; cv=none; d=google.com; s=arc-20160816; b=gCK9sgpfUPcwanz56iEthQlFbGe7EXQESIgjvlyl8FIDQ4LtuHoclDB+Y1FFizgS1o Kh8ixHzYatefDxu9EdAAlMx1c6heyY2TA75ibPehAkAYicYZUcriBoa+5Bvzqx8C51LV I7gn0wI0oGkA+cUfSKXNSDadB+k+rr+tfvWcJiBMkAMSbe3jOCMJjYhH0OQOiLCbMw7n +ghswgzMptmp1KiRoM4448UczD6ixs9ddlIV1MD9Iw3vhwuWswftSnA0GZum2pmxjmcZ dvF4IrUO7+Yft7GO9epmHPpzVAprT4te8fyTvK0Crj6qLDX4z7N5nbU5HVBwpGxFZFpN d3jA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:user-agent:message-id:in-reply-to :date:references:subject:cc:to:from; bh=s4OCh5tHvdu2Gcu3V1PyTQfV/G0IfdAzqzEyaVCNsoE=; b=FG/tMaSKs54bcqkyD9BdROlbCWbnM1eERByg23oVdqqtI4Ntj+iHUYjHipS2Rq0N8L M+7HMH9ipXb8gtEyKg7L6pzQmagk8FLaAVLLvjfZjBhyltjDSwEgecjSs3uyaqzYG66y 0FzsxPni9U+Qtfm1Cncxhc9IcHydt8iiX5+dTZ4oajNhXvXuUK1hl6/SkooN2qMgVtN3 yeHMXAPGc9Y9dbZyCNyfsMNmiSOCb5PXWk4TDzECj3SnVs2Gy22097KrYuAKMPlhhEFI nZBdrc+x+DMbMgqk8VoYRj1pUYT8lgbIQZIwSbXbNqSVd+pkdt2LGRT8hab/XNjLHG4c SXIw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id 30-20020a170906209e00b00711fe0e94d3si4706376ejq.524.2022.06.09.12.42.47; Thu, 09 Jun 2022 12:43:14 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232738AbiFITRq (ORCPT + 99 others); Thu, 9 Jun 2022 15:17:46 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:54952 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229716AbiFITRp (ORCPT ); Thu, 9 Jun 2022 15:17:45 -0400 Received: from mail.parknet.co.jp (mail.parknet.co.jp [210.171.160.6]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 8C18C113A0A for ; Thu, 9 Jun 2022 12:17:43 -0700 (PDT) Received: from ibmpc.myhome.or.jp (server.parknet.ne.jp [210.171.168.39]) by mail.parknet.co.jp (Postfix) with ESMTPSA id 9C5AA2055F9A; Fri, 10 Jun 2022 04:17:41 +0900 (JST) Received: from devron.myhome.or.jp (foobar@devron.myhome.or.jp [192.168.0.3]) by ibmpc.myhome.or.jp (8.16.1/8.16.1/Debian-3) with ESMTPS id 259JHdn0009472 (version=TLSv1.3 cipher=TLS_AES_256_GCM_SHA384 bits=256 verify=NOT); Fri, 10 Jun 2022 04:17:40 +0900 Received: from devron.myhome.or.jp (foobar@localhost [127.0.0.1]) by devron.myhome.or.jp (8.16.1/8.16.1/Debian-3) with ESMTPS id 259JHdMq066467 (version=TLSv1.3 cipher=TLS_AES_256_GCM_SHA384 bits=256 verify=NOT); Fri, 10 Jun 2022 04:17:39 +0900 Received: (from hirofumi@localhost) by devron.myhome.or.jp (8.16.1/8.16.1/Submit) id 259JHcxC066466; Fri, 10 Jun 2022 04:17:38 +0900 From: OGAWA Hirofumi To: Javier Martinez Canillas Cc: linux-kernel@vger.kernel.org, Peter Jones , Alexander Larsson , Colin Walters , Alberto Ruiz , Muhammad Usama Anjum , Lennart Poettering , Chung-Chiang Cheng , Christian Kellner , Carlos Maiolino Subject: Re: [PATCH v5 3/4] fat: add renameat2 RENAME_EXCHANGE flag support References: <20220609093638.664034-1-javierm@redhat.com> <20220609093638.664034-4-javierm@redhat.com> Date: Fri, 10 Jun 2022 04:17:38 +0900 In-Reply-To: <20220609093638.664034-4-javierm@redhat.com> (Javier Martinez Canillas's message of "Thu, 9 Jun 2022 11:36:36 +0200") Message-ID: <878rq54pf1.fsf@mail.parknet.co.jp> User-Agent: Gnus/5.13 (Gnus v5.13) Emacs/29.0.50 (gnu/linux) MIME-Version: 1.0 Content-Type: text/plain X-Spam-Status: No, score=-2.6 required=5.0 tests=BAYES_00,RCVD_IN_DNSWL_LOW, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Javier Martinez Canillas writes: > +static void vfat_update_nlink(struct inode *dir, struct inode *inode) > +{ > + if (S_ISDIR(inode->i_mode)) > + drop_nlink(dir); > + else > + inc_nlink(dir); > +} [...] > + vfat_update_dir_metadata(old_dir, &ts); > + /* if directories are not the same, update new_dir as well */ > + if (old_dir != new_dir) { > + vfat_update_dir_metadata(new_dir, &ts); > + /* nlink only needs to be updated if the file types differ */ > + if (old_inode->i_mode != new_inode->i_mode) { > + vfat_update_nlink(old_dir, old_inode); > + vfat_update_nlink(new_dir, new_inode); > + } > + } Looks like unnecessary complex (and comparing raw i_mode, not S_ISDIR(), better to change before make dir dirty). How about this change, it is only tested slightly though? Can you review and test? Thanks. -- OGAWA Hirofumi Signed-off-by: OGAWA Hirofumi --- fs/fat/namei_vfat.c | 25 ++++++++++++------------- 1 file changed, 12 insertions(+), 13 deletions(-) diff --git a/fs/fat/namei_vfat.c b/fs/fat/namei_vfat.c index c30f829..3aef834 100644 --- a/fs/fat/namei_vfat.c 2022-06-10 03:33:40.334212176 +0900 +++ b/fs/fat/namei_vfat.c 2022-06-10 04:11:30.817064192 +0900 @@ -1055,12 +1055,10 @@ static void vfat_exchange_ipos(struct in fat_attach(new_inode, old_i_pos); } -static void vfat_update_nlink(struct inode *dir, struct inode *inode) +static void vfat_move_nlink(struct inode *src, struct inode *dst) { - if (S_ISDIR(inode->i_mode)) - drop_nlink(dir); - else - inc_nlink(dir); + drop_nlink(src); + inc_nlink(dst); } static int vfat_rename_exchange(struct inode *old_dir, struct dentry *old_dentry, @@ -1112,7 +1110,6 @@ static int vfat_rename_exchange(struct i if (err) goto error_old_dotdot; } - if (new_dotdot_de) { err = vfat_update_dotdot_de(old_dir, new_inode, new_dotdot_bh, new_dotdot_de); @@ -1120,16 +1117,18 @@ static int vfat_rename_exchange(struct i goto error_new_dotdot; } + /* if cross directory and only one is a directory, adjust nlink */ + if (!old_dotdot_de != !new_dotdot_de) { + if (old_dotdot_de) + vfat_move_nlink(old_dir, new_dir); + else + vfat_move_nlink(new_dir, old_dir); + } + vfat_update_dir_metadata(old_dir, &ts); /* if directories are not the same, update new_dir as well */ - if (old_dir != new_dir) { + if (old_dir != new_dir) vfat_update_dir_metadata(new_dir, &ts); - /* nlink only needs to be updated if the file types differ */ - if (old_inode->i_mode != new_inode->i_mode) { - vfat_update_nlink(old_dir, old_inode); - vfat_update_nlink(new_dir, new_inode); - } - } out: brelse(old_dotdot_bh); _