Commit 7f1bda44 authored by Trond Myklebust's avatar Trond Myklebust

NFS: Add a cond_resched() to nfs_commit_release_pages()

The commit list can get very large, and so we need a cond_resched()
in nfs_commit_release_pages() in order to ensure we don't hog the CPU
for excessive periods of time.
Reported-by: default avatarMike Galbraith <efault@gmx.de>
Cc: stable@vger.kernel.org
Signed-off-by: default avatarTrond Myklebust <trond.myklebust@primarydata.com>
parent a8750ddc
...@@ -1837,6 +1837,8 @@ static void nfs_commit_release_pages(struct nfs_commit_data *data) ...@@ -1837,6 +1837,8 @@ static void nfs_commit_release_pages(struct nfs_commit_data *data)
set_bit(NFS_CONTEXT_RESEND_WRITES, &req->wb_context->flags); set_bit(NFS_CONTEXT_RESEND_WRITES, &req->wb_context->flags);
next: next:
nfs_unlock_and_release_request(req); nfs_unlock_and_release_request(req);
/* Latency breaker */
cond_resched();
} }
nfss = NFS_SERVER(data->inode); nfss = NFS_SERVER(data->inode);
if (atomic_long_read(&nfss->writeback) < NFS_CONGESTION_OFF_THRESH) if (atomic_long_read(&nfss->writeback) < NFS_CONGESTION_OFF_THRESH)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment