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 516BCC43381 for ; Mon, 1 Apr 2019 07:59:55 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by mail.kernel.org (Postfix) with ESMTP id 1685F20643 for ; Mon, 1 Apr 2019 07:59:55 +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="J18/gB+9"; dkim=fail reason="key not found in DNS" (0-bit key) header.d=codeaurora.org header.i=@codeaurora.org header.b="FHRWJVYc" Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1732233AbfDAH7t (ORCPT ); Mon, 1 Apr 2019 03:59:49 -0400 Received: from smtp.codeaurora.org ([198.145.29.96]:51562 "EHLO smtp.codeaurora.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731944AbfDAH7s (ORCPT ); Mon, 1 Apr 2019 03:59:48 -0400 Received: by smtp.codeaurora.org (Postfix, from userid 1000) id 54CFB61196; Mon, 1 Apr 2019 07:59:47 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1554105587; bh=IZBRzGsg0vvJ7HuYrn+QdFBMYKkeeYJsYsZuV6dEHkk=; h=Date:From:To:Cc:Subject:In-Reply-To:References:From; b=J18/gB+9uGPSn+M2RGwIxKgePKCV+dnIWrcTbLv/Lhwwl1L9Zl0WG+39YPpBD5NBD zWXfVvMEl5/qWdUG0S0zLZLQgOC3Tz2XobvuQwJostW0lNjQ4JSMDdoRfJkKvt8qb7 6q7TUrSaX5KjXq7G/3ll3eY64g552OcEeAk6ea0o= Received: from mail.codeaurora.org (localhost.localdomain [127.0.0.1]) by smtp.codeaurora.org (Postfix) with ESMTP id 44FFC60E5D; Mon, 1 Apr 2019 07:59:44 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1554105585; bh=IZBRzGsg0vvJ7HuYrn+QdFBMYKkeeYJsYsZuV6dEHkk=; h=Date:From:To:Cc:Subject:In-Reply-To:References:From; b=FHRWJVYcusOTLrmXCrCJ7iHmaKGQ+QNnjKA0kzbxlaT6Skg2Ut9cU2wsOTQ6VSilI xqCMuse3nnOXAWm9y7TQ1KsgDi9+y7B04uKWBR+Vk7F2igWknozCkQ+gBxelobUj1z V3CNnnYK799bJmUOi+ln67X9zJosNobAWI87OyfA= MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII; format=flowed Content-Transfer-Encoding: 7bit Date: Mon, 01 Apr 2019 13:29:43 +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: <20190307233039.GA69116@google.com> References: <20190307004041.38059-1-mka@chromium.org> <20190307004041.38059-3-mka@chromium.org> <20190307182009.GB138592@google.com> <20190307233039.GA69116@google.com> Message-ID: 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, 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. > I wished Qualcomm FW developers would get their act together and: > > - send actual command complete events : > - acknowledge a baudrate change request using the current baudrate > like Broadcom and Intel chips apparently do > > this would have saved countless hours of debugging and implementing > quirky workarounds ... > > Maybe there is hope for future chips (hint, hint)? [Bala]: will take this forward to the SoC teams. -- Regards Balakrishna.