From mboxrd@z Thu Jan 1 00:00:00 1970 From: Jim Baxter Subject: Re: [PATCH v1 3/3] usb: gadget: NCM: Stop RX TCP Bursts getting dropped. Date: Thu, 12 Jun 2014 10:38:11 +0100 Message-ID: <53997503.7040109@mentor.com> References: <1401383543-10181-1-git-send-email-jim_baxter@mentor.com> <1401383543-10181-4-git-send-email-jim_baxter@mentor.com> <1401390263.3645.51.camel@edumazet-glaptop2.roam.corp.google.com> <53886ABC.8030303@mentor.com> Mime-Version: 1.0 Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: 7bit Cc: Felipe Balbi , Greg Kroah-Hartman , , , =?UTF-8?B?QmrDuA==?= =?UTF-8?B?cm4gTW9yaw==?= , David Laight , To: Eric Dumazet Return-path: Received: from relay1.mentorg.com ([192.94.38.131]:61985 "EHLO relay1.mentorg.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932740AbaFLJiT (ORCPT ); Thu, 12 Jun 2014 05:38:19 -0400 In-Reply-To: <53886ABC.8030303@mentor.com> Sender: netdev-owner@vger.kernel.org List-ID: On 30/05/14 12:25, Jim Baxter wrote: > On 29/05/14 20:04, Eric Dumazet wrote: >> On Thu, 2014-05-29 at 18:12 +0100, Jim Baxter wrote: >> >> Note the patch is OK, but changelog a bit misleading ;) >> >> Kernel was not running out of memory, because truesize was correct. >> >> The problem here is that a frame was consuming more kernel memory than >> really needed, so chances of hitting socket sk_rcvbuf limit was high. >> >> BTW : >> #define NTB_OUT_SIZE 16384 >> >> alloc_skb(size) -> >> kmalloc(16384 + sizeof(struct skb_shared_info)) -> >> roundup() => 32768 >> >> So truesize of the skb was infact ~32KB, which is really insane indeed. >> After your patch, its back to ~2KB >> >> Acked-by: Eric Dumazet >> >> >> > > Thank you, I will clarify the description. > > Jim > Hi Eric, Is this commit log more correct? This fixes a problem with dropped packets over 16k CDC-NCM when the connection is being heavily used. The issue was that the extracted frames cloned from the received frame were consuming more memory than necessary due to the truesize being ~32KB instead of ~2KB, this meant there was a high chance of reaching the sk_rcvbuf limit. Acked-by: Eric Dumazet Signed-off-by: Jim Baxter Thank you, Jim