Bluetooth: Add quirk for broken READ_PAGE_SCAN_TYPE

Some fake controllers cannot be initialized because they return a smaller
report than expected for READ_PAGE_SCAN_TYPE.

Signed-off-by: Pedro Nishiyama <nishiyama.pedro@gmail.com>
Signed-off-by: Luiz Augusto von Dentz <luiz.von.dentz@intel.com>
This commit is contained in:
Pedro Nishiyama 2025-03-01 03:22:59 -03:00 committed by Luiz Augusto von Dentz
parent ff26b2dd65
commit 127881334e
2 changed files with 10 additions and 1 deletions

View file

@ -362,6 +362,14 @@ enum {
* This quirk must be set before hci_register_dev is called. * This quirk must be set before hci_register_dev is called.
*/ */
HCI_QUIRK_BROKEN_READ_VOICE_SETTING, HCI_QUIRK_BROKEN_READ_VOICE_SETTING,
/* When this quirk is set, the HCI_OP_READ_PAGE_SCAN_TYPE command is
* skipped. This is required for a subset of the CSR controller clones
* which erroneously claim to support it.
*
* This quirk must be set before hci_register_dev is called.
*/
HCI_QUIRK_BROKEN_READ_PAGE_SCAN_TYPE,
}; };
/* HCI device flags */ /* HCI device flags */

View file

@ -4132,7 +4132,8 @@ static int hci_read_page_scan_type_sync(struct hci_dev *hdev)
* support the Read Page Scan Type command. Check support for * support the Read Page Scan Type command. Check support for
* this command in the bit mask of supported commands. * this command in the bit mask of supported commands.
*/ */
if (!(hdev->commands[13] & 0x01)) if (!(hdev->commands[13] & 0x01) ||
test_bit(HCI_QUIRK_BROKEN_READ_PAGE_SCAN_TYPE, &hdev->quirks))
return 0; return 0;
return __hci_cmd_sync_status(hdev, HCI_OP_READ_PAGE_SCAN_TYPE, return __hci_cmd_sync_status(hdev, HCI_OP_READ_PAGE_SCAN_TYPE,