mm, swap_cgroup: reschedule when neeed in swap_cgroup_swapoff()
commit 460bcec84e11c75122ace5976214abbc596eb91b upstream. We got need_resched() warnings in swap_cgroup_swapoff() because swap_cgroup_ctrl[type].length is particularly large. Reschedule when needed. Link: http://lkml.kernel.org/r/alpine.DEB.2.10.1704061315270.80559@chino.kir.corp.google.com Signed-off-by: David Rientjes <rientjes@google.com> Acked-by: Michal Hocko <mhocko@suse.com> Cc: Johannes Weiner <hannes@cmpxchg.org> Cc: Vladimir Davydov <vdavydov.dev@gmail.com> Cc: KAMEZAWA Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org> Cc: Ben Hutchings <ben.hutchings@codethink.co.uk> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
a9e5044b68
commit
74de12dbfa
1 changed files with 2 additions and 0 deletions
|
@ -205,6 +205,8 @@ void swap_cgroup_swapoff(int type)
|
|||
struct page *page = map[i];
|
||||
if (page)
|
||||
__free_page(page);
|
||||
if (!(i % SWAP_CLUSTER_MAX))
|
||||
cond_resched();
|
||||
}
|
||||
vfree(map);
|
||||
}
|
||||
|
|
Loading…
Add table
Reference in a new issue