Received: by 2002:a89:413:0:b0:1fd:dba5:e537 with SMTP id m19csp562032lqs; Thu, 13 Jun 2024 20:45:04 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCUQnjhyIzmfnZvW84TxRRlY8B+5XrkW3Czfja1hJt4Gxg5u5GaB1HuNV2a9G6rktmvk/LEPN60Rd632eDIlaz4aXBgDDvxR8uG0v1RDoQ== X-Google-Smtp-Source: AGHT+IGNQPnxyjAiGQz34fH2CdKy2Ss2U/cyZzI5QgNfpJ72k66tpeKFbMOb36S50uUCVHFSs7M2 X-Received: by 2002:a05:622a:15c7:b0:440:a6bc:dcc8 with SMTP id d75a77b69052e-442168ac6bdmr12854581cf.23.1718336704649; Thu, 13 Jun 2024 20:45:04 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1718336704; cv=pass; d=google.com; s=arc-20160816; b=iX9Ti1ZjINjJ639S7wnusl0lZpp57hBG65VyX2DdzbkrVIg5Dl9jgsnnPIYrzkma57 6lpZHmeOnT8Zy9xmpFU+UhzT+md4ZmYE4L5S29XOv4EoaNomJ6+jEYufs2qPfGESG4FX 9EOY8VAVeKKVRhW5+ukipylxJy/mOo2Aw2w5xfzVE95GR56IiYLZzA28sTlh2Eb5zpvu 6vFEVL1BfhAVYsLbpGqlldOdsKx9xC3bf4LBHLIYLnQlmI7VN320eJyqyncJpDmF2m/a +CWddQL/C+ExCPQ70dfyxVtHjWtXFjVK6+pyek1uy8nVInrj4ZZq1Mb273txqbLRG85H FLkQ== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:references:in-reply-to:message-id :date:subject:cc:to:from:dkim-signature; bh=+06zCa5/OehqEmUPArNQNelDE0JPDPdSmRJSXmjbS4I=; fh=+HdF1SWcNPggmowVZtzfZ2+SYSXLLgvZBECjaw6UQek=; b=pPZxuZudXh+P6HuDmb533aEH7uqqc+WBt37dghWlUXMrBj/eADtSpQkbSDDRWSGntJ ATZLe05sxe/HT2MlEeT6W0x44OKFS3kqCpoepFMQBP9Mt5A0juEnu7q6GzItZIpaluiP HvRlNuBggdGZIbKCHY5ZVAzctD59s6Sc5uuIt8nfUgAiUubCb/3luwPe2enWmnyp2nXK +Ht2tLAgeLVcfjaTEirlZ7/OjqYAO81zo9jlIh15+BVIQ/3rW4cphRJ4Zd3h12bX89x2 0E1ggxXUxKPmsjHagwVWY8WR99dD9u+x0L/H+ocw3knedonKOflzjNy+Mh7rt4dJbkBW 8acw==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=EPoVgNa3; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-nfs+bounces-3816-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) smtp.mailfrom="linux-nfs+bounces-3816-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from ny.mirrors.kernel.org (ny.mirrors.kernel.org. [147.75.199.223]) by mx.google.com with ESMTPS id d75a77b69052e-441f30f9e24si27682701cf.695.2024.06.13.20.45.04 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 13 Jun 2024 20:45:04 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-nfs+bounces-3816-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) client-ip=147.75.199.223; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=EPoVgNa3; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-nfs+bounces-3816-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) smtp.mailfrom="linux-nfs+bounces-3816-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ny.mirrors.kernel.org (Postfix) with ESMTPS id 479051C20F57 for ; Fri, 14 Jun 2024 03:45:04 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 98CDC1474BA; Fri, 14 Jun 2024 03:44:49 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b="EPoVgNa3" X-Original-To: linux-nfs@vger.kernel.org Received: from smtp.kernel.org (aws-us-west-2-korg-mail-1.web.codeaurora.org [10.30.226.201]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 7574C1474B3 for ; Fri, 14 Jun 2024 03:44:49 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=10.30.226.201 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1718336689; cv=none; b=OY/08y684MWRAA6ry/EOxOmNjctlPIUA0Q/SRreffwicaUXUEBXVXnwo7I/PAWppcA9ZydkkSHhBfueqRKEl2/tbYWsF8VQwOxqomszaFfVBrQjG2VPRecRJwrJwfIkJwk9LwXnriFQWqhGCgGz+oSVPvmegE13bhNUniqC94XE= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1718336689; c=relaxed/simple; bh=JX6aw9YqdgNHM0+6VWobAInAGs2FApn8yzlRP5hTm4M=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=iNrcwY0H64D9T9E5ZNEIrNeKyHWz1pzVqfmSKdkxPPX5sIxKdJXUinjuhYh4NCJXaICvl9I3gaizcW/0yYh99f9+lkyejLrUIWRHMUTAyLypG89ZqbT8ahpSgEmi078F+YZAmn5zE8T2c4fArpWMcZl+42yvkacbpqkU0HC3PuQ= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=EPoVgNa3; arc=none smtp.client-ip=10.30.226.201 Received: by smtp.kernel.org (Postfix) with ESMTPSA id 22B9DC2BBFC; Fri, 14 Jun 2024 03:44:49 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1718336689; bh=JX6aw9YqdgNHM0+6VWobAInAGs2FApn8yzlRP5hTm4M=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=EPoVgNa3QK7RlaYGthJhU7cb9NdTmSreW6acCz+lK/ORSfoTKP+oQPPCl5QLwYjQw MfvWx4c8DH8xDq0tWZdBr8ggwTjO6YtQbyuXtf+/jzwINXtHOjgG7xz2BZ3FTHfhJd rttDY0Q/U7YrqnazmcRisV4R9XSeAV43wa1TEJNLKxWL3aqQmk8+01lMHVQ83JM0tM VQkZgMwqDskNwn8cEJmvlFRdjsVXt9mjXCEYK5DTCGz8ytQY1HqcHyOIY2IDOuuvje ArHqDUlGo4M6hDStvCbU6HKgUpxUyRHPRwLuZ9gqykqpzUeSbrOQtLzFnRpcviBS1e UY6i1WIBqrcZA== From: Mike Snitzer To: linux-nfs@vger.kernel.org Cc: Jeff Layton , Chuck Lever , Trond Myklebust , NeilBrown , snitzer@hammerspace.com Subject: [PATCH v3 16/18] nfsd: prepare to use SRCU to dereference nn->nfsd_serv Date: Thu, 13 Jun 2024 23:44:24 -0400 Message-ID: <20240614034426.31043-17-snitzer@kernel.org> X-Mailer: git-send-email 2.44.0 In-Reply-To: <20240614034426.31043-1-snitzer@kernel.org> References: <20240614034426.31043-1-snitzer@kernel.org> Precedence: bulk X-Mailing-List: linux-nfs@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit The next commit switches the nfsd_serv member for struct nfsd_net over to a void pointer (void __rcu *). Prepare for this by assigning nn->nfsd_serv to an struct svc_serv pointer that is then happily dereferenced. This eliminates what would otherwise be numerous void pointer dereferences after the next commit. All nfsd code what audited so that methods that hold nfsd_mutex will continue to directly dereference nn->nfsd_serv. Signed-off-by: Mike Snitzer --- fs/nfsd/nfsctl.c | 21 +++++++++++++-------- fs/nfsd/nfssvc.c | 28 ++++++++++++++++------------ 2 files changed, 29 insertions(+), 20 deletions(-) diff --git a/fs/nfsd/nfsctl.c b/fs/nfsd/nfsctl.c index 202140df8f82..e26b1bc7ad33 100644 --- a/fs/nfsd/nfsctl.c +++ b/fs/nfsd/nfsctl.c @@ -679,10 +679,11 @@ static ssize_t write_versions(struct file *file, char *buf, size_t size) static ssize_t __write_ports_names(char *buf, struct net *net) { struct nfsd_net *nn = net_generic(net, nfsd_net_id); + struct svc_serv *serv = nn->nfsd_serv; - if (nn->nfsd_serv == NULL) + if (serv == NULL) return 0; - return svc_xprt_names(nn->nfsd_serv, buf, SIMPLE_TRANSACTION_LIMIT); + return svc_xprt_names(serv, buf, SIMPLE_TRANSACTION_LIMIT); } /* @@ -709,7 +710,7 @@ static ssize_t __write_ports_addfd(char *buf, struct net *net, const struct cred serv = nn->nfsd_serv; err = svc_addsock(serv, net, fd, buf, SIMPLE_TRANSACTION_LIMIT, cred); - if (!serv->sv_nrthreads && list_empty(&nn->nfsd_serv->sv_permsocks)) + if (!serv->sv_nrthreads && list_empty(&serv->sv_permsocks)) nfsd_destroy_serv(net); return err; @@ -757,7 +758,7 @@ static ssize_t __write_ports_addxprt(char *buf, struct net *net, const struct cr svc_xprt_put(xprt); } out_err: - if (!serv->sv_nrthreads && list_empty(&nn->nfsd_serv->sv_permsocks)) + if (!serv->sv_nrthreads && list_empty(&serv->sv_permsocks)) nfsd_destroy_serv(net); return err; @@ -1666,6 +1667,7 @@ int nfsd_nl_threads_set_doit(struct sk_buff *skb, struct genl_info *info) int nthreads = 0, count = 0, nrpools, ret = -EOPNOTSUPP, rem; struct net *net = genl_info_net(info); struct nfsd_net *nn = net_generic(net, nfsd_net_id); + struct svc_serv *serv; const struct nlattr *attr; const char *scope = NULL; @@ -1693,7 +1695,8 @@ int nfsd_nl_threads_set_doit(struct sk_buff *skb, struct genl_info *info) info->attrs[NFSD_A_SERVER_LEASETIME] || info->attrs[NFSD_A_SERVER_SCOPE]) { ret = -EBUSY; - if (nn->nfsd_serv && nn->nfsd_serv->sv_nrthreads) + serv = nn->nfsd_serv; + if (serv && serv->sv_nrthreads) goto out_unlock; ret = -EINVAL; @@ -1741,6 +1744,7 @@ int nfsd_nl_threads_get_doit(struct sk_buff *skb, struct genl_info *info) { struct net *net = genl_info_net(info); struct nfsd_net *nn = net_generic(net, nfsd_net_id); + struct svc_serv *serv; void *hdr; int err; @@ -1765,11 +1769,12 @@ int nfsd_nl_threads_get_doit(struct sk_buff *skb, struct genl_info *info) if (err) goto err_unlock; - if (nn->nfsd_serv) { + serv = nn->nfsd_serv; + if (serv) { int i; for (i = 0; i < nfsd_nrpools(net); ++i) { - struct svc_pool *sp = &nn->nfsd_serv->sv_pools[i]; + struct svc_pool *sp = &serv->sv_pools[i]; err = nla_put_u32(skb, NFSD_A_SERVER_THREADS, atomic_read(&sp->sp_nrthreads)); @@ -2087,7 +2092,7 @@ int nfsd_nl_listener_set_doit(struct sk_buff *skb, struct genl_info *info) err = ret; } - if (!serv->sv_nrthreads && list_empty(&nn->nfsd_serv->sv_permsocks)) + if (!serv->sv_nrthreads && list_empty(&serv->sv_permsocks)) nfsd_destroy_serv(net); out_unlock_mtx: diff --git a/fs/nfsd/nfssvc.c b/fs/nfsd/nfssvc.c index 8f4b8c341c7c..d6e9d346e84a 100644 --- a/fs/nfsd/nfssvc.c +++ b/fs/nfsd/nfssvc.c @@ -309,10 +309,12 @@ int nfsd_nrthreads(struct net *net) { int rv = 0; struct nfsd_net *nn = net_generic(net, nfsd_net_id); + struct svc_serv *serv; mutex_lock(&nfsd_mutex); - if (nn->nfsd_serv) - rv = nn->nfsd_serv->sv_nrthreads; + serv = nn->nfsd_serv; + if (serv) + rv = serv->sv_nrthreads; mutex_unlock(&nfsd_mutex); return rv; } @@ -321,16 +323,17 @@ static int nfsd_init_socks(struct net *net, const struct cred *cred) { int error; struct nfsd_net *nn = net_generic(net, nfsd_net_id); + struct svc_serv *serv = nn->nfsd_serv; - if (!list_empty(&nn->nfsd_serv->sv_permsocks)) + if (!list_empty(&serv->sv_permsocks)) return 0; - error = svc_xprt_create(nn->nfsd_serv, "udp", net, PF_INET, NFS_PORT, + error = svc_xprt_create(serv, "udp", net, PF_INET, NFS_PORT, SVC_SOCK_DEFAULTS, cred); if (error < 0) return error; - error = svc_xprt_create(nn->nfsd_serv, "tcp", net, PF_INET, NFS_PORT, + error = svc_xprt_create(serv, "tcp", net, PF_INET, NFS_PORT, SVC_SOCK_DEFAULTS, cred); if (error < 0) return error; @@ -742,11 +745,12 @@ int nfsd_create_serv(struct net *net) int nfsd_nrpools(struct net *net) { struct nfsd_net *nn = net_generic(net, nfsd_net_id); + struct svc_serv *serv = nn->nfsd_serv; - if (nn->nfsd_serv == NULL) + if (serv == NULL) return 0; else - return nn->nfsd_serv->sv_nrpools; + return serv->sv_nrpools; } int nfsd_get_nrthreads(int n, int *nthreads, struct net *net) @@ -767,14 +771,15 @@ int nfsd_set_nrthreads(int n, int *nthreads, struct net *net) int tot = 0; int err = 0; struct nfsd_net *nn = net_generic(net, nfsd_net_id); + struct svc_serv *serv = nn->nfsd_serv; WARN_ON(!mutex_is_locked(&nfsd_mutex)); - if (nn->nfsd_serv == NULL || n <= 0) + if (serv == NULL || n <= 0) return 0; - if (n > nn->nfsd_serv->sv_nrpools) - n = nn->nfsd_serv->sv_nrpools; + if (n > serv->sv_nrpools) + n = serv->sv_nrpools; /* enforce a global maximum number of threads */ tot = 0; @@ -804,8 +809,7 @@ int nfsd_set_nrthreads(int n, int *nthreads, struct net *net) /* apply the new numbers */ for (i = 0; i < n; i++) { - err = svc_set_num_threads(nn->nfsd_serv, - &nn->nfsd_serv->sv_pools[i], + err = svc_set_num_threads(serv, &serv->sv_pools[i], nthreads[i]); if (err) break; -- 2.44.0