Received: by 2002:a05:6358:16cc:b0:ea:6187:17c9 with SMTP id r12csp10272835rwl; Wed, 11 Jan 2023 17:31:43 -0800 (PST) X-Google-Smtp-Source: AMrXdXsZLSRjxMMemTLI9R6zGtfX4vhZfFDKCeeGtAmaIVJDxaOA5hRYm1v4c9VXau9bgzYBHng/ X-Received: by 2002:a05:6a20:3d1a:b0:a4:b2e4:c561 with SMTP id y26-20020a056a203d1a00b000a4b2e4c561mr109229357pzi.51.1673487102852; Wed, 11 Jan 2023 17:31:42 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1673487102; cv=none; d=google.com; s=arc-20160816; b=LCiFpHyspcLHOUqOr9nLIL+xcLW8OIXoZN0ywlNz8PZ105t5esnF9BxHXx0gc19zUd +5bY6DYQhY7dUZTalUfvqTLm5Z1QlrB0MG+KgNWQ8FUT7P7BD6PL9J+iqUhChysCzJDB uK/iy1U+lbT4HkPLMA5dy6eVTgKVP3c4puqYYpCrW4rqatAVNrosgb41o/CFGu6f3RdW kgabeKMpG1VklVkkXW6bJjCSOp72iZMR4gav8cemCCz/w8ydKFMsvCj89Hj0k1NKHJRC cbZ5FD5Ai+IfaSYzZ/XjVxfLj32gEmmCXfB7AQuXGNKZy+yoXMTLRwoozkaCzEQn+dbZ nA+g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-language:content-transfer-encoding :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject; bh=gcFCHb6eOs75OG4HFDK9f7pUNPI9o/08SynyT91hPRw=; b=g4fB+0eo9TUg0q38LwLn7ogm9noq4ZY+STdGDvJpiaCRDT7JdWbJBicW3q9fBJL0vX ly2vb6tqIurWV6LCUUFj0PnifqSvuLJOy/8lkgIkr9ezudgeg4gxDDrLFqNO0YrEzxE4 cSDUhYdJDDgznaY3hK5mBzpl4xolQwEbxQThJSuyZulW4ZNGPOtgTOl/YFfuCmuFKb2G 3YDDu8KFdV1lco8N5T/Ftb8N4xopACkzZJ79j9KzlkMTtCRbeGv9Nc/MKovMTL0u9ALp ax1Cwx8WifJTCxnonDuvjx9WcUD0LQ6Spf5Hk3co8P1+2X7yScM5yD13mD5X3J3jLGhR Cj5A== 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 p3-20020a17090a868300b00219fb3f72bbsi15501758pjn.172.2023.01.11.17.31.36; Wed, 11 Jan 2023 17:31:42 -0800 (PST) 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 S235039AbjALBHl (ORCPT + 50 others); Wed, 11 Jan 2023 20:07:41 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:44224 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234975AbjALBHj (ORCPT ); Wed, 11 Jan 2023 20:07:39 -0500 Received: from dggsgout11.his.huawei.com (dggsgout11.his.huawei.com [45.249.212.51]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 9CE5C11C2C for ; Wed, 11 Jan 2023 17:07:38 -0800 (PST) Received: from mail02.huawei.com (unknown [172.30.67.153]) by dggsgout11.his.huawei.com (SkyGuard) with ESMTP id 4NsmcN64PTz4f3k6B for ; Thu, 12 Jan 2023 09:07:32 +0800 (CST) Received: from [10.174.176.117] (unknown [10.174.176.117]) by APP4 (Coremail) with SMTP id gCh0CgDXP7NUXb9j77E5Bg--.63722S2; Thu, 12 Jan 2023 09:07:35 +0800 (CST) Subject: Re: [PATCH v2 2/2] fscache: Add the missing smp_mb__after_atomic() before wake_up_bit() To: David Howells Cc: linux-cachefs@redhat.com, Jeff Layton , linux-erofs@lists.ozlabs.org, linux-kernel@vger.kernel.org, Jingbo Xu , houtao1@huawei.com References: <20221226103309.953112-3-houtao@huaweicloud.com> <20221226103309.953112-1-houtao@huaweicloud.com> <2431994.1673453386@warthog.procyon.org.uk> From: Hou Tao Message-ID: Date: Thu, 12 Jan 2023 09:07:32 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:78.0) Gecko/20100101 Thunderbird/78.6.0 MIME-Version: 1.0 In-Reply-To: <2431994.1673453386@warthog.procyon.org.uk> Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 7bit Content-Language: en-US X-CM-TRANSID: gCh0CgDXP7NUXb9j77E5Bg--.63722S2 X-Coremail-Antispam: 1UD129KBjvdXoWrZF4rAF15Zr1ftr1rCr1kuFg_yoW3KFb_CF ZYvFZYkw47W3WDK3WUtr1Sqa1xKr18C3Z3trZrJrZ7tr4xZ39IkFn7WryI9F1xG3s7KF43 A34UWF4vyw13CjkaLaAFLSUrUUUUUb8apTn2vfkv8UJUUUU8Yxn0WfASr-VFAUDa7-sFnT 9fnUUIcSsGvfJTRUUUbzAYFVCjjxCrM7AC8VAFwI0_Gr0_Xr1l1xkIjI8I6I8E6xAIw20E Y4v20xvaj40_Wr0E3s1l1IIY67AEw4v_Jr0_Jr4l8cAvFVAK0II2c7xJM28CjxkF64kEwV A0rcxSw2x7M28EF7xvwVC0I7IYx2IY67AKxVWDJVCq3wA2z4x0Y4vE2Ix0cI8IcVCY1x02 67AKxVW8Jr0_Cr1UM28EF7xvwVC2z280aVAFwI0_GcCE3s1l84ACjcxK6I8E87Iv6xkF7I 0E14v26rxl6s0DM2AIxVAIcxkEcVAq07x20xvEncxIr21l5I8CrVACY4xI64kE6c02F40E x7xfMcIj6xIIjxv20xvE14v26r106r15McIj6I8E87Iv67AKxVWUJVW8JwAm72CE4IkC6x 0Yz7v_Jr0_Gr1lF7xvr2IY64vIr41lc7I2V7IY0VAS07AlzVAYIcxG8wCF04k20xvY0x0E wIxGrwCFx2IqxVCFs4IE7xkEbVWUJVW8JwC20s026c02F40E14v26r1j6r18MI8I3I0E74 80Y4vE14v26r106r1rMI8E67AF67kF1VAFwI0_JF0_Jw1lIxkGc2Ij64vIr41lIxAIcVC0 I7IYx2IY67AKxVWUJVWUCwCI42IY6xIIjxv20xvEc7CjxVAFwI0_Gr0_Cr1lIxAIcVCF04 k26cxKx2IYs7xG6Fyj6rWUJwCI42IY6I8E87Iv67AKxVWUJVW8JwCI42IY6I8E87Iv6xkF 7I0E14v26r4j6r4UJbIYCTnIWIevJa73UjIFyTuYvjxUOyCJDUUUU X-CM-SenderInfo: xkrx3t3r6k3tpzhluzxrxghudrp/ X-CFilter-Loop: Reflected X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00,NICE_REPLY_A, SPF_HELO_NONE,SPF_PASS 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 Hi, On 1/12/2023 12:09 AM, David Howells wrote: > Hou Tao wrote: > >> fscache_create_volume_work() uses wake_up_bit() to wake up the processes >> which are waiting for the completion of volume creation. According to >> comments in wake_up_bit() and waitqueue_active(), an extra smp_mb() is >> needed to guarantee the memory order between FSCACHE_VOLUME_CREATING >> flag and waitqueue_active() before invoking wake_up_bit(). > What two values are you ordering? > > If we're using this to create a critical section, then yes, we would need a > barrier to order the changes inside the critical section before changing the > memory location that forms the lock - but this is not a critical section. It is similar with patch #1. The smp_mb() is used for order between volume->flags and wq->head. > David >