Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753188AbZLMW35 (ORCPT ); Sun, 13 Dec 2009 17:29:57 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1751825AbZLMW34 (ORCPT ); Sun, 13 Dec 2009 17:29:56 -0500 Received: from hera.kernel.org ([140.211.167.34]:47507 "EHLO hera.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751788AbZLMW3z (ORCPT ); Sun, 13 Dec 2009 17:29:55 -0500 Message-ID: <4B256A7E.5000508@kernel.org> Date: Sun, 13 Dec 2009 14:28:14 -0800 From: Yinghai Lu User-Agent: Thunderbird 2.0.0.23 (X11/20090817) MIME-Version: 1.0 To: Eric Dumazet CC: David Miller , mingo@elte.hu, sri@us.ibm.com, herbert@gondor.apana.org.au, torvalds@linux-foundation.org, sjayaraman@suse.de, linux-kernel@vger.kernel.org, netdev@vger.kernel.org Subject: Re: nfs broken in net-next? -- now in mainline -- bisected: d9f5950f90292f7cc42834338dfd5f44dc4cc4ca References: <86802c440912112125v4aa72189ifcc2d16ecbf79cc4@mail.gmail.com> <20091211.214117.200029438.davem@davemloft.net> <86802c440912121705y59eea3ebq3bdbd3e7459e748e@mail.gmail.com> <86802c440912121757g474a7df4od6b50f6d5a210cf0@mail.gmail.com> <86802c440912121825h20663affv9ff8d004974d0d31@mail.gmail.com> <86802c440912121841j34cde8ecv892d7d74a32313ac@mail.gmail.com> <4B251CE4.9080401@gmail.com> In-Reply-To: <4B251CE4.9080401@gmail.com> Content-Type: text/plain; charset=ISO-8859-1 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2552 Lines: 83 Eric Dumazet wrote: > Le 13/12/2009 03:41, Yinghai Lu a ?crit : >>>> cause the problem: nfs mount fail. >>>> >>>> the setup is: >>>> 64bit kernel, have all needed drivers in kernel, and boot with >>>> ip=dhcp, root disk is 256M ramdisk. >>>> then try to mount nfs.... >>>> >>> change entries default value from 65536 to 256, >>> nfs mount will work. >>> >> interesting: >> >> m:~/dump # grep UDP dmesg.txt >> [ 28.996034] UDP hash table entries: 65536 (order: 11, 10485760 bytes) >> [ 29.032364] UDP-Lite hash table entries: 65536 (order: 11, 10485760 bytes) >> >> will not work >> >> but 32768 will work. > > Thanks a lot for this work Yinghai ! > This last bit helped me a lot ... > > Hmm, udp_lib_get_port() assumes it can loop at least one time in : > > for (last = first + udptable->mask + 1; > first != last; > first++) { > // unit_work > } > > but if udptable->mask == 65535, loop is not entered at all (since last == first) > > We should convert it to a do { } while(...); construct, or use 32bit variables > and (u16) casts. > > Thanks > > [PATCH] udp: udp_lib_get_port() fix > > Now we can have a large udp hash table, udp_lib_get_port() loop > should be converted to a do {} while (cond) form, > or we dont enter it at all if hash table size is exactly 65536. > > Reported-by: Yinghai Lu > Signed-off-by: Eric Dumazet > --- > diff --git a/net/ipv4/udp.c b/net/ipv4/udp.c > index 1f95348..f0126fd 100644 > --- a/net/ipv4/udp.c > +++ b/net/ipv4/udp.c > @@ -216,9 +216,8 @@ int udp_lib_get_port(struct sock *sk, unsigned short snum, > * force rand to be an odd multiple of UDP_HTABLE_SIZE > */ > rand = (rand | 1) * (udptable->mask + 1); > - for (last = first + udptable->mask + 1; > - first != last; > - first++) { > + last = first + udptable->mask + 1; > + do { > hslot = udp_hashslot(udptable, net, first); > bitmap_zero(bitmap, PORTS_PER_CHAIN); > spin_lock_bh(&hslot->lock); > @@ -238,7 +237,7 @@ int udp_lib_get_port(struct sock *sk, unsigned short snum, > snum += rand; > } while (snum != first); > spin_unlock_bh(&hslot->lock); > - } > + } while (++first != last); > goto fail; > } else { > hslot = udp_hashslot(udptable, net, snum); thanks. that fix the problem. YH -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/