OSDN Git Service

Bluetooth: Add new HCI_QUIRK_NO_SUSPEND_NOTIFIER quirk
authorHans de Goede <hdegoede@redhat.com>
Thu, 28 Jan 2021 16:33:12 +0000 (17:33 +0100)
committerMarcel Holtmann <marcel@holtmann.org>
Fri, 29 Jan 2021 15:37:00 +0000 (16:37 +0100)
commit219991e6be7f4a31d471611e265b72f75b2d0538
treeb621ebf7e8cb7ad6cd56f5d0230f937bcd101d18
parent98d2c3e1731007acf03addf83c863df6694beb95
Bluetooth: Add new HCI_QUIRK_NO_SUSPEND_NOTIFIER quirk

Some devices, e.g. the RTL8723BS bluetooth part, some USB attached devices,
completely drop from the bus on a system-suspend. These devices will
have their driver unbound and rebound on resume (when the dropping of
the bus gets detected) and will show up as a new HCI after resume.

These devices do not benefit from the suspend / resume handling work done
by the hci_suspend_notifier. At best this unnecessarily adds some time to
the suspend/resume time. But this may also actually cause problems, if the
code doing the driver unbinding runs after the pm-notifier then the
hci_suspend_notifier code will try to talk to a device which is now in
an uninitialized state.

This commit adds a new HCI_QUIRK_NO_SUSPEND_NOTIFIER quirk which allows
drivers to opt-out of the hci_suspend_notifier when they know beforehand
that their device will be fully re-initialized / reprobed on resume.

Signed-off-by: Hans de Goede <hdegoede@redhat.com>
Reviewed-by: Abhishek Pandit-Subedi <abhishekpandit@chromium.org>
Signed-off-by: Marcel Holtmann <marcel@holtmann.org>
include/net/bluetooth/hci.h
net/bluetooth/hci_core.c