Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp3999800pxf; Tue, 16 Mar 2021 03:17:03 -0700 (PDT) X-Google-Smtp-Source: ABdhPJz2ftjY0FhZsHvMdmXw1ZXJNvuKuZSNbX3ZeSKSntTODF5S9b+dPKqfiOEQCnGHsbdG1O4V X-Received: by 2002:a17:906:6c93:: with SMTP id s19mr28465494ejr.151.1615889822961; Tue, 16 Mar 2021 03:17:02 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1615889822; cv=none; d=google.com; s=arc-20160816; b=W+s0xZBQLwSIjkTPY219Uu4SjrxBGz6O03fCSDeYaCsb+t+2n342o4LaKUZydLtu88 Q6onb/v94Sq9uI3VRxin4Sf9u5RRze5DuToqFcDzXymyJC6zVe0YUVbxJtlZ7MaUQwj2 kXFpGV6wbIV1a/BnqJqabHEXKwUaMwWku6oetgStTwRftGagYFAkmeiY1r2woUpd0if3 9X4QQyNtJK3wCw8/qA+KMD3JYjiOoztY0uBszSntzyRX/PCj/r0uCeSN6xPw5dXyPrgB KhKG8cJVOZ9A4JyP6on9BOin+XhT4lXzuCHG8ghn8oK6BN4uLWFbmzhCZ8fn9E1fh3YJ l4JA== 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=ExCunZuG7NT6pTF0HEV04Vg9tWqn9T4NZcW9Ikw4aN0=; b=pdpi9OIyNmZgy7too8GpZmTsOhdzL1Lrwg5VjVDDAqAIvfniEs7Q1pt087DEEQKpRW 9CYieguQa1/WxuinlhBi28uZXqx9ZS7LwZ6ZrYZbfnl/sixs80JQnrZVukJFseRphCDm R83oYfeHQhUc+610i749fkTY8Vpa5bGNLo+mdbrmtlwXQCk8kleDNmVGapE/baa7MMjy bRe0uSI1+jddtVMSewZnTyZDE010fsGF6wSjsQCXLo1i1r4UbEpP7Wq9Nv0SGVb9T2nq 2l8EdDVrUEi8FTS1SQvuGEaFsSW9l0CFC0LWJwA0zxcpk+au5MdaaRfMksAW3Moqp7ZW skGw== 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 40si12956764edq.26.2021.03.16.03.16.39; Tue, 16 Mar 2021 03:17:02 -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 S234838AbhCPKH4 (ORCPT + 99 others); Tue, 16 Mar 2021 06:07:56 -0400 Received: from rtits2.realtek.com ([211.75.126.72]:47837 "EHLO rtits2.realtek.com.tw" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234292AbhCPKH3 (ORCPT ); Tue, 16 Mar 2021 06:07:29 -0400 Authenticated-By: X-SpamFilter-By: ArmorX SpamTrap 5.73 with qID 12GA75eS4018098, This message is accepted by code: ctloc85258 Received: from mail.realtek.com (rtexmbs04.realtek.com.tw[172.21.6.97]) by rtits2.realtek.com.tw (8.15.2/2.70/5.88) with ESMTPS id 12GA75eS4018098 (version=TLSv1.2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128 verify=NOT); Tue, 16 Mar 2021 18:07:05 +0800 Received: from localhost.localdomain (172.21.132.99) by RTEXMBS04.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.2106.2; Tue, 16 Mar 2021 18:07:05 +0800 From: To: CC: , , , , , , , , , , Subject: [PATCH v2] Bluetooth: hci_h5: btrtl: Add quirk for keep power in suspend/resume Date: Tue, 16 Mar 2021 18:06:57 +0800 Message-ID: <20210316100657.16499-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.132.99] X-ClientProxiedBy: RTEXMBS03.realtek.com.tw (172.21.6.96) To RTEXMBS04.realtek.com.tw (172.21.6.97) Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: hildawu RTL8822C devices support BT wakeup Host. Add a quirk for these specific devices did not power off during suspend and resume. By this change, if the Host support that received BT device signal then it can be wakeup. Signed-off-by: hildawu --- Changes in v2: - Add missing struct member - Modify title for fit length --- --- drivers/bluetooth/btrtl.c | 36 ------------------------------------ drivers/bluetooth/btrtl.h | 36 ++++++++++++++++++++++++++++++++++++ drivers/bluetooth/hci_h5.c | 35 ++++++++++++++++++++++++----------- include/net/bluetooth/hci.h | 9 +++++++++ 4 files changed, 69 insertions(+), 47 deletions(-) diff --git a/drivers/bluetooth/btrtl.c b/drivers/bluetooth/btrtl.c index e7fe5fb22753..94d1e7885aee 100644 --- a/drivers/bluetooth/btrtl.c +++ b/drivers/bluetooth/btrtl.c @@ -38,42 +38,6 @@ .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; - __u16 hci_rev; - __u8 hci_ver; - __u8 hci_bus; - bool config_needed; - bool has_rom_version; - char *fw_name; - char *cfg_name; -}; - -struct btrtl_device_info { - const struct id_table *ic_info; - u8 rom_version; - u8 *fw_data; - int fw_len; - u8 *cfg_data; - int cfg_len; - bool drop_fw; - int project_id; -}; - static const struct id_table ic_id_table[] = { /* 8723A */ { IC_INFO(RTL_ROM_LMP_8723A, 0xb, 0x6, HCI_USB), diff --git a/drivers/bluetooth/btrtl.h b/drivers/bluetooth/btrtl.h index 2a582682136d..713768b38e21 100644 --- a/drivers/bluetooth/btrtl.h +++ b/drivers/bluetooth/btrtl.h @@ -12,6 +12,42 @@ #define rtl_dev_info(dev, fmt, ...) bt_dev_info(dev, "RTL: " fmt, ##__VA_ARGS__) #define rtl_dev_dbg(dev, fmt, ...) bt_dev_dbg(dev, "RTL: " fmt, ##__VA_ARGS__) +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; + __u16 hci_rev; + __u8 hci_ver; + __u8 hci_bus; + bool config_needed; + bool has_rom_version; + char *fw_name; + char *cfg_name; +}; + +struct btrtl_device_info { + const struct id_table *ic_info; + u8 rom_version; + u8 *fw_data; + int fw_len; + u8 *cfg_data; + int cfg_len; + bool drop_fw; + int project_id; +}; + struct btrtl_device_info; struct rtl_download_cmd { diff --git a/drivers/bluetooth/hci_h5.c b/drivers/bluetooth/hci_h5.c index 27e96681d583..1ca4ff89ea14 100644 --- a/drivers/bluetooth/hci_h5.c +++ b/drivers/bluetooth/hci_h5.c @@ -909,7 +909,15 @@ static int h5_btrtl_setup(struct h5 *h5) /* Enable controller to do both LE scan and BR/EDR inquiry * simultaneously. */ - set_bit(HCI_QUIRK_SIMULTANEOUS_DISCOVERY, &h5->hu->hdev->quirks); + switch (btrtl_dev->project_id) { + case CHIP_ID_8822C: + case CHIP_ID_8852A: + set_bit(HCI_QUIRK_SIMULTANEOUS_DISCOVERY, &h5->hu->hdev->quirks); + set_bit(HCI_QUIRK_DEVICES_WAKEUP_SUPPORTED, &h5->hu->hdev->quirks); + break; + default: + break; + } out_free: btrtl_free(btrtl_dev); @@ -945,8 +953,11 @@ static void h5_btrtl_close(struct h5 *h5) static int h5_btrtl_suspend(struct h5 *h5) { serdev_device_set_flow_control(h5->hu->serdev, false); - gpiod_set_value_cansleep(h5->device_wake_gpio, 0); - gpiod_set_value_cansleep(h5->enable_gpio, 0); + + if (!test_bit(HCI_QUIRK_DEVICES_WAKEUP_SUPPORTED, &h5->hu->hdev->quirks)) { + gpiod_set_value_cansleep(h5->device_wake_gpio, 0); + gpiod_set_value_cansleep(h5->enable_gpio, 0); + } return 0; } @@ -972,17 +983,19 @@ static void h5_btrtl_reprobe_worker(struct work_struct *work) static int h5_btrtl_resume(struct h5 *h5) { - struct h5_btrtl_reprobe *reprobe; + if (!test_bit(HCI_QUIRK_DEVICES_WAKEUP_SUPPORTED, &h5->hu->hdev->quirks)) { + struct h5_btrtl_reprobe *reprobe; - reprobe = kzalloc(sizeof(*reprobe), GFP_KERNEL); - if (!reprobe) - return -ENOMEM; + reprobe = kzalloc(sizeof(*reprobe), GFP_KERNEL); + if (!reprobe) + return -ENOMEM; - __module_get(THIS_MODULE); + __module_get(THIS_MODULE); - INIT_WORK(&reprobe->work, h5_btrtl_reprobe_worker); - reprobe->dev = get_device(&h5->hu->serdev->dev); - queue_work(system_long_wq, &reprobe->work); + INIT_WORK(&reprobe->work, h5_btrtl_reprobe_worker); + reprobe->dev = get_device(&h5->hu->serdev->dev); + queue_work(system_long_wq, &reprobe->work); + } return 0; } diff --git a/include/net/bluetooth/hci.h b/include/net/bluetooth/hci.h index ea4ae551c426..1e4c2a97ab8d 100644 --- a/include/net/bluetooth/hci.h +++ b/include/net/bluetooth/hci.h @@ -246,6 +246,15 @@ enum { * HCI after resume. */ HCI_QUIRK_NO_SUSPEND_NOTIFIER, + + /* When this quirk is set, the controller does not power off + * during suspend and resume. This mechanism lets BT devices wake + * the Host up if the Host and chips support. + * + * This quirk can be set before hci_register_dev is called or + * during the hdev->setup vendor callback. + */ + HCI_QUIRK_DEVICES_WAKEUP_SUPPORTED, }; /* HCI device flags */ -- 2.17.1