From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754075Ab0HYUo4 (ORCPT ); Wed, 25 Aug 2010 16:44:56 -0400 Received: from mail-wy0-f174.google.com ([74.125.82.174]:62597 "EHLO mail-wy0-f174.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753255Ab0HYUoy (ORCPT ); Wed, 25 Aug 2010 16:44:54 -0400 DomainKey-Signature: a=rsa-sha1; c=nofws; d=gmail.com; s=gamma; h=subject:from:to:cc:in-reply-to:references:content-type:date :message-id:mime-version:x-mailer:content-transfer-encoding; b=d+UHLOHYRECU3oEdd/zwNOU53qRXxNCf3nDZpcD56Za02OouLViKkRRg6hpIx979aY KiMOeRR5DAcCLzVTOBRnhMpXnogyB2h9/dFCaVjghVjfmOE+IQoBo0jTK4idGLgskSzR 8Wy25dNRLGGbob01eEfziFtJb/Tm7Hm9hqJR0= Subject: Re: [2.6.35-rc1] page alloc failure order:1, mode:0x4020 From: Eric Dumazet To: Nikhil Sethi =?UTF-8?Q?=28=E0=A4=A8=E0=A4=BF=E0=A4=96=E0=A4=BF=E0=A4=B2_?= =?UTF-8?Q?=E0=A4=B8=E0=A5=87=E0=A4=A0=E0=A5=80=29?= Cc: Michael Guntsche , linux-kernel , netdev In-Reply-To: References: <20100604092025.GA96690@trillian.comsick.at> <1275656014.2482.169.camel@edumazet-laptop> <20100604161644.GA98048@trillian.local> <20100606095640.GA4436@trillian.comsick.at> <1275820945.5238.987.camel@edumazet-laptop> Content-Type: text/plain; charset="UTF-8" Date: Wed, 25 Aug 2010 22:44:49 +0200 Message-ID: <1282769089.2681.159.camel@edumazet-laptop> Mime-Version: 1.0 X-Mailer: Evolution 2.28.3 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Le mercredi 25 août 2010 à 13:25 -0700, Nikhil Sethi (निखिल सेठी) a écrit : > Hello. > > I am running 2.5.35.3 with the above patch, and I still get these > failures. Though they are much less often than without the patch. A > snippet from dmesg below. > > Please let me know what other details I should provide. Thanks > > skbuff alloc of size 3872 failed > java: page allocation failure. order:1, mode:0x4020 > Pid: 11464, comm: java Not tainted 2.6.35.3 #3 > Call Trace: > [] ? __alloc_pages_nodemask+0x3e6/0x513 > [] ? __slab_alloc+0x2d7/0x2eb > [] ? __kmalloc_track_caller+0x74/0x95 > [] ? ath_rxbuf_alloc+0x1a/0x78 [ath] > [] ? ath_rxbuf_alloc+0x1a/0x78 [ath] > [] ? __alloc_skb+0x57/0x100 > [] ? ath_rxbuf_alloc+0x1a/0x78 [ath] > [] ? ath_rx_tasklet+0x2fb/0x808 [ath9k] > [] ? br_handle_frame+0x1b3/0x1c3 [bridge] > [] ? __netif_receive_skb+0x141/0x25f > [] ? ath9k_tasklet+0xcc/0x107 [ath9k] > [] ? tasklet_action+0x5f/0x65 > [] ? __do_softirq+0x60/0xc6 > [] ? do_softirq+0x2e/0x30 > [] ? irq_exit+0x53/0x55 > [] ? do_IRQ+0x3a/0x72 > [] ? common_interrupt+0x29/0x30 > Mem-Info: > DMA per-cpu: > CPU 0: hi: 0, btch: 1 usd: 0 > Normal per-cpu: > CPU 0: hi: 90, btch: 15 usd: 32 > active_anon:6158 inactive_anon:15748 isolated_anon:0 > active_file:11477 inactive_file:22926 isolated_file:0 > unevictable:468 dirty:5788 writeback:0 unstable:0 > free:990 slab_reclaimable:3091 slab_unreclaimable:2349 > mapped:1410 shmem:5 pagetables:227 bounce:0 > DMA free:1000kB min:124kB low:152kB high:184kB active_anon:1304kB > inactive_anon:2304kB active_file:2584kB inactive_file:4900kB > unevictable:0kB isolated(anon):0kB isolated(file):0kB present:15864kB > mlocked:0kB dirty:0kB writeback:0kB mapped:284kB shmem:0kB > slab_reclaimable:648kB slab_unreclaimable:752kB kernel_stack:152kB > pagetables:0kB unstable:0kB bounce:0kB writeback_tmp:0kB > pages_scanned:0 all_unreclaimable? no > lowmem_reserve[]: 0 238 238 > Normal free:2960kB min:1908kB low:2384kB high:2860kB > active_anon:23328kB inactive_anon:60688kB active_file:43324kB > inactive_file:86804kB unevictable:1872kB isolated(anon):0kB > isolated(file):0kB present:243840kB mlocked:1872kB dirty:23152kB > writeback:0kB mapped:5356kB shmem:20kB slab_reclaimable:11716kB > slab_unreclaimable:8644kB kernel_stack:888kB pagetables:908kB > unstable:0kB bounce:0kB writeback_tmp:0kB pages_scanned:0 > all_unreclaimable? no > lowmem_reserve[]: 0 0 0 > DMA: 76*4kB 29*8kB 5*16kB 0*32kB 0*64kB 1*128kB 1*256kB 0*512kB > 0*1024kB 0*2048kB 0*4096kB = 1000kB > Normal: 650*4kB 9*8kB 2*16kB 8*32kB 0*64kB 0*128kB 0*256kB 0*512kB > 0*1024kB 0*2048kB 0*4096kB = 2960kB > 37964 total pagecache pages > 3160 pages in swap cache > Swap cache stats: add 164954, delete 161794, find 97931/115609 > Free swap = 937284kB > Total swap = 963896kB > 65535 pages RAM > 1237 pages reserved > 29042 pages shared > 38802 pages non-shared > SLUB: Unable to allocate memory on node -1 (gfp=0x20) > cache: kmalloc-8192, object size: 8192, buffer size: 8192, default > order: 3, min order: 1 > node 0: slabs: 0, objs: 0, free: 0 > skbuff alloc of size 3872 failed > java: page allocation failure. order:1, mode:0x4020 > Pid: 11464, comm: java Not tainted 2.6.35.3 #3 > Call Trace: > [] ? __alloc_pages_nodemask+0x3e6/0x513 > [] ? __slab_alloc+0x2d7/0x2eb > [] ? __kmalloc_track_caller+0x74/0x95 > [] ? ath_rxbuf_alloc+0x1a/0x78 [ath] > [] ? ath_rxbuf_alloc+0x1a/0x78 [ath] > [] ? __alloc_skb+0x57/0x100 > [] ? ath_rxbuf_alloc+0x1a/0x78 [ath] > [] ? ath_rx_tasklet+0x2fb/0x808 [ath9k] > [] ? br_handle_frame+0x1b3/0x1c3 [bridge] > [] ? __netif_receive_skb+0x141/0x25f > [] ? ath9k_tasklet+0xcc/0x107 [ath9k] > [] ? tasklet_action+0x5f/0x65 > [] ? __do_softirq+0x60/0xc6 > [] ? do_softirq+0x2e/0x30 > [] ? irq_exit+0x53/0x55 > [] ? do_IRQ+0x3a/0x72 > [] ? common_interrupt+0x29/0x30 > Mem-Info: > DMA per-cpu: > CPU 0: hi: 0, btch: 1 usd: 0 > Normal per-cpu: > CPU 0: hi: 90, btch: 15 usd: 32 > active_anon:6158 inactive_anon:15748 isolated_anon:0 > active_file:11477 inactive_file:22926 isolated_file:0 > unevictable:468 dirty:5788 writeback:0 unstable:0 > free:990 slab_reclaimable:3091 slab_unreclaimable:2349 > mapped:1410 shmem:5 pagetables:227 bounce:0 > DMA free:1000kB min:124kB low:152kB high:184kB active_anon:1304kB > inactive_anon:2304kB active_file:2584kB inactive_file:4900kB > unevictable:0kB isolated(anon):0kB isolated(file):0kB present:15864kB > mlocked:0kB dirty:0kB writeback:0kB mapped:284kB shmem:0kB > slab_reclaimable:648kB slab_unreclaimable:752kB kernel_stack:152kB > pagetables:0kB unstable:0kB bounce:0kB writeback_tmp:0kB > pages_scanned:0 all_unreclaimable? no > lowmem_reserve[]: 0 238 238 > Normal free:2960kB min:1908kB low:2384kB high:2860kB > active_anon:23328kB inactive_anon:60688kB active_file:43324kB > inactive_file:86804kB unevictable:1872kB isolated(anon):0kB > isolated(file):0kB present:243840kB mlocked:1872kB dirty:23152kB > writeback:0kB mapped:5356kB shmem:20kB slab_reclaimable:11716kB > slab_unreclaimable:8644kB kernel_stack:888kB pagetables:908kB > unstable:0kB bounce:0kB writeback_tmp:0kB pages_scanned:0 > all_unreclaimable? no > lowmem_reserve[]: 0 0 0 > DMA: 76*4kB 29*8kB 5*16kB 0*32kB 0*64kB 1*128kB 1*256kB 0*512kB > 0*1024kB 0*2048kB 0*4096kB = 1000kB > Normal: 650*4kB 9*8kB 2*16kB 8*32kB 0*64kB 0*128kB 0*256kB 0*512kB > 0*1024kB 0*2048kB 0*4096kB = 2960kB > 37964 total pagecache pages > 3160 pages in swap cache > > On Sun, Jun 6, 2010 at 3:42 AM, Eric Dumazet wrote: > > > > Le dimanche 06 juin 2010 à 11:56 +0200, Michael Guntsche a écrit : > > > On 2010.06.04 18:16:44 , Michael Guntsche wrote: > > > > I applied the patch recompiled and run it on the routerboard, trying > > > > to trigger the bug again. > > > > > > Hi Eric, > > > > > > Up to now I was not able to reproduce the bug, do you think this patch > > > can be pushed to mainline or is there a "better"/other fix for it? > > > > > > Kind regards, > > > Michael > > > > > > > > > > Thanks Michael for testing. > > > > I'll submit ASAP an official patch, sent to all people involved in this > > driver to get their Ack (or Nack). > > > > IEEE80211_MAX_MPDU_LEN being 3840 + somebits is suspect, since it doesnt > > match 802.11 specs. > > > > It should be more close of 2304 + MAC header (32bytes) + FCS (4 bytes) ? > > > > > > > > -- reading my former patch, I believe I mistakenly used a max_t() instead of a min_() macro : diff --git a/drivers/net/wireless/ath/ath9k/recv.c b/drivers/net/wireless/ath/ath9k/recv.c index ca6065b..0a0dc3a 100644 --- a/drivers/net/wireless/ath/ath9k/recv.c +++ b/drivers/net/wireless/ath/ath9k/recv.c @@ -226,10 +226,10 @@ static int ath_rx_edma_init(struct ath_softc *sc, int nbufs) u32 size; - common->rx_bufsize = roundup(IEEE80211_MAX_MPDU_LEN + - ah->caps.rx_status_len, - min(common->cachelsz, (u16)64)); - + size = roundup(IEEE80211_MAX_MPDU_LEN + ah->caps.rx_status_len, + min(common->cachelsz, (u16)64)); + common->rx_bufsize = max_t(u32, size, + SKB_MAX_ORDER(NET_SKB_PAD + common->cachelsz, 0)); ath9k_hw_set_rx_bufsize(ah, common->rx_bufsize - ah->caps.rx_status_len); Please use instead this one : diff --git a/drivers/net/wireless/ath/ath9k/recv.c b/drivers/net/wireless/ath/ath9k/recv.c index ca6065b..0a0dc3a 100644 --- a/drivers/net/wireless/ath/ath9k/recv.c +++ b/drivers/net/wireless/ath/ath9k/recv.c @@ -226,10 +226,10 @@ static int ath_rx_edma_init(struct ath_softc *sc, int nbufs) u32 size; - common->rx_bufsize = roundup(IEEE80211_MAX_MPDU_LEN + - ah->caps.rx_status_len, - min(common->cachelsz, (u16)64)); - + size = roundup(IEEE80211_MAX_MPDU_LEN + ah->caps.rx_status_len, + min(common->cachelsz, (u16)64)); + common->rx_bufsize = min_t(u32, size, + SKB_MAX_ORDER(NET_SKB_PAD + common->cachelsz, 0)); ath9k_hw_set_rx_bufsize(ah, common->rx_bufsize - ah->caps.rx_status_len);