summaryrefslogtreecommitdiffstats
path: root/fs/proc
diff options
context:
space:
mode:
authorEric Dumazet <edumazet@google.com>2017-01-24 15:18:07 -0800
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2017-06-17 06:41:56 +0200
commit9618fba264999372c641b5cb3db777c6a216caa5 (patch)
tree41417a950a5385fcefefc35200755fd3b92a7109 /fs/proc
parente23b1c05a50ffc7cabe12b9bc4fdfa55e32d9614 (diff)
downloadlinux-stable-9618fba264999372c641b5cb3db777c6a216caa5.tar.gz
linux-stable-9618fba264999372c641b5cb3db777c6a216caa5.tar.bz2
linux-stable-9618fba264999372c641b5cb3db777c6a216caa5.zip
proc: add a schedule point in proc_pid_readdir()
[ Upstream commit 3ba4bceef23206349d4130ddf140819b365de7c8 ] We have seen proc_pid_readdir() invocations holding cpu for more than 50 ms. Add a cond_resched() to be gentle with other tasks. [akpm@linux-foundation.org: coding style fix] Link: http://lkml.kernel.org/r/1484238380.15816.42.camel@edumazet-glaptop3.roam.corp.google.com Signed-off-by: Eric Dumazet <edumazet@google.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org> Signed-off-by: Sasha Levin <alexander.levin@verizon.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'fs/proc')
-rw-r--r--fs/proc/base.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/fs/proc/base.c b/fs/proc/base.c
index ca651ac00660..e67fec3c9856 100644
--- a/fs/proc/base.c
+++ b/fs/proc/base.c
@@ -3181,6 +3181,8 @@ int proc_pid_readdir(struct file *file, struct dir_context *ctx)
iter.tgid += 1, iter = next_tgid(ns, iter)) {
char name[PROC_NUMBUF];
int len;
+
+ cond_resched();
if (!has_pid_permissions(ns, iter.task, 2))
continue;