From mboxrd@z Thu Jan 1 00:00:00 1970 From: Stephen Hemminger Subject: Re: [RFC][PATCH 2/9] deadlock prevention core Date: Tue, 8 Aug 2006 13:57:21 -0700 Message-ID: <20060808135721.5af713fb@localhost.localdomain> References: <20060808193325.1396.58813.sendpatchset@lappy> <20060808193345.1396.16773.sendpatchset@lappy> Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Cc: linux-mm@kvack.org, linux-kernel@vger.kernel.org, netdev@vger.kernel.org, Daniel Phillips , Peter Zijlstra Return-path: Received: from smtp.osdl.org ([65.172.181.4]:49041 "EHLO smtp.osdl.org") by vger.kernel.org with ESMTP id S964872AbWHHU5a (ORCPT ); Tue, 8 Aug 2006 16:57:30 -0400 To: Peter Zijlstra In-Reply-To: <20060808193345.1396.16773.sendpatchset@lappy> Sender: netdev-owner@vger.kernel.org List-Id: netdev.vger.kernel.org On Tue, 08 Aug 2006 21:33:45 +0200 Peter Zijlstra wrote: > > The core of the VM deadlock avoidance framework. > > From the 'user' side of things it provides a function to mark a 'struct sock' > as SOCK_MEMALLOC, meaning this socket may dip into the memalloc reserves on > the receive side. > > From the net_device side of things, the extra 'struct net_device *' argument > to {,__}netdev_alloc_skb() is used to attribute/account the memalloc usage. > Converted drivers will make use of this new API and will set NETIF_F_MEMALLOC > to indicate the driver fully supports this feature. > > When a SOCK_MEMALLOC socket is marked, the device is checked for this feature > and tries to increase the memalloc pool; if both succeed, the device is marked > with IFF_MEMALLOC, indicating to {,__}netdev_alloc_skb() that it is OK to dip > into the memalloc pool. > > Memalloc sk_buff allocations are not done from the SLAB but are done using > alloc_pages(). sk_buff::memalloc records this exception so that kfree_skbmem() > can do the right thing. > > Signed-off-by: Peter Zijlstra > Signed-off-by: Daniel Phillips > How much of this is just building special case support for large allocations for jumbo frames? Wouldn't it make more sense to just fix those drivers to do scatter and add the support hooks for that?