diff options
author | Al Viro <viro@ZenIV.linux.org.uk> | 2012-03-07 06:16:35 +0100 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2012-03-10 03:59:59 +0100 |
commit | 86b62a2cb4fc09037bbce2959d2992962396fd7f (patch) | |
tree | ea45bb1de1f49862415b5643dea840318d02ee67 /net/decnet/README | |
parent | Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/mas... (diff) | |
download | linux-86b62a2cb4fc09037bbce2959d2992962396fd7f.tar.xz linux-86b62a2cb4fc09037bbce2959d2992962396fd7f.zip |
aio: fix io_setup/io_destroy race
Have ioctx_alloc() return an extra reference, so that caller would drop it
on success and not bother with re-grabbing it on failure exit. The current
code is obviously broken - io_destroy() from another thread that managed
to guess the address io_setup() would've returned would free ioctx right
under us; gets especially interesting if aio_context_t * we pass to
io_setup() points to PROT_READ mapping, so put_user() fails and we end
up doing io_destroy() on kioctx another thread has just got freed...
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Acked-by: Benjamin LaHaise <bcrl@kvack.org>
Reviewed-by: Jeff Moyer <jmoyer@redhat.com>
Cc: stable@vger.kernel.org
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'net/decnet/README')
0 files changed, 0 insertions, 0 deletions