|
@@ -3291,10 +3291,13 @@ __alloc_pages_may_oom(gfp_t gfp_mask, unsigned int order,
|
|
/*
|
|
/*
|
|
* Go through the zonelist yet one more time, keep very high watermark
|
|
* Go through the zonelist yet one more time, keep very high watermark
|
|
* here, this is only to catch a parallel oom killing, we must fail if
|
|
* here, this is only to catch a parallel oom killing, we must fail if
|
|
- * we're still under heavy pressure.
|
|
|
|
|
|
+ * we're still under heavy pressure. But make sure that this reclaim
|
|
|
|
+ * attempt shall not depend on __GFP_DIRECT_RECLAIM && !__GFP_NORETRY
|
|
|
|
+ * allocation which will never fail due to oom_lock already held.
|
|
*/
|
|
*/
|
|
- page = get_page_from_freelist(gfp_mask | __GFP_HARDWALL, order,
|
|
|
|
- ALLOC_WMARK_HIGH|ALLOC_CPUSET, ac);
|
|
|
|
|
|
+ page = get_page_from_freelist((gfp_mask | __GFP_HARDWALL) &
|
|
|
|
+ ~__GFP_DIRECT_RECLAIM, order,
|
|
|
|
+ ALLOC_WMARK_HIGH|ALLOC_CPUSET, ac);
|
|
if (page)
|
|
if (page)
|
|
goto out;
|
|
goto out;
|
|
|
|
|