diff options
author | 2011-04-14 20:55:19 +0400 | |
---|---|---|
committer | 2011-04-21 11:51:04 +1000 | |
commit | b522f02184b413955f3bc952e3776ce41edc6355 (patch) | |
tree | 3141d04c93d5342c06e54bbba389b646a005cb04 /tools/perf/scripts/python/syscall-counts.py | |
parent | drm/radeon/kms: fix IH writeback on r6xx+ on big endian machines (diff) | |
download | linux-dev-b522f02184b413955f3bc952e3776ce41edc6355.tar.xz linux-dev-b522f02184b413955f3bc952e3776ce41edc6355.zip |
agp: fix OOM and buffer overflow
page_count is copied from userspace. agp_allocate_memory() tries to
check whether this number is too big, but doesn't take into account the
wrap case. Also agp_create_user_memory() doesn't check whether
alloc_size is calculated from num_agp_pages variable without overflow.
This may lead to allocation of too small buffer with following buffer
overflow.
Another problem in agp code is not addressed in the patch - kernel memory
exhaustion (AGPIOC_RESERVE and AGPIOC_ALLOCATE ioctls). It is not checked
whether requested pid is a pid of the caller (no check in agpioc_reserve_wrap()).
Each allocation is limited to 16KB, though, there is no per-process limit.
This might lead to OOM situation, which is not even solved in case of the
caller death by OOM killer - the memory is allocated for another (faked) process.
Signed-off-by: Vasiliy Kulikov <segoon@openwall.com>
Signed-off-by: Dave Airlie <airlied@redhat.com>
Diffstat (limited to 'tools/perf/scripts/python/syscall-counts.py')
0 files changed, 0 insertions, 0 deletions