Received: by 2002:a05:6602:18e:0:0:0:0 with SMTP id m14csp4014433ioo; Wed, 25 May 2022 12:53:08 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxLoOY6SudRihQrV+8T5fA3hnhSX82LoWM5SaMiE1FM25ZYBBuIPVofVEsUULvdJnLuDJAm X-Received: by 2002:aa7:ccd2:0:b0:42b:cd46:c62d with SMTP id y18-20020aa7ccd2000000b0042bcd46c62dmr3813145edt.141.1653508388083; Wed, 25 May 2022 12:53:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1653508388; cv=none; d=google.com; s=arc-20160816; b=pJNhkqNcPr2TqKWZ+yYC7vKcuegwpHpGFawSSzkZFwv2MbEWWHUoAbC6eRFnXHRqrR nYIF4f8hxp6/7g1cZAByDQ9vDe70CwW7cdVr+n3XmxEEL4AcGBe7teJai4iDUMLHQh+U 0OWSvczuNkT7TTqeNe/R0n9kLlg8/ZHWGLCkF0YL2ib9YMXb5I5x5H/xZBFkc4Msirb1 zMh9wmNdY90C0Dxch2jmaG3nZD5TkD+f24FOvw5jOCtgktZsqTwXQmuWA7/5+KlRByJO jZBSdO4JTcbJTReDMQ2Y3uZfvkjJDaeMQd6F0L2FlrbcKPi0D+cQ4zSTM8YDYUPLSP9h 9crQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:message-id:date:subject:cc:to:from :dkim-signature; bh=s+X9BdhgymZkGEs6XYAhxZ8YaW7Mc7cLeWf6UbB+AxA=; b=ckbr65oqNRkkISvM3DUoD08M2NPaaf7lsgFzAR1ZFv5wmRTt+Fg8NTfyAxRUgpb+7A 1Aqur3ksyyDdCofz2cRqgMr/q8fu52HXSURV6WA0ZBt16kdhQx/leY2CT1iibuo7qP24 QFbp9YHuC/ItAK0YyKXwId2+mQWOGyI6dw54BAcMbbow8HbU8uHjHpIZuiy8VxSzcE97 yCe4qYjo87KoVH+jS+8R24lsnpsRvGS068ZH1xlXtxLkYZXyA4If5wqUuYzd6niTDpom KD/0COfrs1diLn65jDYJvDCm+OaogYjuKN+Tb4mSH72mBuWUHQn07fYPYdrX9H/6gzgR 6y/Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=Jq6B+pyN; 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=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id gt13-20020a1709072d8d00b006fecf187808si6273445ejc.377.2022.05.25.12.52.41; Wed, 25 May 2022 12:53:08 -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; dkim=pass header.i=@gmail.com header.s=20210112 header.b=Jq6B+pyN; 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=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S243710AbiEYCwk (ORCPT + 99 others); Tue, 24 May 2022 22:52:40 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:48360 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S243711AbiEYCwj (ORCPT ); Tue, 24 May 2022 22:52:39 -0400 Received: from mail-pf1-x434.google.com (mail-pf1-x434.google.com [IPv6:2607:f8b0:4864:20::434]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 7CCFA54F9B for ; Tue, 24 May 2022 19:52:38 -0700 (PDT) Received: by mail-pf1-x434.google.com with SMTP id y1so2033790pfr.6 for ; Tue, 24 May 2022 19:52:38 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=from:to:cc:subject:date:message-id; bh=s+X9BdhgymZkGEs6XYAhxZ8YaW7Mc7cLeWf6UbB+AxA=; b=Jq6B+pyNCb1mYvXzr6ps4NSWUHjieRp0VcM1SyMlkTa54elhAVDF8lwJw1FY/f2iIl aeebf0ks/bugs/UJw+z7FOYfrPi5DBSL0s0hQr+MaGdYKOlp6fxVYA29f0hkWqSbvvy4 tu/WtWm6MHwNn2OJzsLFFersx37sTEy1vvGaPDtwvbqleIlAyY9gfpHWnSygy8ZgCd78 FwB2ZSdU2LImi9bVilxOxs7Ox8zTPI5bf7ED+H/+O5BfJ1Ut5e2OqclwzDZ/r18DIfdQ RCfvG6j/PUJOfdP3lDx+/K8tpMlIcwnOt2WkDLoy474mY5aO+4CNfVOfNVHsj11Jki5R vFcw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id; bh=s+X9BdhgymZkGEs6XYAhxZ8YaW7Mc7cLeWf6UbB+AxA=; b=R6O3OYN09U91amzNHEiU2IoNnZsDSkqSm5GvvnP4hjiHgBivNgjQkScLGc/ATnOD6W 5Vjy0JgmtSTJduSOznuOdCfMZzsiYiYLscI2wmhnkhy0wZBPFrg6SM5ff4r44MtoBQxH KHrZhC2isLSbCkFm9gQ5yLZsJMS2lIqqe6CpxTfLgF5dm9QnLGgOlx74FAhwslX/xkjv XAna3BSQGdh5o5aQx1lgMFZlHj3TjxM0dELBq5CXHo92TwKWB7bFXJKyk7XtT/gCepZ9 2uHktvNXG5eexycGETI/vaF33u+5mddjMvpqlwz5MjVDUjgEmMUgLzzp/i2j8VY4r2Ll Z+7A== X-Gm-Message-State: AOAM530sos5pWdMnBI5YKZ66CMQZ0RbjBOasfqp8p77g1JoOIM9wGSvU dpXSdV6mqz7UGNaE3enCZS/jLhRvkVxx0w== X-Received: by 2002:a63:9044:0:b0:3fa:27bf:448c with SMTP id a65-20020a639044000000b003fa27bf448cmr13399959pge.131.1653447158046; Tue, 24 May 2022 19:52:38 -0700 (PDT) Received: from localhost.localdomain ([103.220.76.197]) by smtp.gmail.com with ESMTPSA id n9-20020a629709000000b0050df474e4d2sm9897374pfe.218.2022.05.24.19.52.35 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 24 May 2022 19:52:37 -0700 (PDT) From: Yue Hu X-Google-Original-From: Yue Hu To: dhowells@redhat.com, linux-cachefs@redhat.com Cc: linux-kernel@vger.kernel.org, huyue2@coolpad.com, zhangwen@coolpad.com Subject: [PATCH] fscache: Introduce fscache_cookie_is_dropped() Date: Wed, 25 May 2022 10:51:50 +0800 Message-Id: <20220525025150.466-1-huyue2@coolpad.com> X-Mailer: git-send-email 2.17.1 X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,FREEMAIL_FROM, RCVD_IN_DNSWL_NONE,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 FSCACHE_COOKIE_STATE_DROPPED will be read more than once, so let's add a helper to avoid code duplication. Signed-off-by: Yue Hu --- fs/fscache/cookie.c | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/fs/fscache/cookie.c b/fs/fscache/cookie.c index 9d3cf0111709..575a5ba07c0d 100644 --- a/fs/fscache/cookie.c +++ b/fs/fscache/cookie.c @@ -372,17 +372,22 @@ static struct fscache_cookie *fscache_alloc_cookie( return NULL; } +static inline bool fscache_cookie_is_dropped(struct fscache_cookie *cookie) +{ + return READ_ONCE(cookie->state) == FSCACHE_COOKIE_STATE_DROPPED; +} + static void fscache_wait_on_collision(struct fscache_cookie *candidate, struct fscache_cookie *wait_for) { enum fscache_cookie_state *statep = &wait_for->state; - wait_var_event_timeout(statep, READ_ONCE(*statep) == FSCACHE_COOKIE_STATE_DROPPED, + wait_var_event_timeout(statep, fscache_cookie_is_dropped(wait_for), 20 * HZ); - if (READ_ONCE(*statep) != FSCACHE_COOKIE_STATE_DROPPED) { + if (!fscache_cookie_is_dropped(wait_for)) { pr_notice("Potential collision c=%08x old: c=%08x", candidate->debug_id, wait_for->debug_id); - wait_var_event(statep, READ_ONCE(*statep) == FSCACHE_COOKIE_STATE_DROPPED); + wait_var_event(statep, fscache_cookie_is_dropped(wait_for)); } } -- 2.17.1