Re: [PATCH 29 of 66] don't alloc harder for gfp nomemalloc even if nowait

From: KOSAKI Motohiro
Date: Mon Nov 08 2010 - 22:05:51 EST


> From: Andrea Arcangeli <aarcange@xxxxxxxxxx>
>
> Not worth throwing away the precious reserved free memory pool for allocations
> that can fail gracefully (either through mempool or because they're transhuge
> allocations later falling back to 4k allocations).
>
> Signed-off-by: Andrea Arcangeli <aarcange@xxxxxxxxxx>
> Acked-by: Rik van Riel <riel@xxxxxxxxxx>
> ---
>
> diff --git a/mm/page_alloc.c b/mm/page_alloc.c
> --- a/mm/page_alloc.c
> +++ b/mm/page_alloc.c
> @@ -1941,7 +1941,12 @@ gfp_to_alloc_flags(gfp_t gfp_mask)
> alloc_flags |= (__force int) (gfp_mask & __GFP_HIGH);
>
> if (!wait) {
> - alloc_flags |= ALLOC_HARDER;
> + /*
> + * Not worth trying to allocate harder for
> + * __GFP_NOMEMALLOC even if it can't schedule.
> + */
> + if (!(gfp_mask & __GFP_NOMEMALLOC))
> + alloc_flags |= ALLOC_HARDER;
> /*
> * Ignore cpuset if GFP_ATOMIC (!wait) rather than fail alloc.
> * See also cpuset_zone_allowed() comment in kernel/cpuset.c.

I like this.
Reviewed-by: KOSAKI Motohiro <kosaki.motohiro@xxxxxxxxxxxxxx>




--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/