From: Hugh Dickins Date: Mon, 9 Nov 2009 15:58:23 +0000 (+0000) Subject: ksm: cond_resched in unstable tree X-Git-Tag: firefly_0821_release~11953 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=d178f27fc5150d680d9df865ea9dfe3269cf00a6;p=firefly-linux-kernel-4.4.55.git ksm: cond_resched in unstable tree KSM needs a cond_resched() for CONFIG_PREEMPT_NONE, in its unbounded search of the unstable tree. The stable tree cases already have one, and originally there was one down inside get_user_pages(); but I missed it when I converted to follow_page() instead. Signed-off-by: Hugh Dickins Acked-by: Izik Eidus Signed-off-by: Linus Torvalds --- diff --git a/mm/ksm.c b/mm/ksm.c index bef1af4f77e3..5575f8628fef 100644 --- a/mm/ksm.c +++ b/mm/ksm.c @@ -1012,6 +1012,7 @@ static struct rmap_item *unstable_tree_search_insert(struct page *page, struct rmap_item *tree_rmap_item; int ret; + cond_resched(); tree_rmap_item = rb_entry(*new, struct rmap_item, node); page2[0] = get_mergeable_page(tree_rmap_item); if (!page2[0])