Received: by 2002:a05:6a10:9afc:0:0:0:0 with SMTP id t28csp3131374pxm; Mon, 28 Feb 2022 12:43:02 -0800 (PST) X-Google-Smtp-Source: ABdhPJxEb3rfbKP6NpWxYRoe25bPVQKfiHIZMee8mjoI/GZXT4w/ARUTgG3zuf+J9+86yV57YM9k X-Received: by 2002:a05:6402:b9c:b0:410:d469:d73d with SMTP id cf28-20020a0564020b9c00b00410d469d73dmr21280301edb.78.1646080982670; Mon, 28 Feb 2022 12:43:02 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1646080982; cv=none; d=google.com; s=arc-20160816; b=erHVDYW+x/SoG1vo0H/6XU21G9U28dyStj7RqHQIAf3v1mAchLXIs3lFoPkrDIWctq y+PIs+Vk6Y6ZQloB3pmRtm3sBuIzACi/bLbgzZhJiqalxBoPfeRTjk7A+NhBRw0K5rCZ hNe9R1BVyyQkRSkwn3qk8p15bfifF9CC7ECofhQwQxA2QSZyh3IhM6H70YHxxw/Ro7Md HWv496iDZJKKejUlSxwlaSbbIecZY1RGSrkPKueLnCAeLYX4SwsTnBsS5CUXAmSFWMjE 2QOMN7STwN4Unk38M7CA6a63l4l3xgZ99y35N45kfez3PIFn1YwFyr+GBaMQbRqlA8Ed GdWA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=cNagKDysBsf6UvnFDztIqGvr1Ndg7lq6E+bzhf9XLvk=; b=hS2UdUc8NP9mTCIGk5RTZd+SBzwpo49DKwap49soLROn9NTnt9yfBVvSXnuuGPqJSg gLOK72h/bKZU390Guu7ov1mkatLXQI+diX9am38PsLbIW0CYr0OMPd0+UIdXvzddmJfz 926ZAUUnYcjq5PiDVLQtCb22YNHPK9v5C+Bsj6/x2bt0nPOT/oP6Ec6kXogZjxI6FlCJ D0UOIuXowP7SK7ePhT5jILJ70wC6wuEWfxGKkpIx0fWWxG6zSqSAPPpcfXf13njdKT1q CkqMRU8zogp7bkGdqp7bj6OYEpqrIcAYnaLDwEvsNZkEb+cW3iMFHguDMgSkzFvoXJq4 1U9A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b="Uu3W/c6P"; spf=pass (google.com: domain of linux-nfs-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-nfs-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 ay15-20020a056402202f00b00410838dc44csi7393621edb.553.2022.02.28.12.42.38; Mon, 28 Feb 2022 12:43:02 -0800 (PST) Received-SPF: pass (google.com: domain of linux-nfs-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="Uu3W/c6P"; spf=pass (google.com: domain of linux-nfs-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-nfs-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 S229507AbiB1Uit (ORCPT + 99 others); Mon, 28 Feb 2022 15:38:49 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:51564 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229778AbiB1Uis (ORCPT ); Mon, 28 Feb 2022 15:38:48 -0500 Received: from mail-qk1-x72a.google.com (mail-qk1-x72a.google.com [IPv6:2607:f8b0:4864:20::72a]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 02FA317E0C for ; Mon, 28 Feb 2022 12:38:09 -0800 (PST) Received: by mail-qk1-x72a.google.com with SMTP id bm39so11408218qkb.0 for ; Mon, 28 Feb 2022 12:38:08 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=cNagKDysBsf6UvnFDztIqGvr1Ndg7lq6E+bzhf9XLvk=; b=Uu3W/c6PkQDtf/JPsuhlHGUsjTpFsaEfELDDUx+Vlspm4YkpFOMpDCZS6wOqzRhBBl NM8lIZ0TNE50fW/wHcZhb9IYwNXhYsFaRV9xLes7HnNlvdlx52J+AN4Z7PJup5t09Emm WQrUzht9aN61mkJ2ekGSZd4RufNXSFwBpIOlyz4z8gEbZV98tkz4coVpyxld+aORiqK4 mO4OKoiVYX4YEYyhBIJA7EJkJwUkhGQiaacrvx0fEThcNhK64lTqFPAvdQ4FQoWrY/UJ xj2PiTCJIcpgbJOaHi+xcLx8rquZNQD55roJ7a3mWC78/boPHfSGsQwIwX0L+CLNTO7Z l/KA== 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:in-reply-to :references:mime-version:content-transfer-encoding; bh=cNagKDysBsf6UvnFDztIqGvr1Ndg7lq6E+bzhf9XLvk=; b=ihm+Jttag6OvUDOquPenl7O/bvBG8814fx81EmBYURDMMMmPTYamRr7OcHmCkxShAE LnhowZT0eDhNTFnGM5V7dOuF8HcAMZSsT2HAnuKxUBczgJjNlqLLhQJrFVdvPniyAi1Y h21L7nS4drXa6YlBjyazGlc0XCwumgihTpNxOnMSPNfCVPwOh3MrMhC2H21Dt51pbDLZ fWCQJNm0vjYlS/SfTOa4ZHRzF7sQmw3dL4ECJPEFhuPbSJN9Z/KmaheVBm3kHdMueA/Q Nqor+1J5MxjkcBmpokrLoESjQjVSRqWnAgymNmperNVi+JzfX/MC4rpcPmntq1me48X4 YddQ== X-Gm-Message-State: AOAM5308MvCepfYyC4v8sWrSzFIKEasnmqvem4yY/rXOt1O2LTiAjE7e wriVUhaGjo1xLSfIQLzrqbA= X-Received: by 2002:ae9:e711:0:b0:648:e0ca:13fa with SMTP id m17-20020ae9e711000000b00648e0ca13famr12603635qka.300.1646080688072; Mon, 28 Feb 2022 12:38:08 -0800 (PST) Received: from kolga-mac-1.vpn.netapp.com ([2600:1700:6a10:2e90:4cc0:8dcd:bb8c:75c2]) by smtp.gmail.com with ESMTPSA id p20-20020a05620a22b400b00648ca1458b4sm5457606qkh.5.2022.02.28.12.38.07 (version=TLS1_2 cipher=ECDHE-ECDSA-AES128-GCM-SHA256 bits=128/128); Mon, 28 Feb 2022 12:38:07 -0800 (PST) From: Olga Kornievskaia To: trond.myklebust@hammerspace.com, anna.schumaker@netapp.com Cc: linux-nfs@vger.kernel.org Subject: [RFC PATCH 1/3] SUNRPC provide accessible functions for offline remote xprt functionality Date: Mon, 28 Feb 2022 15:38:02 -0500 Message-Id: <20220228203804.61803-2-olga.kornievskaia@gmail.com> X-Mailer: git-send-email 2.30.1 (Apple Git-130) In-Reply-To: <20220228203804.61803-1-olga.kornievskaia@gmail.com> References: <20220228203804.61803-1-olga.kornievskaia@gmail.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit 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-nfs@vger.kernel.org From: Olga Kornievskaia Re-arrange the code that make offline transport and delete transport callable functions. Signed-off-by: Olga Kornievskaia --- include/linux/sunrpc/xprt.h | 2 ++ net/sunrpc/sysfs.c | 23 +++++------------------ net/sunrpc/xprt.c | 25 +++++++++++++++++++++++++ 3 files changed, 32 insertions(+), 18 deletions(-) diff --git a/include/linux/sunrpc/xprt.h b/include/linux/sunrpc/xprt.h index 955ea4d7af0b..201c58991d4a 100644 --- a/include/linux/sunrpc/xprt.h +++ b/include/linux/sunrpc/xprt.h @@ -502,4 +502,6 @@ static inline int xprt_test_and_set_binding(struct rpc_xprt *xprt) return test_and_set_bit(XPRT_BINDING, &xprt->state); } +void xprt_set_offline_locked(struct rpc_xprt *xprt, struct rpc_xprt_switch *xps); +void xprt_delete_locked(struct rpc_xprt *xprt, struct rpc_xprt_switch *xps); #endif /* _LINUX_SUNRPC_XPRT_H */ diff --git a/net/sunrpc/sysfs.c b/net/sunrpc/sysfs.c index 05c758da6a92..4a6488dd1608 100644 --- a/net/sunrpc/sysfs.c +++ b/net/sunrpc/sysfs.c @@ -6,6 +6,7 @@ #include #include #include +//#include #include "sysfs.h" @@ -312,11 +313,7 @@ static ssize_t rpc_sysfs_xprt_state_change(struct kobject *kobj, goto release_tasks; } if (offline) { - if (!test_and_set_bit(XPRT_OFFLINE, &xprt->state)) { - spin_lock(&xps->xps_lock); - xps->xps_nactive--; - spin_unlock(&xps->xps_lock); - } + xprt_set_offline_locked(xprt, xps); } else if (online) { if (test_and_clear_bit(XPRT_OFFLINE, &xprt->state)) { spin_lock(&xps->xps_lock); @@ -324,20 +321,10 @@ static ssize_t rpc_sysfs_xprt_state_change(struct kobject *kobj, spin_unlock(&xps->xps_lock); } } else if (remove) { - if (test_bit(XPRT_OFFLINE, &xprt->state)) { - if (!test_and_set_bit(XPRT_REMOVE, &xprt->state)) { - xprt_force_disconnect(xprt); - if (test_bit(XPRT_CONNECTED, &xprt->state)) { - if (!xprt->sending.qlen && - !xprt->pending.qlen && - !xprt->backlog.qlen && - !atomic_long_read(&xprt->queuelen)) - rpc_xprt_switch_remove_xprt(xps, xprt); - } - } - } else { + if (test_bit(XPRT_OFFLINE, &xprt->state)) + xprt_delete_locked(xprt, xps); + else count = -EINVAL; - } } release_tasks: diff --git a/net/sunrpc/xprt.c b/net/sunrpc/xprt.c index 9f0025e0742c..16d4435b61b4 100644 --- a/net/sunrpc/xprt.c +++ b/net/sunrpc/xprt.c @@ -2151,3 +2151,28 @@ void xprt_put(struct rpc_xprt *xprt) kref_put(&xprt->kref, xprt_destroy_kref); } EXPORT_SYMBOL_GPL(xprt_put); + +void xprt_set_offline_locked(struct rpc_xprt *xprt, struct rpc_xprt_switch *xps) +{ + if (!test_and_set_bit(XPRT_OFFLINE, &xprt->state)) { + spin_lock(&xps->xps_lock); + xps->xps_nactive--; + spin_unlock(&xps->xps_lock); + } +} +EXPORT_SYMBOL(xprt_set_offline_locked); + +void xprt_delete_locked(struct rpc_xprt *xprt, struct rpc_xprt_switch *xps) +{ + if (test_and_set_bit(XPRT_REMOVE, &xprt->state)) + return; + + xprt_force_disconnect(xprt); + if (!test_bit(XPRT_CONNECTED, &xprt->state)) + return; + + if (!xprt->sending.qlen && !xprt->pending.qlen && + !xprt->backlog.qlen && !atomic_long_read(&xprt->queuelen)) + rpc_xprt_switch_remove_xprt(xps, xprt); +} +EXPORT_SYMBOL(xprt_delete_locked); -- 2.27.0