diff options
author | Hugh Dickins <[email protected]> | 2009-06-23 12:36:58 -0700 |
---|---|---|
committer | Linus Torvalds <[email protected]> | 2009-06-23 12:50:05 -0700 |
commit | a5c9b696ec109bb54d547fdb437a7a0c2d514670 (patch) | |
tree | c97533e38359a2e731bcc2c65f063a27f4f629e6 /drivers/mtd/lpddr/lpddr_cmds.c | |
parent | 626f380d0b264a1e40237f5a2a3dffc5d14f256e (diff) |
mm: pass mm to grab_swap_token
If a kthread happens to use get_user_pages() on an mm (as KSM does),
there's a chance that it will end up trying to read in a swap page, then
oops in grab_swap_token() because the kthread has no mm: GUP passes down
the right mm, so grab_swap_token() ought to be using it.
We have not identified a stronger case than KSM's daemon (not yet in
mainline), but the issue must have come up before, since RHEL has included
a fix for this for years (though a different fix, they just back out of
grab_swap_token if current->mm is unset: which is what we first proposed,
but using the right mm here seems more correct).
Reported-by: Izik Eidus <[email protected]>
Signed-off-by: Johannes Weiner <[email protected]>
Signed-off-by: Hugh Dickins <[email protected]>
Acked-by: Rik van Riel <[email protected]>
Signed-off-by: Andrew Morton <[email protected]>
Signed-off-by: Linus Torvalds <[email protected]>
Diffstat (limited to 'drivers/mtd/lpddr/lpddr_cmds.c')
0 files changed, 0 insertions, 0 deletions