Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp1050889imu; Wed, 16 Jan 2019 11:54:03 -0800 (PST) X-Google-Smtp-Source: ALg8bN4+N2UgUXmBEDtOhitNoryfz5DoZ8uq9SpeSUqexI6LyZ+9yM3fSuTVYEQhFeRl3GT6kKnp X-Received: by 2002:a17:902:981:: with SMTP id 1mr11322111pln.142.1547668443682; Wed, 16 Jan 2019 11:54:03 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1547668443; cv=none; d=google.com; s=arc-20160816; b=EAfnt1n1uR2GkOedEo0HzQkCpqu0bRbUKRbk+XFs9KphhWUbaAx0j1+3oA6k3ri1r3 RJhAie2/WrOl4OJdQZ8CgpwK7L7ZX6PvWieFkg3ydqreRZp/KPK+KW2ph1q9itqoOZ60 xw2Yq5Us8Qf5WdE3yZUgJ25YJCrBpTy0ftqVzl+iZV2O3i7xa39UE0mf2+zamWtjkZp2 rUe/u6iw2vcBItWOHEFXi1hKM1PMPiXXwYmNB1zZ4iLCeoL2KQPj62bAv9sPY+mXDsuD 34OmKUvCVnJ8mNDwod4Z+Zg010WgDK4nx56A1esM2b/WYsEMutgcnYWqe/+t5QaMykcy aqZQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dmarc-filter:dkim-signature:dkim-signature; bh=rbHzWLOYyzNZ0ZEi3QQQRyJve6VfPzW4ht0vN1prgJs=; b=BQsVdNrRVOq8GY/CYwflyLeDE9kuZutSYUlpM/7TynGg+jctPpSgksDt/JEFql6Mi1 MNwHuoVk8yI7HBvtd2ncZMg7rAL8Md1fGOiDXrXL//rrLZZ70Q5tviN0t1IPNqCgP/+6 owA+HqJMUinfGVaLN1iaEAO0k0xKgou0Z2X5FbBfyuqdFH1v6AT8TtvqaHzSnqBBQfc0 PhD0yz+UwZ8spdMWCXXyOc4bjaof3MtoWsRkrOIbhjz0d8uxcr8gRI6QBZ9iFqaq8u6y COBc91OqTJLJ5W0cINZ3TuC8dB63jiuUygYYtxVfVs81me+91zbqXRTj7cWAMLfmaMW9 Lzuw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b=XFffsftc; dkim=pass header.i=@codeaurora.org header.s=default header.b=XFffsftc; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id e7si42647pgv.499.2019.01.16.11.53.45; Wed, 16 Jan 2019 11:54:03 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b=XFffsftc; dkim=pass header.i=@codeaurora.org header.s=default header.b=XFffsftc; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2392528AbfAPLqo (ORCPT + 99 others); Wed, 16 Jan 2019 06:46:44 -0500 Received: from smtp.codeaurora.org ([198.145.29.96]:43548 "EHLO smtp.codeaurora.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2389613AbfAPLqc (ORCPT ); Wed, 16 Jan 2019 06:46:32 -0500 Received: by smtp.codeaurora.org (Postfix, from userid 1000) id 94A39608FB; Wed, 16 Jan 2019 11:46:31 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1547639191; bh=ymB409/EObpTpVe+aPgVCCFfMgzXP9PAx6hVzoDTkiQ=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=XFffsftcqXFYAHVpWi3jut3vDDiYSTCuKn9BeQcHL7S0IzWz2eOMLsGNA4JZm44n7 TnisocOyk8/q6vVwzKw1Cd5jPhPHBE6Gb7HaYz5WwfNH34Wd8lq9UnpxOCw8YszUA6 lFZrgzUPHp0JWuVtFL2t9DKBChzyJW2Wdagz8lJQ= X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on pdx-caf-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-2.7 required=2.0 tests=ALL_TRUSTED,BAYES_00, DKIM_INVALID,DKIM_SIGNED autolearn=no autolearn_force=no version=3.4.0 Received: from bgodavar-linux.qualcomm.com (blr-c-bdr-fw-01_globalnat_allzones-outside.qualcomm.com [103.229.19.19]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: bgodavar@smtp.codeaurora.org) by smtp.codeaurora.org (Postfix) with ESMTPSA id 46D2F6087D; Wed, 16 Jan 2019 11:46:28 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1547639191; bh=ymB409/EObpTpVe+aPgVCCFfMgzXP9PAx6hVzoDTkiQ=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=XFffsftcqXFYAHVpWi3jut3vDDiYSTCuKn9BeQcHL7S0IzWz2eOMLsGNA4JZm44n7 TnisocOyk8/q6vVwzKw1Cd5jPhPHBE6Gb7HaYz5WwfNH34Wd8lq9UnpxOCw8YszUA6 lFZrgzUPHp0JWuVtFL2t9DKBChzyJW2Wdagz8lJQ= DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org 46D2F6087D Authentication-Results: pdx-caf-mail.web.codeaurora.org; dmarc=none (p=none dis=none) header.from=codeaurora.org Authentication-Results: pdx-caf-mail.web.codeaurora.org; spf=none smtp.mailfrom=bgodavar@codeaurora.org From: Balakrishna Godavarthi To: marcel@holtmann.org, johan.hedberg@gmail.com Cc: mka@chromium.org, linux-kernel@vger.kernel.org, linux-bluetooth@vger.kernel.org, hemantg@codeaurora.org, linux-arm-msm@vger.kernel.org, Balakrishna Godavarthi Subject: [PATCH v8 3/3] Bluetooth: hci_qca: Disable IBS state machine and flush Tx buffer Date: Wed, 16 Jan 2019 17:16:03 +0530 Message-Id: <20190116114603.500-4-bgodavar@codeaurora.org> X-Mailer: git-send-email 2.19.1 In-Reply-To: <20190116114603.500-1-bgodavar@codeaurora.org> References: <20190116114603.500-1-bgodavar@codeaurora.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org During hci down we observed IBS sleep commands are queued in the Tx buffer and hci_uart_write_work is sending data to the chip which is not required as the chip is powered off. This patch will disable IBS and flush the Tx buffer before we turn off the chip. Signed-off-by: Balakrishna Godavarthi --- drivers/bluetooth/hci_qca.c | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/drivers/bluetooth/hci_qca.c b/drivers/bluetooth/hci_qca.c index 7e4afcf40da2..7330ba71ada4 100644 --- a/drivers/bluetooth/hci_qca.c +++ b/drivers/bluetooth/hci_qca.c @@ -1275,6 +1275,14 @@ static const struct qca_vreg_data qca_soc_data = { static void qca_power_shutdown(struct hci_uart *hu) { + struct qca_data *qca = hu->priv; + + /* From this point we go into power off state. But serial port is + * still open, stop queueing the IBS data and flush all the buffered + * data in skb's. + */ + clear_bit(STATE_IN_BAND_SLEEP_ENABLED, &qca->flags); + qca_flush(hu); host_set_baudrate(hu, 2400); qca_send_power_pulse(hu, QCA_WCN3990_POWEROFF_PULSE); qca_power_setup(hu, false); -- The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum, a Linux Foundation Collaborative Project