Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp3565869ybt; Tue, 30 Jun 2020 06:13:40 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzf//1fgugvHiYn/sUVGypGRqt8TuTP4mGg+zevbuUBWnli011fFtAe+peXDZTWdisjEjf0 X-Received: by 2002:a05:6402:13d0:: with SMTP id a16mr22831437edx.269.1593522820760; Tue, 30 Jun 2020 06:13:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1593522820; cv=none; d=google.com; s=arc-20160816; b=XhW9eFW80zCPB3DsIXlFHx1Abohz5t8V9rytVHqRX27uFLdnTOT2Q9GnZmqL27KY/W pbg47Py9mT9diDpOkU3ooqblZetgjxZfFXzXaukCLjZDvU9k2Ws813i0EKdePpY3kvC1 Ags3+lKyzNon8b8yyktzpa2beAvQ8VI4EDGFVqSARnfCiunYmyUl6XAgvKhz54Ve6gRs pAcvHmFiu4X51AwruXAm7DcQx1XSlwSQwRFoBkh/2HWc6ea8sJ3Xgt+JUfuu2g0BiG3C kKCzJ0WhWP8JPdyfFyKtYI0Gzo8mnCfJ/ce/TllvHzXk+lUkPnXMIjpqSnozqcCFsd7/ jYew== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:message-id:date:subject:cc :to:from:authenticated-by; bh=jTBibtHkltaqNAWlHzgNxM8/MHLn4koGJ0YxXX+vzVk=; b=rnuX5PwaWm5cPxNpz4MTJrMEwRLcPqeAfF7TOkHEBPwQweMWgDyRf5BoLG/9AUM53K MoYavHd08dZNlNA09Kh4WkjdWbbBIgf5Iy+Mim3+OEoZUr6LCfIsFc17kO+1Z/yNFUnB nwljOnBbHpSUtCPDs4Xe0LlUoa9TYTG1YWtp2PpMpa0gccSBtiHtmyU1bzbrKaAgy5kk bqWTfbPJIixy1NbQvx6hCMGnWP/0/jCQh60a+fTiDmbNHehV6ZBxWp+zjz3I0EiCFhoG i7xgfqi1/o3/89Dn+ONDqrKBR6sYYwalG7HaopvvjsPaJrG9fqdPTQfPuz2G8hF2NUbx LrIA== 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 g26si1620728edv.376.2020.06.30.06.13.15; Tue, 30 Jun 2020 06:13:40 -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; 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 S1729337AbgF3NLH (ORCPT + 99 others); Tue, 30 Jun 2020 09:11:07 -0400 Received: from rtits2.realtek.com ([211.75.126.72]:53132 "EHLO rtits2.realtek.com.tw" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726008AbgF3NLE (ORCPT ); Tue, 30 Jun 2020 09:11:04 -0400 Authenticated-By: X-SpamFilter-By: ArmorX SpamTrap 5.69 with qID 05UD9m3N2022713, This message is accepted by code: ctloc85258 Received: from mail.realtek.com (rtexmb06.realtek.com.tw[172.21.6.99]) by rtits2.realtek.com.tw (8.15.2/2.66/5.86) with ESMTPS id 05UD9m3N2022713 (version=TLSv1.2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128 verify=NOT); Tue, 30 Jun 2020 21:09:48 +0800 Received: from RTEXMB04.realtek.com.tw (172.21.6.97) by RTEXMB06.realtek.com.tw (172.21.6.99) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.1779.2; Tue, 30 Jun 2020 21:09:48 +0800 Received: from localhost.localdomain (172.21.87.237) by RTEXMB04.realtek.com.tw (172.21.6.97) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.1779.2; Tue, 30 Jun 2020 21:09:47 +0800 From: To: CC: , , , , , , , , Subject: [PATCH v2] Bluetooth: btusb: USB alternate setting 1 for WBS Date: Tue, 30 Jun 2020 21:09:40 +0800 Message-ID: <20200630130940.14339-1-hildawu@realtek.com> X-Mailer: git-send-email 2.17.1 MIME-Version: 1.0 Content-Type: text/plain X-Originating-IP: [172.21.87.237] X-ClientProxiedBy: RTEXMB03.realtek.com.tw (172.21.6.96) To RTEXMB04.realtek.com.tw (172.21.6.97) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Hilda Wu RTL8822CE supports transparent WBS to apply USB alternate setting 1. Add a flag to the device match data to apply alternate setting 1 which meet the transfer speed for WBS support. Signed-off-by: Hilda Wu --- Changes in v2: - More descriptive commit log and short description. - Use BTUSB_USE_ALT1_FOR_WBS replace BTUSB_WBS_ALT1 for descriptive name. - Move alternate setting 1 check into the btusb_probe() function and adjust position of data->isoc for alternate setting check. --- --- drivers/bluetooth/btusb.c | 34 ++++++++++++++++++++-------------- 1 file changed, 20 insertions(+), 14 deletions(-) diff --git a/drivers/bluetooth/btusb.c b/drivers/bluetooth/btusb.c index c7cc8e594166..e4a12c58501e 100644 --- a/drivers/bluetooth/btusb.c +++ b/drivers/bluetooth/btusb.c @@ -453,6 +453,7 @@ static const struct dmi_system_id btusb_needs_reset_resume_table[] = { #define BTUSB_HW_RESET_ACTIVE 12 #define BTUSB_TX_WAIT_VND_EVT 13 #define BTUSB_WAKEUP_DISABLE 14 +#define BTUSB_USE_ALT1_FOR_WBS 15 struct btusb_data { struct hci_dev *hdev; @@ -1666,14 +1667,15 @@ static void btusb_work(struct work_struct *work) new_alts = data->sco_num; } } else if (data->air_mode == HCI_NOTIFY_ENABLE_SCO_TRANSP) { - - data->usb_alt6_packet_flow = true; - /* Check if Alt 6 is supported for Transparent audio */ - if (btusb_find_altsetting(data, 6)) + if (btusb_find_altsetting(data, 6)) { + data->usb_alt6_packet_flow = true; new_alts = 6; - else + } else if (test_bit(BTUSB_USE_ALT1_FOR_WBS, &data->flags)) { + new_alts = 1; + } else { bt_dev_err(hdev, "Device does not support ALT setting 6"); + } } if (btusb_switch_alt_setting(hdev, new_alts) < 0) @@ -3954,6 +3956,15 @@ static int btusb_probe(struct usb_interface *intf, btusb_check_needs_reset_resume(intf); } + if (id->driver_info & BTUSB_AMP) { + /* AMP controllers do not support SCO packets */ + data->isoc = NULL; + } else { + /* Interface orders are hardcoded in the specification */ + data->isoc = usb_ifnum_to_if(data->udev, ifnum_base + 1); + data->isoc_ifnum = ifnum_base + 1; + } + if (IS_ENABLED(CONFIG_BT_HCIBTUSB_RTL) && (id->driver_info & BTUSB_REALTEK)) { hdev->setup = btrtl_setup_realtek; @@ -3965,21 +3976,16 @@ static int btusb_probe(struct usb_interface *intf, * (DEVICE_REMOTE_WAKEUP) */ set_bit(BTUSB_WAKEUP_DISABLE, &data->flags); + if (btusb_find_altsetting(data, 1)) + set_bit(BTUSB_USE_ALT1_FOR_WBS, &data->flags); + else + bt_dev_err(hdev, "Device does not support ALT setting 1"); err = usb_autopm_get_interface(intf); if (err < 0) goto out_free_dev; } - if (id->driver_info & BTUSB_AMP) { - /* AMP controllers do not support SCO packets */ - data->isoc = NULL; - } else { - /* Interface orders are hardcoded in the specification */ - data->isoc = usb_ifnum_to_if(data->udev, ifnum_base + 1); - data->isoc_ifnum = ifnum_base + 1; - } - if (!reset) set_bit(HCI_QUIRK_RESET_ON_CLOSE, &hdev->quirks); -- 2.17.1