Merge branch 'sched-urgent-for-linus' of git://git.kernel.org/pub/scm/linux/kernel...
[firefly-linux-kernel-4.4.55.git] / fs / nfs / nfs3proc.c
index 524f9f837408253ffc25ade7be5de9b65dc06b30..78e557c3ab87d014694e6e4098faefb20553f579 100644 (file)
@@ -800,6 +800,9 @@ static int nfs3_read_done(struct rpc_task *task, struct nfs_pgio_header *hdr)
 {
        struct inode *inode = hdr->inode;
 
+       if (hdr->pgio_done_cb != NULL)
+               return hdr->pgio_done_cb(task, hdr);
+
        if (nfs3_async_handle_jukebox(task, inode))
                return -EAGAIN;
 
@@ -825,6 +828,9 @@ static int nfs3_write_done(struct rpc_task *task, struct nfs_pgio_header *hdr)
 {
        struct inode *inode = hdr->inode;
 
+       if (hdr->pgio_done_cb != NULL)
+               return hdr->pgio_done_cb(task, hdr);
+
        if (nfs3_async_handle_jukebox(task, inode))
                return -EAGAIN;
        if (task->tk_status >= 0)
@@ -845,6 +851,9 @@ static void nfs3_proc_commit_rpc_prepare(struct rpc_task *task, struct nfs_commi
 
 static int nfs3_commit_done(struct rpc_task *task, struct nfs_commit_data *data)
 {
+       if (data->commit_done_cb != NULL)
+               return data->commit_done_cb(task, data);
+
        if (nfs3_async_handle_jukebox(task, data->inode))
                return -EAGAIN;
        nfs_refresh_inode(data->inode, data->res.fattr);