NFSv4: Split out NFS v4.2 copy completion functions
authorAnna Schumaker <Anna.Schumaker@Netapp.com>
Thu, 20 Sep 2018 20:12:13 +0000 (16:12 -0400)
committerTrond Myklebust <trond.myklebust@hammerspace.com>
Sun, 30 Sep 2018 19:35:17 +0000 (15:35 -0400)
The convention in the rest of the code is to have a separate function
for anything that might be ifdef-ed out.

Signed-off-by: Anna Schumaker <Anna.Schumaker@Netapp.com>
Signed-off-by: Trond Myklebust <trond.myklebust@hammerspace.com>
fs/nfs/nfs4state.c

index 91fd404..62ae0fd 100644 (file)
@@ -1549,6 +1549,31 @@ out:
        return status;
 }
 
+#ifdef CONFIG_NFS_V4_2
+static void nfs42_complete_copies(struct nfs4_state_owner *sp, struct nfs4_state *state)
+{
+       struct nfs4_copy_state *copy;
+
+       if (!test_bit(NFS_CLNT_DST_SSC_COPY_STATE, &state->flags))
+               return;
+
+       spin_lock(&sp->so_server->nfs_client->cl_lock);
+       list_for_each_entry(copy, &sp->so_server->ss_copies, copies) {
+               if (nfs4_stateid_match_other(&state->stateid, &copy->parent_state->stateid))
+                       continue;
+               copy->flags = 1;
+               complete(&copy->completion);
+               break;
+       }
+       spin_unlock(&sp->so_server->nfs_client->cl_lock);
+}
+#else /* !CONFIG_NFS_V4_2 */
+static inline void nfs42_complete_copies(struct nfs4_state_owner *sp,
+                                        struct nfs4_state *state)
+{
+}
+#endif /* CONFIG_NFS_V4_2 */
+
 static int __nfs4_reclaim_open_state(struct nfs4_state_owner *sp, struct nfs4_state *state,
                                     const struct nfs4_state_recovery_ops *ops)
 {
@@ -1572,21 +1597,7 @@ static int __nfs4_reclaim_open_state(struct nfs4_state_owner *sp, struct nfs4_st
                spin_unlock(&state->state_lock);
        }
 
-#ifdef CONFIG_NFS_V4_2
-       if (test_bit(NFS_CLNT_DST_SSC_COPY_STATE, &state->flags)) {
-               struct nfs4_copy_state *copy;
-               spin_lock(&sp->so_server->nfs_client->cl_lock);
-               list_for_each_entry(copy, &sp->so_server->ss_copies, copies) {
-                       if (nfs4_stateid_match_other(&state->stateid, &copy->parent_state->stateid))
-                               continue;
-                       copy->flags = 1;
-                       complete(&copy->completion);
-                       break;
-               }
-               spin_unlock(&sp->so_server->nfs_client->cl_lock);
-       }
-#endif /* CONFIG_NFS_V4_2 */
-
+       nfs42_complete_copies(sp, state);
        clear_bit(NFS_STATE_RECLAIM_NOGRACE, &state->flags);
        return status;
 }