diff options
author | Andrew Morton <akpm@osdl.org> | 2005-07-27 20:43:54 +0200 |
---|---|---|
committer | Linus Torvalds <torvalds@g5.osdl.org> | 2005-07-28 01:25:53 +0200 |
commit | 1aaf18ff9de1f37bf674236fc0779c3aaa65b998 (patch) | |
tree | 53df4d3dd0fbd81b79d5cdb63cf0d11853307a6b /sound/oss/maestro.c | |
parent | [PATCH] fix xip sparse file handling in ext2 (diff) | |
download | linux-1aaf18ff9de1f37bf674236fc0779c3aaa65b998.tar.xz linux-1aaf18ff9de1f37bf674236fc0779c3aaa65b998.zip |
[PATCH] check_user_page_readable() deadlock fix
Fix bug identifued by Richard Purdie <rpurdie@rpsys.net>.
oprofile calls check_user_page_readable() from interrupt context, so we
deadlock over various VFS locks.
But check_user_page_readable() doesn't imply either a read or a write of the
page's contents. Change __follow_page() so that check_user_page_readable()
can tell __follow_page() that we're not accessing the page's contents, and use
that info to avoid the troublesome lock-takings.
Also, make follow_page() inline for the single callsite in memory.c to save a
bit of stack space.
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'sound/oss/maestro.c')
0 files changed, 0 insertions, 0 deletions