Bluetooth: hci_qca: Add delay for wcn3990 stability
authorJeffrey Hugo <jeffrey.l.hugo@gmail.com>
Thu, 17 Oct 2019 21:29:55 +0000 (14:29 -0700)
committerMarcel Holtmann <marcel@holtmann.org>
Thu, 17 Oct 2019 09:10:06 +0000 (11:10 +0200)
On the msm8998 mtp, the response to the baudrate change command is never
received.  On the Lenovo Miix 630, the response to the baudrate change
command is corrupted - "Frame reassembly failed (-84)".

Adding a 50ms delay before re-enabling flow to receive the baudrate change
command response from the wcn3990 addesses both issues, and allows
bluetooth to become functional.

Signed-off-by: Jeffrey Hugo <jeffrey.l.hugo@gmail.com>
Signed-off-by: Marcel Holtmann <marcel@holtmann.org>
drivers/bluetooth/hci_qca.c

index e3164c2..265fc60 100644 (file)
@@ -1156,8 +1156,10 @@ static int qca_set_speed(struct hci_uart *hu, enum qca_speed_type speed_type)
                host_set_baudrate(hu, speed);
 
 error:
-               if (qca_is_wcn399x(soc_type))
+               if (qca_is_wcn399x(soc_type)) {
+                       msleep(50);
                        hci_uart_set_flow_control(hu, false);
+               }
 
                if (soc_type == QCA_WCN3990) {
                        /* Wait for the controller to send the vendor event