|
@@ -807,27 +807,29 @@ void pnfs_roc_set_barrier(struct inode *ino, u32 barrier)
|
|
|
spin_unlock(&ino->i_lock);
|
|
|
}
|
|
|
|
|
|
-bool pnfs_roc_drain(struct inode *ino, u32 *barrier)
|
|
|
+bool pnfs_roc_drain(struct inode *ino, u32 *barrier, struct rpc_task *task)
|
|
|
{
|
|
|
struct nfs_inode *nfsi = NFS_I(ino);
|
|
|
+ struct pnfs_layout_hdr *lo;
|
|
|
struct pnfs_layout_segment *lseg;
|
|
|
+ u32 current_seqid;
|
|
|
bool found = false;
|
|
|
|
|
|
spin_lock(&ino->i_lock);
|
|
|
list_for_each_entry(lseg, &nfsi->layout->plh_segs, pls_list)
|
|
|
if (test_bit(NFS_LSEG_ROC, &lseg->pls_flags)) {
|
|
|
+ rpc_sleep_on(&NFS_SERVER(ino)->roc_rpcwaitq, task, NULL);
|
|
|
found = true;
|
|
|
- break;
|
|
|
+ goto out;
|
|
|
}
|
|
|
- if (!found) {
|
|
|
- struct pnfs_layout_hdr *lo = nfsi->layout;
|
|
|
- u32 current_seqid = be32_to_cpu(lo->plh_stateid.seqid);
|
|
|
+ lo = nfsi->layout;
|
|
|
+ current_seqid = be32_to_cpu(lo->plh_stateid.seqid);
|
|
|
|
|
|
- /* Since close does not return a layout stateid for use as
|
|
|
- * a barrier, we choose the worst-case barrier.
|
|
|
- */
|
|
|
- *barrier = current_seqid + atomic_read(&lo->plh_outstanding);
|
|
|
- }
|
|
|
+ /* Since close does not return a layout stateid for use as
|
|
|
+ * a barrier, we choose the worst-case barrier.
|
|
|
+ */
|
|
|
+ *barrier = current_seqid + atomic_read(&lo->plh_outstanding);
|
|
|
+out:
|
|
|
spin_unlock(&ino->i_lock);
|
|
|
return found;
|
|
|
}
|