summaryrefslogtreecommitdiffstats
path: root/arch/sh/mm/fault.c
diff options
context:
space:
mode:
authorHugh Dickins2005-10-30 02:16:33 +0100
committerLinus Torvalds2005-10-30 05:40:41 +0100
commitdeceb6cd17e6dfafe4c4f81b1b4153bc41b2cb70 (patch)
tree2a722f50e8edef8609a49f65bfcb222e499c44cc /arch/sh/mm/fault.c
parent[PATCH] mm: kill check_user_page_readable (diff)
downloadkernel-qcow2-linux-deceb6cd17e6dfafe4c4f81b1b4153bc41b2cb70.tar.gz
kernel-qcow2-linux-deceb6cd17e6dfafe4c4f81b1b4153bc41b2cb70.tar.xz
kernel-qcow2-linux-deceb6cd17e6dfafe4c4f81b1b4153bc41b2cb70.zip
[PATCH] mm: follow_page with inner ptlock
Final step in pushing down common core's page_table_lock. follow_page no longer wants caller to hold page_table_lock, uses pte_offset_map_lock itself; and so no page_table_lock is taken in get_user_pages itself. But get_user_pages (and get_futex_key) do then need follow_page to pin the page for them: take Daniel's suggestion of bitflags to follow_page. Need one for WRITE, another for TOUCH (it was the accessed flag before: vanished along with check_user_page_readable, but surely get_numa_maps is wrong to mark every page it finds as accessed), another for GET. And another, ANON to dispose of untouched_anonymous_page: it seems silly for that to descend a second time, let follow_page observe if there was no page table and return ZERO_PAGE if so. Fix minor bug in that: check VM_LOCKED - make_pages_present ought to make readonly anonymous present. Give get_numa_maps a cond_resched while we're there. Signed-off-by: Hugh Dickins <hugh@veritas.com> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'arch/sh/mm/fault.c')
0 files changed, 0 insertions, 0 deletions