Received: by 2002:a05:7412:b995:b0:f9:9502:5bb8 with SMTP id it21csp6406338rdb; Tue, 2 Jan 2024 00:03:50 -0800 (PST) X-Google-Smtp-Source: AGHT+IHJJCH+PBptOOGhsXI7d2zpHMSTJQuG6/MEezH8uCGAWaoOmqC2vyIQ2/N68k/LrqOOGaI8 X-Received: by 2002:a05:620a:454f:b0:781:92f1:caca with SMTP id u15-20020a05620a454f00b0078192f1cacamr10350569qkp.69.1704182630238; Tue, 02 Jan 2024 00:03:50 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1704182630; cv=none; d=google.com; s=arc-20160816; b=gmo4GRtJvZC1ZbhY5Y3QYtM7TXy9D2dibx6fq+zZ7B+wUs3lhGVlkBW1U2kdTh5JoI yfiTU4hqX1K1dAWVP2sRoh0jSu/AHjiXk5fWcgq3bE0pqqpaIYeg9lA69m9UZUBDg6gc oTR7ncfo+dWyOWP6rjqhA9ydhhN9XvEcJLil1jVGz0gR7D/hMg5qO8zVe6tvMQS85nnM NwwnPrmP+hhW5GGx/MtZt7bfzwROuaXJ3e0v0oY74d/lV7iPwyZjB0gwJMkqvOWA/6VU jDD8fk3V75Fis8JLG0nJSiPqiV7Dhnu/rIxfBvgYq/NBQVwVnzUm21eLJquRs2P/5rx+ UY5Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=in-reply-to:content-disposition:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:references:message-id:subject:cc :to:from:date:dkim-signature; bh=xVdCyAdpfUHjmTt45GOA91DVDilEBRbMRwP/Od+dsOk=; fh=VyTrz2t+Al3k438Olj5FwSnYZGN4RCAVlDkXpLfzWqg=; b=eaxJTaQwE9KeDo2VeCp+0K50h9hRXTkTPYlrROU38Hi6XlsEKYsTItLNJpit357neZ sBH8URDMqie2hCQ19/sCSXfo2nJ9TXGA92INF3xxOSKEs7z3BJjkXaXb6a4cTX3FsL/N rYXxm6RltX1VIlC+LoJQPms7ZdY3jJXCDlSsRSOlYnVGeyeCYsFt6l1Hg38dJlDv5zrL /5BZNHQCAG6ZDiWc8/v20+XRKVpxmVAjScstKofor2B5GS3CGlaWS/GRfKPE+SWBA5nm ZVN4yRoRwdR7XNypgbrMEosUN7uZU0UUG5PWSIgvEY7b9hpkSrC8OoVh3Xj/SmEglm9Z DaYg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=liRJtG0C; spf=pass (google.com: domain of linux-kernel+bounces-14130-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) smtp.mailfrom="linux-kernel+bounces-14130-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from ny.mirrors.kernel.org (ny.mirrors.kernel.org. [147.75.199.223]) by mx.google.com with ESMTPS id x22-20020a05620a0b5600b00781784aa6b4si10490063qkg.303.2024.01.02.00.03.50 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 02 Jan 2024 00:03:50 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-14130-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) client-ip=147.75.199.223; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=liRJtG0C; spf=pass (google.com: domain of linux-kernel+bounces-14130-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) smtp.mailfrom="linux-kernel+bounces-14130-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ny.mirrors.kernel.org (Postfix) with ESMTPS id F26E31C2159B for ; Tue, 2 Jan 2024 08:03:49 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id F39CC4429; Tue, 2 Jan 2024 08:03:40 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=linuxfoundation.org header.i=@linuxfoundation.org header.b="liRJtG0C" X-Original-To: linux-kernel@vger.kernel.org Received: from smtp.kernel.org (aws-us-west-2-korg-mail-1.web.codeaurora.org [10.30.226.201]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 07A384C8D; Tue, 2 Jan 2024 08:03:39 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 04E89C433C8; Tue, 2 Jan 2024 08:03:38 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1704182619; bh=G7TbsBighO2IjplER38wkl1W6g99DzQ9SMBnkOmvlWs=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=liRJtG0CIeoBvO67Pa0qb0EBCTeQ+1ZZIsYirwrjtfOSkUVncqvG1rWciP/AB4aju ndVe/cGhG01SJTGu1XOx1Hm8ojyPvoT+R3bGpC6J+QFipu8zyunBuzuRIVzKCrcILz mR5sTYyQ64qhUi3t0vffNNF7OIgRpIQeuCvxTQ1o= Date: Tue, 2 Jan 2024 08:03:36 +0000 From: Greg Kroah-Hartman To: Krishna Kurapati Cc: Maciej =?utf-8?Q?=C5=BBenczykowski?= , Hardik Gajjar , linux-usb@vger.kernel.org, linux-kernel@vger.kernel.org, quic_ppratap@quicinc.com, quic_wcheng@quicinc.com, quic_jackp@quicinc.com Subject: Re: [PATCH] usb: gadget: ncm: Avoid dropping datagrams of properly parsed NTBs Message-ID: <2024010223-snore-unbolted-dc68@gregkh> References: <20240102055143.3889-1-quic_kriskura@quicinc.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20240102055143.3889-1-quic_kriskura@quicinc.com> On Tue, Jan 02, 2024 at 11:21:43AM +0530, Krishna Kurapati wrote: > It is observed sometimes when tethering is used over NCM with Windows 11 > as host, at some instances, the gadget_giveback has one byte appended at > the end of a proper NTB. When the NTB is parsed, unwrap call looks for > any leftover bytes in SKB provided by u_ether and if there are any pending > bytes, it treats them as a separate NTB and parses it. But in case the > second NTB (as per unwrap call) is faulty/corrupt, all the datagrams that > were parsed properly in the first NTB and saved in rx_list are dropped. > > Adding a few custom traces showed the following: > > [002] d..1 7828.532866: dwc3_gadget_giveback: ep1out: > req 000000003868811a length 1025/16384 zsI ==> 0 > [002] d..1 7828.532867: ncm_unwrap_ntb: K: ncm_unwrap_ntb toprocess: 1025 > [002] d..1 7828.532867: ncm_unwrap_ntb: K: ncm_unwrap_ntb nth: 1751999342 > [002] d..1 7828.532868: ncm_unwrap_ntb: K: ncm_unwrap_ntb seq: 0xce67 > [002] d..1 7828.532868: ncm_unwrap_ntb: K: ncm_unwrap_ntb blk_len: 0x400 > [002] d..1 7828.532868: ncm_unwrap_ntb: K: ncm_unwrap_ntb ndp_len: 0x10 > [002] d..1 7828.532869: ncm_unwrap_ntb: K: Parsed NTB with 1 frames > > In this case, the giveback is of 1025 bytes and block length is 1024. > The rest 1 byte (which is 0x00) won't be parsed resulting in drop of > all datagrams in rx_list. > > Same is case with packets of size 2048: > [002] d..1 7828.557948: dwc3_gadget_giveback: ep1out: > req 0000000011dfd96e length 2049/16384 zsI ==> 0 > [002] d..1 7828.557949: ncm_unwrap_ntb: K: ncm_unwrap_ntb nth: 1751999342 > [002] d..1 7828.557950: ncm_unwrap_ntb: K: ncm_unwrap_ntb blk_len: 0x800 > > Lecroy shows one byte coming in extra confirming that the byte is coming > in from PC: > > Transfer 2959 - Bytes Transferred(1025) Timestamp((18.524 843 590) > - Transaction 8391 - Data(1025 bytes) Timestamp(18.524 843 590) > --- Packet 4063861 > Data(1024 bytes) > Duration(2.117us) Idle(14.700ns) Timestamp(18.524 843 590) > --- Packet 4063863 > Data(1 byte) > Duration(66.160ns) Time(282.000ns) Timestamp(18.524 845 722) > > Fix this by checking if the leftover bytes before parsing next NTB is of > size more than the expected header. > > Fixes: 427694cfaafa ("usb: gadget: ncm: Handle decoding of multiple NTB's in unwrap call") > Signed-off-by: Krishna Kurapati > --- > There could probably be cases where the first NTB is proper and the second > NTB's header is proper but the NDP is corrupt, and in those cases too, all > the datagrams are dropped. But I haven't seen such case practically. > > drivers/usb/gadget/function/f_ncm.c | 2 +- > 1 file changed, 1 insertion(+), 1 deletion(-) Hi, This is the friendly patch-bot of Greg Kroah-Hartman. You have sent him a patch that has triggered this response. He used to manually respond to these common problems, but in order to save his sanity (he kept writing the same thing over and over, yet to different people), I was created. Hopefully you will not take offence and will fix the problem in your patch and resubmit it so that it can be accepted into the Linux kernel tree. You are receiving this message because of the following common error(s) as indicated below: - You have marked a patch with a "Fixes:" tag for a commit that is in an older released kernel, yet you do not have a cc: stable line in the signed-off-by area at all, which means that the patch will not be applied to any older kernel releases. To properly fix this, please follow the documented rules in the Documentation/process/stable-kernel-rules.rst file for how to resolve this. If you wish to discuss this problem further, or you have questions about how to resolve this issue, please feel free to respond to this email and Greg will reply once he has dug out from the pending patches received from other developers. thanks, greg k-h's patch email bot