Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-3.8 required=3.0 tests=DKIM_INVALID,DKIM_SIGNED, HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI,SIGNED_OFF_BY,SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 3AA21C4360F for ; Tue, 2 Apr 2019 12:03:02 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by mail.kernel.org (Postfix) with ESMTP id F1BAE20883 for ; Tue, 2 Apr 2019 12:03:01 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=fail reason="key not found in DNS" (0-bit key) header.d=codeaurora.org header.i=@codeaurora.org header.b="eU9Ik/20"; dkim=fail reason="key not found in DNS" (0-bit key) header.d=codeaurora.org header.i=@codeaurora.org header.b="Qu44IbHZ" Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730834AbfDBMC5 (ORCPT ); Tue, 2 Apr 2019 08:02:57 -0400 Received: from smtp.codeaurora.org ([198.145.29.96]:37354 "EHLO smtp.codeaurora.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726903AbfDBMC4 (ORCPT ); Tue, 2 Apr 2019 08:02:56 -0400 Received: by smtp.codeaurora.org (Postfix, from userid 1000) id 9712D609EF; Tue, 2 Apr 2019 12:02:55 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1554206575; bh=BvXshpmlmRjUItSkb18/i86HqgQzgkht+YcDge8yxCk=; h=Date:From:To:Cc:Subject:In-Reply-To:References:From; b=eU9Ik/20O9CMflRzamcwWobD4KL5UMU0aoL0cbTxTiClyuxFqwpyF/3MxN59fI+Ba ++IFSmvfZKe/5MhmTI6xjU1nCrJTaDO1RTge43vGv2vx4BvyYP1bnrz2Vt/vFRqqp6 xmukgpFz3XP4XiShjmsR2C3XRnwqmFLexFDqjct8= Received: from mail.codeaurora.org (localhost.localdomain [127.0.0.1]) by smtp.codeaurora.org (Postfix) with ESMTP id 11258602BA; Tue, 2 Apr 2019 12:02:54 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1554206574; bh=BvXshpmlmRjUItSkb18/i86HqgQzgkht+YcDge8yxCk=; h=Date:From:To:Cc:Subject:In-Reply-To:References:From; b=Qu44IbHZduyowLCkWN2uk82GViCqk0D334gjbO4fvBNnJQIolYD5achwXxqNwygoM f2jKUuYYk9L2gOmNxaIhLfYy46TDxfI6lwTJDylSdqQRx8AQnyqHa3VVPhXpbytKnA a5uPgkeI8Do8CsI94jikN71ETDw36yS/ATRWgV48= MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII; format=flowed Content-Transfer-Encoding: 7bit Date: Tue, 02 Apr 2019 17:32:54 +0530 From: Balakrishna Godavarthi To: Matthias Kaehlcke Cc: Marcel Holtmann , Johan Hedberg , linux-bluetooth@vger.kernel.org, linux-kernel@vger.kernel.org, Hemantg Subject: Re: [PATCH 2/2] Bluetooth: hci_qca: wcn3990: Drop baudrate change vendor event In-Reply-To: <20190401171202.GH112750@google.com> References: <20190307004041.38059-1-mka@chromium.org> <20190307004041.38059-3-mka@chromium.org> <20190307182009.GB138592@google.com> <20190307233039.GA69116@google.com> <20190401171202.GH112750@google.com> Message-ID: <1bebaf0766988a9f27cbbcb9bb35e26f@codeaurora.org> X-Sender: bgodavar@codeaurora.org User-Agent: Roundcube Webmail/1.2.5 Sender: linux-bluetooth-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-bluetooth@vger.kernel.org Hi Matthias, On 2019-04-01 22:42, Matthias Kaehlcke wrote: > On Mon, Apr 01, 2019 at 01:48:23PM +0530, Balakrishna Godavarthi wrote: >> Hi Matthias, >> >> On 2019-04-01 13:29, Balakrishna Godavarthi wrote: >> > Hi Matthias, >> > >> > Sorry for the late reply i was on vacation. >> > >> > On 2019-03-08 05:00, Matthias Kaehlcke wrote: >> > > On Thu, Mar 07, 2019 at 10:20:09AM -0800, Matthias Kaehlcke wrote: >> > > > Hi Balakrishna, >> > > > >> > > > On Thu, Mar 07, 2019 at 10:35:08AM +0530, Balakrishna Godavarthi >> > > > wrote: >> > > > > hi Matthias, >> > > > > >> > > > > On 2019-03-07 06:10, Matthias Kaehlcke wrote: >> > > > > > Firmware download to the WCN3990 often fails with a 'TLV response size >> > > > > > mismatch' error: >> > > > > > >> > > > > > [ 133.064659] Bluetooth: hci0: setting up wcn3990 >> > > > > > [ 133.489150] Bluetooth: hci0: QCA controller version 0x02140201 >> > > > > > [ 133.495245] Bluetooth: hci0: QCA Downloading qca/crbtfw21.tlv >> > > > > > [ 133.507214] Bluetooth: hci0: QCA TLV response size mismatch >> > > > > > [ 133.513265] Bluetooth: hci0: QCA Failed to download patch (-84) >> > > > > > >> > > > > > This is caused by a vendor event that corresponds to an earlier command >> > > > > > to change the baudrate. The event is not processed in the context of the >> > > > > > baudrate change and later interpreted as response to the firmware >> > > > > > download command (which is also a vendor command), but the driver >> > > > > > detects >> > > > > > that the event doesn't have the expected amount of associated data. >> > > > > > >> > > > > > More details: >> > > > > > >> > > > > > For the WCN3990 the vendor command for a baudrate change isn't sent as >> > > > > > synchronous HCI command, because the controller sends the corresponding >> > > > > > vendor event with the new baudrate. The event is received and decoded >> > > > > > after the baudrate change of the host port. >> > > > > > >> > > > > > Identify the 'unused' event when it is received and don't add it to >> > > > > > the queue of RX frames. >> > > > > > >> > > > > > Signed-off-by: Matthias Kaehlcke >> > > > > > --- >> > > > > >> > > > > ... >> > > > > >> > > > > Can you test by reverting this change "94d6671473924". >> > > > >> > > > The issue is still reproducible. >> > > > >> > > > > We need at least 15ms minimum delay for the soc to change its baud rate and >> > > > > respond to the with command complete event. >> > > > >> > > > The baudrate change has clearly been successful when the problem is >> > > > observed, since the host receives the vendor event with the new >> > > > baudrate. >> > > >> > > I forgot to mention this earlier: the controller doesn't send a >> > > command complete event for the command, or at least not a correct >> > > one. >> > > >> > > That's the data that is received: >> > > >> > > 04 0e 04 01 00 00 00 >> > > ~~ ~~ >> > > >> > [Bala]: can you share me the command sent and event recevied. >> > I see that we receive a command complete event for the baud rate >> > change command. >> > >> > command sent: 01 48 fc 01 11 >> > vendor specific event: 04 ff 02 92 01 >> > command complete event: 04 0e 04 01 00 00 00. >> > >> > >> > >> > > This is *a* command complete event, but the opcode is 0x0000 instead >> > > of the earlier command. The same happens for the firmware >> > > download/read version command, which is the reason why the command >> > > complete injection mess >> > > (https://lore.kernel.org/patchwork/patch/1027955/) is needed in one >> > > way or another. >> > > >> > [Bala]: fw download approach is different where we use >> > __hci_cmd_sync() where as here we use hci_uart_tx_wakeup() >> > which directly calls the hci_uart_write_work(). so even we >> > send an valid opcode or not for baudrate change will bot matter. >> > >> [Bala]: i miss understood the comment. Yes your true. in the all >> vendor >> commands SoC responds with an 0x0000 opcode. > > And IIUC this is not compliant with the spec, or at least the BT core > expects the actual opcode to consider the command to be completed. [Bala]: Did you try increasing the the baud rate change timeout to 50ms instead of 10ms. i suspect it is an timing issue. I have see on the hardware sniffer that the chip is responding with command complete event with the newer baud rate after 15ms. -- Regards Balakrishna.