From mboxrd@z Thu Jan 1 00:00:00 1970 From: Eric Dumazet Subject: Re: [PATCH V4] mlx4_core: allocate ICM memory in page size chunks Date: Thu, 31 May 2018 04:35:31 -0400 Message-ID: References: <20180523232246.20445-1-qing.huang@oracle.com> <20180525.102321.858995452200286788.davem@davemloft.net> <7a353b65-6b7f-1aee-1c48-e83c8e02f693@gmail.com> <0e11e0fc-6ccf-aa93-9c4f-b9eae1b90643@gmail.com> <20180531065405.GH15278@dhcp22.suse.cz> Mime-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 7bit Cc: David Miller , qing.huang@oracle.com, tariqt@mellanox.com, haakon.bugge@oracle.com, yanjun.zhu@oracle.com, netdev@vger.kernel.org, linux-rdma@vger.kernel.org, linux-kernel@vger.kernel.org, gi-oh.kim@profitbricks.com To: Michal Hocko , Eric Dumazet Return-path: In-Reply-To: <20180531065405.GH15278@dhcp22.suse.cz> Content-Language: en-US Sender: linux-kernel-owner@vger.kernel.org List-Id: netdev.vger.kernel.org On 05/31/2018 02:54 AM, Michal Hocko wrote: > On Tue 29-05-18 23:49:59, Eric Dumazet wrote: >> >> >> On 05/29/2018 11:44 PM, Eric Dumazet wrote: >> >>> >>> And I will add this simple fix, this really should address your initial concern much better. >>> >>> @@ -99,6 +100,8 @@ static int mlx4_alloc_icm_pages(struct scatterlist *mem, int order, >>> { >>> struct page *page; >>> >>> + if (order) >>> + gfp_mask |= __GFP_NORETRY; >> >> and also gfp_mask &= ~__GFP_DIRECT_RECLAIM > > JFTR the latter one makes __GFP_NORETRY pointless. Non sleeping allocations > are not retrying. Hi Michal Since when this rule is applied ? These GFP flags change all the time, I suggest mm experts to cleanup existing call sites ? I merely copied/pasted from alloc_skb_with_frags() :/ Thanks !