Received: by 2002:a05:6a10:1287:0:0:0:0 with SMTP id d7csp3772452pxv; Mon, 19 Jul 2021 08:24:05 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwYGwGar1sqekLqmZ+4UgzEKvX4bIiIWi9xl0jjiUJw8VJ/fwtYtiVpSWAWCWpWZ4zgrlB8 X-Received: by 2002:a50:9f8e:: with SMTP id c14mr35373145edf.283.1626708245692; Mon, 19 Jul 2021 08:24:05 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626708245; cv=none; d=google.com; s=arc-20160816; b=BNQkZePHOUKENz1j8vxVg+8fRbjSSmexBG3uAR1rSK5lNyvvLLRXZXDs81W5V3R0wy 4tjFBNDgs/l3kHFSbhOQHE+WNNmERRCVJZX8TkWocjCGtHAoPBfAKiPfesv7+Sn6aJP0 TW/jlyhCYEP+tmObWN5L1mw/5X2PyWWYng1T4NgGn1R9a5RuUgvDxRJxJpL8hPPW27XV lLPar+Lzd8tuCpf2Jzt4pyK3CKqxNPwuOAhAGM4SrfZzyQ+Jo+RTgS/3mu/iM6ZVSZ7v hlWP96sniwkVax5WgrQmflUoZVR5UaYie3k7wwXE/SLk4YPuFY9V69MDPFs0iTLlORw7 Q+yg== 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=ntjfZgEgjSHQYUa+NsXc7kJ84u2D6gKNxWpIuOEP6Yc=; b=txF1M/6qdLGTchtFilvMXAPN3tziSxBSK8BDs2mlss2hn172NtcP/SfPyPn87XjFwC dWihfl+LLy0FFh7bygtl4QZCCnLhmHPWOaHE6QV7HN9pAWHrgfh2r9LcZelpR84CQC7p ucSrUQYsRcy7mJdbt7rgjXB8EvtOU0k3CGHCVBBgJVWcy9AvFV87ggNx84u6c7KpfxBM GOdz7IxrFvYCzHa+f1S/G2llOKz2J4cOj0yuQoYXsdpy2yCGpeL+x0YmAY3fMUSEIYTX 1s+aBwflxgHikuAnQ+Wum74ZHNxPtteP5S4mm8SwEjauhAJNhufGf2W2BjMp3lN6G50/ P9EA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=2Bmh29ww; 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 oz32si21133542ejc.718.2021.07.19.08.23.42; Mon, 19 Jul 2021 08:24:05 -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=2Bmh29ww; 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 S245723AbhGSOj0 (ORCPT + 99 others); Mon, 19 Jul 2021 10:39:26 -0400 Received: from mail.kernel.org ([198.145.29.99]:40508 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S244616AbhGSO3x (ORCPT ); Mon, 19 Jul 2021 10:29:53 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id DD5C66113A; Mon, 19 Jul 2021 15:10:15 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1626707416; bh=grkEjosmlW7zlW8HPokuK+9bc9XrMK0ts/pfTBaXc38=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=2Bmh29wwQSBY5i2xNB9JWVCI2OJrwuog0SNB6f9VkZff62ii50XS5+j6AkMTzO+DS z6M3F6GE3M1ta/t922POMPsevj4lkB00NWsxQxILMOJGQyZiN9LchBxlTkM6v7wS3x u9ZHpIHrX5yi4+DwH1drnz4HmRMSewCdkVuTL5JA= 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.9 155/245] Bluetooth: btusb: fix bt fiwmare downloading failure issue for qca btsoc. Date: Mon, 19 Jul 2021 16:51:37 +0200 Message-Id: <20210719144945.409865923@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210719144940.288257948@linuxfoundation.org> References: <20210719144940.288257948@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 4e3b24a0511f..30c09b9ddbf0 100644 --- a/drivers/bluetooth/btusb.c +++ b/drivers/bluetooth/btusb.c @@ -2508,6 +2508,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