Received: by 2002:a05:6a10:1287:0:0:0:0 with SMTP id d7csp4162948pxv; Mon, 19 Jul 2021 18:57:10 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxaJgRSE8hHfXzlpo26xLfyoBrirSjHiCrDsZwmVQeNgBfUfYSfJ0re7ztOtA+WpTuYNyP9 X-Received: by 2002:a17:906:1701:: with SMTP id c1mr29896391eje.425.1626746230507; Mon, 19 Jul 2021 18:57:10 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626746230; cv=none; d=google.com; s=arc-20160816; b=pJqI/r7ci4AlCTj7uql7c0t7FQvHsuaUd9zACmW/40XuaXVHWmTiEd8zilguW3m1uF 3n3uAzGyFOHxknP6Rq6PXrjrKTgXIvp7iXtiP2U+7HP7a5VUgm6r+Ih1RLF0hoH9q+Qk IRLbtU4DxyrNVQwkTWqEtRV4KB5L6Y/wcYiyCJPHktLgByMR1YCATb75JhnFZHLcnTtZ wRWAtxNXwXik8dJ6OMtlJXf/2jDsnFL3hKc6yzpV8eqznXUJo4YIVDrsZRTxpdd1RZAo F2yhJBZPwn/2yBy451w+IylYn12OLKKe+TR0x1g/QrPUHrBB7xkrnhY63Q7fuE7DmJr4 qdVg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=Kn4xzg9GaDRQxo7jfXCa4EWxVsl8XrMPtZ9YKuZOjpA=; b=U7p5Z6fiRuP+pH6T3N8KV+LDLPS2HjtIm4+USZmSFU0TMikWVTbH0FXstDnySB+LYV E522tsIfaTThkmVdbnCpv6wnjKuRg43r3PNSPhCxPUbByTidqrO9ftKqaLm27tK9+xlG dxmk3QoRNT/PV5D192cQDuCpqkoBLZCnwn+NMo/7ovvD6WQ8SuE03rZOl+6cx+ZTmp8c u/oMnf90PrZdSzmbsWSo3L1mnPAphXueR01WK2Vfv92QH6y5KMQItiztBaCoSS9n+dfN 0Dl5wyjpxtF6Or1qw+lid4R++rdv89OGZXdcRrvYAZlH2726Ndtp0c2IPIg2fNMpJ4bh /fYQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=KT4nSl+f; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id m4si22247741ejl.583.2021.07.19.18.56.47; Mon, 19 Jul 2021 18:57:10 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=KT4nSl+f; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1347555AbhGSPTp (ORCPT + 99 others); Mon, 19 Jul 2021 11:19:45 -0400 Received: from mail.kernel.org ([198.145.29.99]:35202 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S237711AbhGSOoJ (ORCPT ); Mon, 19 Jul 2021 10:44:09 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 872A86120E; Mon, 19 Jul 2021 15:22:27 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1626708148; bh=flRU1/nWCDRQ6R0bshuPatNPWKM0h0EUK/k/aA8oMCQ=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=KT4nSl+fkGC9Z3fMrwGeBlBPi+N5tEXfrHJ137EBDpghJwO4u8w/4xj8may5hxvSK ZXlB+09hhq8cjVNWbNUFGNS69da614sKlNzFmPq0oqxpJp7p2VoPnURR+HYnt4XUR6 Z7SG66ruDUkRbp+YKxZ9KoE7O2eMMGsToenOJ8oo= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Tim Jiang , Marcel Holtmann , Sasha Levin Subject: [PATCH 4.14 199/315] Bluetooth: btusb: fix bt fiwmare downloading failure issue for qca btsoc. Date: Mon, 19 Jul 2021 16:51:28 +0200 Message-Id: <20210719144949.971770642@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210719144942.861561397@linuxfoundation.org> References: <20210719144942.861561397@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Tim Jiang [ Upstream commit 4f00bfb372674d586c4a261bfc595cbce101fbb6 ] This is btsoc timing issue, after host start to downloading bt firmware, ep2 need time to switch from function acl to function dfu, so host add 20ms delay as workaround. Signed-off-by: Tim Jiang Signed-off-by: Marcel Holtmann Signed-off-by: Sasha Levin --- drivers/bluetooth/btusb.c | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/drivers/bluetooth/btusb.c b/drivers/bluetooth/btusb.c index 424f399cc79b..f2e84e09c970 100644 --- a/drivers/bluetooth/btusb.c +++ b/drivers/bluetooth/btusb.c @@ -2614,6 +2614,11 @@ static int btusb_setup_qca_download_fw(struct hci_dev *hdev, sent += size; count -= size; + /* ep2 need time to switch from function acl to function dfu, + * so we add 20ms delay here. + */ + msleep(20); + while (count) { size = min_t(size_t, count, QCA_DFU_PACKET_LEN); -- 2.30.2