Received: by 2002:ad5:4acb:0:0:0:0:0 with SMTP id n11csp5026160imw; Tue, 19 Jul 2022 19:06:52 -0700 (PDT) X-Google-Smtp-Source: AGRyM1vfhNGOAEkdpiymS2JRk0psvI5rP9Uw+DtPq2AnBsKWX+ENV+xJt0+3iZbyldcBRBZxe9st X-Received: by 2002:a17:906:cc11:b0:72b:458e:5d45 with SMTP id ml17-20020a170906cc1100b0072b458e5d45mr33248702ejb.589.1658282812664; Tue, 19 Jul 2022 19:06:52 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1658282812; cv=none; d=google.com; s=arc-20160816; b=X/oEghJYa7ytRmsRbt4b4XSJsK7mQ8Dbb9Jt/9APlzXK0KzPeH8k97HZiNn/fWI8/v kUUFE6ENCj6GHjsDB0RVR6Z7D8zgYFs/ak35DJTkw5ZwZuePR9RnVXiU8PWvXmNMHhGn mcrRirYSowUbtftqs98ioFCTRPKYzfiUpIR+jNG+XDYIP42VXVJwj121r667L1vCUtEU JuLG3HddEAI17Oh3dmWhMzQQfbbFEajoP0hnG33czJ/t4H2C9xrldhoJRNTgR6t1J6Vx F8q9RQ9waIOS8mxtAGWHpF5cr3HxrRpjawnWQ1QM+i6XRfRD49ZaHEl0v8aYxY3Pbwbi H4sQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id; bh=NX05cMqeeRAjpr07tXqn3kw6n+fnuv50nH8MNujYiTk=; b=w1d1b5yWMeV3QGseI/0QePpjyzTfcP7V5vDjVQ2t4WAPT4ZDT/UNzMm9c2gOXhP0pG yXs8mbUEeNR7yFzrzhPURTkwzk+IhttOvfoj8GO95i0zQSY/n7P50M2NMikZEB1jKFoW NNQl6sxnIyzfNSlxCFrlbrjOclcfJBYKkoOIaqDnm+6oI/EP3GRj0NVMB1xknfpG+B26 FdLYK9elkPJDF34W/mhjS6icD+IR0OhcnY+1Xgqd7cuARk63/9+66SZfugF1Z3LEh/2t gw+pZBhwD10uavGRkW5REFEN+x7mb2apqxvb+As49ynAZiRv3NvqqOHvRsYjyZ0TV+bn 0wCg== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id g6-20020a1709065d0600b0072f09e7093fsi17974363ejt.141.2022.07.19.19.06.26; Tue, 19 Jul 2022 19:06:52 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S238701AbiGTB7y (ORCPT + 99 others); Tue, 19 Jul 2022 21:59:54 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:53890 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232617AbiGTB7w (ORCPT ); Tue, 19 Jul 2022 21:59:52 -0400 Received: from out30-54.freemail.mail.aliyun.com (out30-54.freemail.mail.aliyun.com [115.124.30.54]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id D22DD501A8; Tue, 19 Jul 2022 18:59:51 -0700 (PDT) X-Alimail-AntiSpam: AC=PASS;BC=-1|-1;BR=01201311R961e4;CH=green;DM=||false|;DS=||;FP=0|-1|-1|-1|0|-1|-1|-1;HT=ay29a033018046059;MF=joseph.qi@linux.alibaba.com;NM=1;PH=DS;RN=7;SR=0;TI=SMTPD_---0VJuiYTA_1658282387; Received: from 30.227.66.165(mailfrom:joseph.qi@linux.alibaba.com fp:SMTPD_---0VJuiYTA_1658282387) by smtp.aliyun-inc.com; Wed, 20 Jul 2022 09:59:48 +0800 Message-ID: <07c924de-78bf-c993-ce73-635af71f4edd@linux.alibaba.com> Date: Wed, 20 Jul 2022 09:59:47 +0800 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.15; rv:91.0) Gecko/20100101 Thunderbird/91.11.0 Subject: Re: [PATCH 2/3] ocfs2: Remove a useless spinlock Content-Language: en-US To: Christophe JAILLET , David Laight , Mark Fasheh , Joel Becker Cc: "linux-kernel@vger.kernel.org" , "kernel-janitors@vger.kernel.org" , "ocfs2-devel@oss.oracle.com" References: <8ba7004d330cbe5f626539a8a3bff696d0c4285e.1658224839.git.christophe.jaillet@wanadoo.fr> <7b644e5d32d74d3d90dfc5b1786ae5b9@AcuMS.aculab.com> <29c3fbdd-7695-46c5-bb75-fe358c574ab3@wanadoo.fr> From: Joseph Qi In-Reply-To: <29c3fbdd-7695-46c5-bb75-fe358c574ab3@wanadoo.fr> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-9.9 required=5.0 tests=BAYES_00, ENV_AND_HDR_SPF_MATCH,NICE_REPLY_A,RCVD_IN_DNSWL_NONE,SPF_HELO_NONE, SPF_PASS,UNPARSEABLE_RELAY,USER_IN_DEF_SPF_WL 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 On 7/19/22 9:25 PM, Christophe JAILLET wrote: > Le 19/07/2022 à 12:24, David Laight a écrit : >> From: Christophe JAILLET >>> Sent: 19 July 2022 11:02 >>> >>> 'node_map_lock' is a spinlock only used to protect calls to set_bit(), >>> clear_bit() and test_bit(). >>> >>> {set|clear}_bit() are already atomic and don't need this extra spinlock. >>> test_bit() only reads the bitmap for a given bit. >>> >>> Remove this useless spinlock. >> >> It looks to me like the calling code is racy >> unless there is another lock in the callers. > > The call chains are: >   ocfs2_recover_orphans() >     ocfs2_mark_recovering_orphan_dir() >       spin_lock(&osb->osb_lock);        <-- osb_lock spinlock >       ocfs2_node_map_set_bit()            <-- uses node_map_lock >       ... >       spin_unlock(&osb->osb_lock); >     ... >     ocfs2_clear_recovering_orphan_dir() >       ocfs2_node_map_clear_bit()        <-- uses node_map_lock >                             osb_lock is NOT taken > > >   ocfs2_check_orphan_recovery_state() >     spin_lock(&osb->osb_lock);            <-- osb_lock spinlock >     ... >     ocfs2_node_map_test_bit()            <-- uses node_map_lock >     ... >     spin_unlock(&osb->osb_lock); > > > So the code looks already protected by the 'osb_lock' spinlock, but I don't know this code and ocfs2_mark_recovering_orphan_dir() looks tricky to me. (so some other eyes are much welcome) osb_lock is to protect osb filed such as 'osb_orphan_wipes', while node_map_lock is to protect the node map 'osb_recovering_orphan_dirs' specifically. Thanks, Joseph