summaryrefslogtreecommitdiff
path: root/include/linux/rhashtable.h
diff options
context:
space:
mode:
authorHelge Deller <deller@gmx.de>2015-06-04 23:57:18 +0200
committerHelge Deller <deller@gmx.de>2015-06-04 23:57:18 +0200
commit9b7b819ca1e508195feed5ece558dca66adeef05 (patch)
treecf62f858c89c61d5b38052273ff7ca2defb3a818 /include/linux/rhashtable.h
parentff25ea8f4eeea252bfcaf65289fa57ba6de080dd (diff)
downloadlwn-9b7b819ca1e508195feed5ece558dca66adeef05.tar.gz
lwn-9b7b819ca1e508195feed5ece558dca66adeef05.zip
compat: cleanup coding in compat_get_bitmap() and compat_put_bitmap()
In the functions compat_get_bitmap() and compat_put_bitmap() the variable nr_compat_longs stores how many compat_ulong_t words should be copied in a loop. The copy loop itself is this: if (nr_compat_longs-- > 0) { if (__get_user(um, umask)) return -EFAULT; } else { um = 0; } Since nr_compat_longs gets unconditionally decremented in each loop and since it's type is unsigned this could theoretically lead to out of bounds accesses to userspace if nr_compat_longs wraps around to (unsigned)(-1). Although the callers currently do not trigger out-of-bounds accesses, we should better implement the loop in a safe way to completely avoid such warp-arounds. Signed-off-by: Helge Deller <deller@gmx.de> Cc: Linus Torvalds <torvalds@linux-foundation.org> Cc: Al Viro <viro@zeniv.linux.org.uk>
Diffstat (limited to 'include/linux/rhashtable.h')
0 files changed, 0 insertions, 0 deletions