diff options
author | Dave Jones <davej@redhat.com> | 2012-04-05 17:25:06 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2012-04-05 18:25:50 -0400 |
commit | 703bf2d122c95412a30f72658c53ad6292867b0b (patch) | |
tree | a949f0f54df7e1e2aed731a1be9a536c4d16287e /fs | |
parent | b82c32872db20667d6ee8e2ea1e7bdec791bdcc7 (diff) |
fs/xattr.c: suppress page allocation failure warnings from sys_listxattr()
This size is user controllable, up to a maximum of XATTR_LIST_MAX (64k).
So it's trivial for someone to trigger a stream of order:4 page
allocation errors.
Signed-off-by: Dave Jones <davej@redhat.com>
Cc: Al Viro <viro@zeniv.linux.org.uk>
Cc: Dave Chinner <david@fromorbit.com>
Acked-by: David Rientjes <rientjes@google.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'fs')
-rw-r--r-- | fs/xattr.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/fs/xattr.c b/fs/xattr.c index d6dfd247bb2f..a14d842ccb21 100644 --- a/fs/xattr.c +++ b/fs/xattr.c | |||
@@ -496,7 +496,7 @@ listxattr(struct dentry *d, char __user *list, size_t size) | |||
496 | if (size) { | 496 | if (size) { |
497 | if (size > XATTR_LIST_MAX) | 497 | if (size > XATTR_LIST_MAX) |
498 | size = XATTR_LIST_MAX; | 498 | size = XATTR_LIST_MAX; |
499 | klist = kmalloc(size, GFP_KERNEL); | 499 | klist = kmalloc(size, __GFP_NOWARN | GFP_KERNEL); |
500 | if (!klist) | 500 | if (!klist) |
501 | return -ENOMEM; | 501 | return -ENOMEM; |
502 | } | 502 | } |