|
@@ -171,6 +171,13 @@ static u32 initiate_file_draining(struct nfs_client *clp,
|
|
|
goto out;
|
|
|
|
|
|
ino = lo->plh_inode;
|
|
|
+
|
|
|
+ spin_lock(&ino->i_lock);
|
|
|
+ pnfs_set_layout_stateid(lo, &args->cbl_stateid, true);
|
|
|
+ spin_unlock(&ino->i_lock);
|
|
|
+
|
|
|
+ pnfs_layoutcommit_inode(ino, false);
|
|
|
+
|
|
|
spin_lock(&ino->i_lock);
|
|
|
if (test_bit(NFS_LAYOUT_BULK_RECALL, &lo->plh_flags) ||
|
|
|
pnfs_mark_matching_lsegs_invalid(lo, &free_me_list,
|
|
@@ -178,7 +185,6 @@ static u32 initiate_file_draining(struct nfs_client *clp,
|
|
|
rv = NFS4ERR_DELAY;
|
|
|
else
|
|
|
rv = NFS4ERR_NOMATCHING_LAYOUT;
|
|
|
- pnfs_set_layout_stateid(lo, &args->cbl_stateid, true);
|
|
|
spin_unlock(&ino->i_lock);
|
|
|
pnfs_free_lseg_list(&free_me_list);
|
|
|
pnfs_put_layout_hdr(lo);
|