proc: add a reschedule point in proc_readfd_common()
authorEric Dumazet <edumazet@google.com>
Thu, 3 Dec 2015 19:12:07 +0000 (11:12 -0800)
committerAl Viro <viro@zeniv.linux.org.uk>
Sat, 9 Jan 2016 07:56:10 +0000 (02:56 -0500)
User can pass an arbitrary large buffer to getdents().

It is typically a 32KB buffer used by libc scandir() implementation.

When scanning /proc/{pid}/fd, we can hold cpu way too long,
so add a cond_resched() to be kind with other tasks.

We've seen latencies of more than 50ms on real workloads.

Signed-off-by: Eric Dumazet <edumazet@google.com>
Cc: Alexander Viro <viro@zeniv.linux.org.uk>
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
fs/proc/fd.c

index 3c2a915c695a319708c2939c9bb8923b73508112..56afa5ef08f2dbca5f36f5feafa2a257bf525ab3 100644 (file)
@@ -258,6 +258,7 @@ static int proc_readfd_common(struct file *file, struct dir_context *ctx,
                                     name, len, instantiate, p,
                                     (void *)(unsigned long)fd))
                        goto out_fd_loop;
+               cond_resched();
                rcu_read_lock();
        }
        rcu_read_unlock();