Received: by 2002:a05:6a10:1287:0:0:0:0 with SMTP id d7csp659314pxv; Thu, 15 Jul 2021 12:44:05 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwgaB7FPPJSf3BY26si+QXryL0UjdnOagIa2vmbbWNTkypVZXf0SP4sZz839hj9gkPUrxc6 X-Received: by 2002:a17:906:b204:: with SMTP id p4mr7302841ejz.239.1626378245057; Thu, 15 Jul 2021 12:44:05 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626378245; cv=none; d=google.com; s=arc-20160816; b=aE+9SOsnIOANGLwTWXzY7SH389H8lz31fNyzgvcLm4eu/hP8WyBa80Q7mq8cmoaXwy Iq8YLFd7UrXV6rO3hVAWsybsl34mrOsJjNCtCV7mPDAry5P39wSQwLZx2+3cysl1J6Sp SkCb3GygiOKj1udmD8VLmkIzMrTh7PC3vOHR5ZJRdwsBgp477CDEkWGwogvzfYN5tAtI +lG100o5esX0c4fna9nm2gBqQ1k0EjN3cxMgf9bT/4bdVS5H+ZQDrfqRnLbpheISf8iu 2UnDvmTKF31IdTjQR0QUpaq3y6oJ/VMQEJEnSXh7SFWpelx8cFUQ800qhAIZwkZsBCpb Jc8w== 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=9o4OQXYk+pq6MFmpsmvpl6DMOs/cRRqJ5M5DXQPFAq0=; b=l1/I69OuCaOABKB8eje2lnrJDABnvxleOdVKDvQDJtxJIlBYEHVUBh5wNLJj2Sn13X Yt6aD8HYo0T7Cf8t8fdLiTXIiOd95yJ1Q8QYLd1jgX4Y4joLoVBohL+Ux5JN99KcqGhC PnBRSdavFSwr5prYuv/RzoPCg2Ck2+aEOAUDFHFOM9I6p/wovCw12Kos1e6Pw8/mBeJm PMnjaj5kqvRAsiEFItbO/BfXRMT4Xj7ARI59+boBmNndftAtLWRxL+0orlnZqb8tvzyt pzWcr7abF3vd2K6HkS4GA5xJAF52LjfgZFEwTYEXHJz9Q2RPj6jLMYeVBG4yvi3MWMP0 3eiw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=quPoqpW7; 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 gb29si2446927ejc.623.2021.07.15.12.43.42; Thu, 15 Jul 2021 12:44: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=quPoqpW7; 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 S1345017AbhGOTol (ORCPT + 99 others); Thu, 15 Jul 2021 15:44:41 -0400 Received: from mail.kernel.org ([198.145.29.99]:50994 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S244833AbhGOTPQ (ORCPT ); Thu, 15 Jul 2021 15:15:16 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 8AC8961421; Thu, 15 Jul 2021 19:11:34 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1626376295; bh=9CZYZH1IJIqZRfQ/cPp5d9YX2cUsPDo8NZVgJPiZQHA=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=quPoqpW7ENTCYAdfL286yy9ghNoCuHMwEXlHDIL4KZtEbXD29NSoDbgzvCG+DLZUl DvPAnPP703Pe6mqc1vZhDp0bVB/dyt5QMyppK3693o0m2uJUqkWTn8J/UvxntTi7/l vlVFfjmmBZuiyEXz6UJqw53HNNGVI1Tdy5bgbbWY= 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 5.13 168/266] Bluetooth: btusb: fix bt fiwmare downloading failure issue for qca btsoc. Date: Thu, 15 Jul 2021 20:38:43 +0200 Message-Id: <20210715182642.081204347@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210715182613.933608881@linuxfoundation.org> References: <20210715182613.933608881@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 1cec9b2353c6..6d23308119d1 100644 --- a/drivers/bluetooth/btusb.c +++ b/drivers/bluetooth/btusb.c @@ -4071,6 +4071,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