Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp4022180pxb; Tue, 26 Jan 2021 10:17:39 -0800 (PST) X-Google-Smtp-Source: ABdhPJz7Bd5dfRbS3Fme2usQVtvXcmhyxr3aW2VC1em1RCbuLCYbiaStHRDs8gTLemv3a9bekted X-Received: by 2002:a17:906:80c9:: with SMTP id a9mr4075875ejx.78.1611685059123; Tue, 26 Jan 2021 10:17:39 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1611685059; cv=none; d=google.com; s=arc-20160816; b=A/LAgm8k1YZtzDdxJLqGvWfm5LxrOyKuPksCKT8BaBUrn3CkD7zJIj0UJEsxrrjEey TGXyXJAy7YyEfa6nyFp7jDy4dFii4W3bFRVxP7ujoB6zCHJfwseFwR0cZLYImrVWUUZT 8sgR0Cseqy3sGQdG+tUcVLfaGQrPYFYwG+0FrBJzdMTQo4noLoDScDkzWBrQ9OP8bDGE wAuUuHamc1LNOgkrgvX6BdRJegBlP/caijL6pkeuLgU4ZeGArBzKFFEy9FoOuycgZuEX icYY35lKhNEQn7crgybhqa2s4UUbTX0zisG+IT9HLWSaPSV98ZMCdqsfCQOXXt70nDR7 +G9Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:message-id:date:subject:cc:to:from :authenticated-by; bh=C66IZuMy0++LcuDDemTeqmEFOTiyNOs8RliiPFvjQt4=; b=XCQ0CJyIDGh170vJ0gE8AzI/wM4iAlwYV2mNB6DoYEzHBjW3nSw00gR/PkbIqqK78t sPuFYMhGXOGrwneBiW9ZDw/vlUCYpUBTn9PqAouVdPPdG3AlKbReS6pV240JsI7ebb3t z32O8R3lXkt47zl9YXTgCfNZwqpcD7a2yj1CE2pDKlcHohzIVcGMhZq4/nvnODZmEA5j Hv09gNrLDOkd6hcRHxDyh6TppwCdCVbG9d6IpIhNHMEmllQBHcwYSDrME1XZAaoej/JG mgyBIlxT+E7IIto5yQforSHZXzcI8Hb8nbNM1UQRSDlHAlzo7rkE2H0WIqfs1AD8bg43 nWcQ== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id s9si7223679ejc.752.2021.01.26.10.17.12; Tue, 26 Jan 2021 10:17:38 -0800 (PST) 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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2404093AbhAZKnA (ORCPT + 99 others); Tue, 26 Jan 2021 05:43:00 -0500 Received: from rtits2.realtek.com ([211.75.126.72]:45045 "EHLO rtits2.realtek.com.tw" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1732086AbhAZCFe (ORCPT ); Mon, 25 Jan 2021 21:05:34 -0500 Authenticated-By: X-SpamFilter-By: ArmorX SpamTrap 5.73 with qID 10Q24d772009407, This message is accepted by code: ctloc85258 Received: from mail.realtek.com (rtexmbs03.realtek.com.tw[172.21.6.96]) by rtits2.realtek.com.tw (8.15.2/2.70/5.88) with ESMTPS id 10Q24d772009407 (version=TLSv1.2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128 verify=NOT); Tue, 26 Jan 2021 10:04:39 +0800 Received: from localhost.localdomain (172.21.132.186) by RTEXMBS03.realtek.com.tw (172.21.6.96) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2106.2; Tue, 26 Jan 2021 10:04:38 +0800 From: To: , , , , CC: , , , , , Subject: [PATCH v4] Bluetooth: btrtl: Enable WBS for the specific Realtek devices Date: Tue, 26 Jan 2021 10:04:34 +0800 Message-ID: <20210126020434.4911-1-max.chou@realtek.com> X-Mailer: git-send-email 2.17.1 MIME-Version: 1.0 Content-Type: text/plain X-Originating-IP: [172.21.132.186] X-ClientProxiedBy: RTEXMBS02.realtek.com.tw (172.21.6.95) To RTEXMBS03.realtek.com.tw (172.21.6.96) Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Max Chou By this change, it will enable WBS supported on the specific Realtek BT devices, such as RTL8822C and RTL8852A. In the future, it's able to maintain what the Realtek devices support WBS here. Tested-by: Hilda Wu Reviewed-by: Abhishek Pandit-Subedi Signed-off-by: Max Chou --- change in v4 -remove the unnecessary comment to avoid the unaligned starting point. --- drivers/bluetooth/btrtl.c | 29 +++++++++++++++++++++++------ 1 file changed, 23 insertions(+), 6 deletions(-) diff --git a/drivers/bluetooth/btrtl.c b/drivers/bluetooth/btrtl.c index 24f03a1f8d57..adcd054313a4 100644 --- a/drivers/bluetooth/btrtl.c +++ b/drivers/bluetooth/btrtl.c @@ -38,6 +38,19 @@ .hci_ver = (hciv), \ .hci_bus = (bus) +enum btrtl_chip_id { + CHIP_ID_8723A, + CHIP_ID_8723B, + CHIP_ID_8821A, + CHIP_ID_8761A, + CHIP_ID_8822B = 8, + CHIP_ID_8723D, + CHIP_ID_8821C, + CHIP_ID_8822C = 13, + CHIP_ID_8761B, + CHIP_ID_8852A = 18, +}; + struct id_table { __u16 match_flags; __u16 lmp_subver; @@ -58,6 +71,7 @@ struct btrtl_device_info { u8 *cfg_data; int cfg_len; bool drop_fw; + int project_id; }; static const struct id_table ic_id_table[] = { @@ -307,8 +321,10 @@ static int rtlbt_parse_firmware(struct hci_dev *hdev, /* Find project_id in table */ for (i = 0; i < ARRAY_SIZE(project_id_to_lmp_subver); i++) { - if (project_id == project_id_to_lmp_subver[i].id) + if (project_id == project_id_to_lmp_subver[i].id) { + btrtl_dev->project_id = project_id; break; + } } if (i >= ARRAY_SIZE(project_id_to_lmp_subver)) { @@ -719,18 +735,19 @@ int btrtl_setup_realtek(struct hci_dev *hdev) */ set_bit(HCI_QUIRK_SIMULTANEOUS_DISCOVERY, &hdev->quirks); - if (!btrtl_dev->ic_info) - goto done; - /* Enable central-peripheral role (able to create new connections with * an existing connection in slave role). */ - switch (btrtl_dev->ic_info->lmp_subver) { - case RTL_ROM_LMP_8822B: + /* Enable WBS supported for the specific Realtek devices. */ + switch (btrtl_dev->project_id) { + case CHIP_ID_8822C: + case CHIP_ID_8852A: set_bit(HCI_QUIRK_VALID_LE_STATES, &hdev->quirks); + set_bit(HCI_QUIRK_WIDEBAND_SPEECH_SUPPORTED, &hdev->quirks); break; default: rtl_dev_dbg(hdev, "Central-peripheral role not enabled."); + rtl_dev_dbg(hdev, "WBS supported not enabled."); break; } -- 2.17.1