]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
nfsd: perform all find_openstateowner_str calls in the one place.
authorNeilBrown <neilb@suse.de>
Mon, 8 Apr 2024 02:09:15 +0000 (12:09 +1000)
committerChuck Lever <chuck.lever@oracle.com>
Mon, 6 May 2024 13:07:15 +0000 (09:07 -0400)
Currently find_openstateowner_str look ups are done both in
nfsd4_process_open1() and alloc_init_open_stateowner() - the latter
possibly being a surprise based on its name.

It would be easier to follow, and more conformant to common patterns, if
the lookup was all in the one place.

So replace alloc_init_open_stateowner() with
find_or_alloc_open_stateowner() and use the latter in
nfsd4_process_open1() without any calls to find_openstateowner_str().

This means all finds are find_openstateowner_str_locked() and
find_openstateowner_str() is no longer needed.  So discard
find_openstateowner_str() and rename find_openstateowner_str_locked() to
find_openstateowner_str().

Reviewed-by: Jeff Layton <jlayton@kernel.org>
Signed-off-by: NeilBrown <neilb@suse.de>
Signed-off-by: Chuck Lever <chuck.lever@oracle.com>
fs/nfsd/nfs4state.c

index 84d4093ca71317ebb7a70bde76819704e25ec7dc..65225b3d1d93c9e0d3e1d6fc9a9a2cc09ecf7bbc 100644 (file)
@@ -541,7 +541,7 @@ same_owner_str(struct nfs4_stateowner *sop, struct xdr_netobj *owner)
 }
 
 static struct nfs4_openowner *
-find_openstateowner_str_locked(unsigned int hashval, struct nfsd4_open *open,
+find_openstateowner_str(unsigned int hashval, struct nfsd4_open *open,
                        struct nfs4_client *clp)
 {
        struct nfs4_stateowner *so;
@@ -558,18 +558,6 @@ find_openstateowner_str_locked(unsigned int hashval, struct nfsd4_open *open,
        return NULL;
 }
 
-static struct nfs4_openowner *
-find_openstateowner_str(unsigned int hashval, struct nfsd4_open *open,
-                       struct nfs4_client *clp)
-{
-       struct nfs4_openowner *oo;
-
-       spin_lock(&clp->cl_lock);
-       oo = find_openstateowner_str_locked(hashval, open, clp);
-       spin_unlock(&clp->cl_lock);
-       return oo;
-}
-
 static inline u32
 opaque_hashval(const void *ptr, int nbytes)
 {
@@ -4866,34 +4854,46 @@ nfsd4_find_and_lock_existing_open(struct nfs4_file *fp, struct nfsd4_open *open)
 }
 
 static struct nfs4_openowner *
-alloc_init_open_stateowner(unsigned int strhashval, struct nfsd4_open *open,
-                          struct nfsd4_compound_state *cstate)
+find_or_alloc_open_stateowner(unsigned int strhashval, struct nfsd4_open *open,
+                             struct nfsd4_compound_state *cstate)
 {
        struct nfs4_client *clp = cstate->clp;
-       struct nfs4_openowner *oo, *ret;
+       struct nfs4_openowner *oo, *new = NULL;
 
-       oo = alloc_stateowner(openowner_slab, &open->op_owner, clp);
-       if (!oo)
-               return NULL;
-       oo->oo_owner.so_ops = &openowner_ops;
-       oo->oo_owner.so_is_open_owner = 1;
-       oo->oo_owner.so_seqid = open->op_seqid;
-       oo->oo_flags = 0;
-       if (nfsd4_has_session(cstate))
-               oo->oo_flags |= NFS4_OO_CONFIRMED;
-       oo->oo_time = 0;
-       oo->oo_last_closed_stid = NULL;
-       INIT_LIST_HEAD(&oo->oo_close_lru);
+retry:
        spin_lock(&clp->cl_lock);
-       ret = find_openstateowner_str_locked(strhashval, open, clp);
-       if (ret == NULL) {
-               hash_openowner(oo, clp, strhashval);
-               ret = oo;
-       } else
-               nfs4_free_stateowner(&oo->oo_owner);
-
+       oo = find_openstateowner_str(strhashval, open, clp);
+       if (!oo && new) {
+               hash_openowner(new, clp, strhashval);
+               spin_unlock(&clp->cl_lock);
+               return new;
+       }
        spin_unlock(&clp->cl_lock);
-       return ret;
+
+       if (oo && !(oo->oo_flags & NFS4_OO_CONFIRMED)) {
+               /* Replace unconfirmed owners without checking for replay. */
+               release_openowner(oo);
+               oo = NULL;
+       }
+       if (oo) {
+               if (new)
+                       nfs4_free_stateowner(&new->oo_owner);
+               return oo;
+       }
+
+       new = alloc_stateowner(openowner_slab, &open->op_owner, clp);
+       if (!new)
+               return NULL;
+       new->oo_owner.so_ops = &openowner_ops;
+       new->oo_owner.so_is_open_owner = 1;
+       new->oo_owner.so_seqid = open->op_seqid;
+       new->oo_flags = 0;
+       if (nfsd4_has_session(cstate))
+               new->oo_flags |= NFS4_OO_CONFIRMED;
+       new->oo_time = 0;
+       new->oo_last_closed_stid = NULL;
+       INIT_LIST_HEAD(&new->oo_close_lru);
+       goto retry;
 }
 
 static struct nfs4_ol_stateid *
@@ -5342,27 +5342,14 @@ nfsd4_process_open1(struct nfsd4_compound_state *cstate,
        clp = cstate->clp;
 
        strhashval = ownerstr_hashval(&open->op_owner);
-       oo = find_openstateowner_str(strhashval, open, clp);
+       oo = find_or_alloc_open_stateowner(strhashval, open, cstate);
        open->op_openowner = oo;
-       if (!oo) {
-               goto new_owner;
-       }
-       if (!(oo->oo_flags & NFS4_OO_CONFIRMED)) {
-               /* Replace unconfirmed owners without checking for replay. */
-               release_openowner(oo);
-               open->op_openowner = NULL;
-               goto new_owner;
-       }
+       if (!oo)
+               return nfserr_jukebox;
        status = nfsd4_check_seqid(cstate, &oo->oo_owner, open->op_seqid);
        if (status)
                return status;
-       goto alloc_stateid;
-new_owner:
-       oo = alloc_init_open_stateowner(strhashval, open, cstate);
-       if (oo == NULL)
-               return nfserr_jukebox;
-       open->op_openowner = oo;
-alloc_stateid:
+
        open->op_stp = nfs4_alloc_open_stateid(clp);
        if (!open->op_stp)
                return nfserr_jukebox;