* [PATCH v2 1/3] Bluetooth: btusb: fix wakeup source leak on probe failure
2026-04-02 9:27 [PATCH v2 0/3] Bluetooth: btusb: fix wakeup irq devres lifetime Johan Hovold
@ 2026-04-02 9:27 ` Johan Hovold
2026-04-02 10:17 ` Bluetooth: btusb: fix wakeup irq devres lifetime bluez.test.bot
2026-04-02 9:27 ` [PATCH v2 2/3] " Johan Hovold
` (2 subsequent siblings)
3 siblings, 1 reply; 6+ messages in thread
From: Johan Hovold @ 2026-04-02 9:27 UTC (permalink / raw)
To: Luiz Augusto von Dentz, Marcel Holtmann
Cc: linux-bluetooth, linux-kernel, Johan Hovold, stable, Rajat Jain
Make sure to disable wakeup on probe failure to avoid leaking the wakeup
source.
Fixes: fd913ef7ce61 ("Bluetooth: btusb: Add out-of-band wakeup support")
Cc: stable@vger.kernel.org # 4.11
Cc: Rajat Jain <rajatja@google.com>
Signed-off-by: Johan Hovold <johan@kernel.org>
---
drivers/bluetooth/btusb.c | 13 ++++++++-----
1 file changed, 8 insertions(+), 5 deletions(-)
diff --git a/drivers/bluetooth/btusb.c b/drivers/bluetooth/btusb.c
index 21e85c212506..9e4390ba82ba 100644
--- a/drivers/bluetooth/btusb.c
+++ b/drivers/bluetooth/btusb.c
@@ -4146,7 +4146,7 @@ static int btusb_probe(struct usb_interface *intf,
if (id->driver_info & BTUSB_MARVELL && data->oob_wake_irq) {
err = marvell_config_oob_wake(hdev);
if (err)
- goto out_free_dev;
+ goto err_disable_wakeup;
}
#endif
if (id->driver_info & BTUSB_CW6622)
@@ -4183,7 +4183,7 @@ static int btusb_probe(struct usb_interface *intf,
if (id->driver_info & BTUSB_INTEL_COMBINED) {
err = btintel_configure_setup(hdev, btusb_driver.name);
if (err)
- goto out_free_dev;
+ goto err_disable_wakeup;
/* Transport specific configuration */
hdev->send = btusb_send_frame_intel;
@@ -4346,7 +4346,7 @@ static int btusb_probe(struct usb_interface *intf,
err = usb_set_interface(data->udev, 0, 0);
if (err < 0) {
BT_ERR("failed to set interface 0, alt 0 %d", err);
- goto out_free_dev;
+ goto err_disable_wakeup;
}
}
@@ -4354,7 +4354,7 @@ static int btusb_probe(struct usb_interface *intf,
err = usb_driver_claim_interface(&btusb_driver,
data->isoc, data);
if (err < 0)
- goto out_free_dev;
+ goto err_disable_wakeup;
}
if (IS_ENABLED(CONFIG_BT_HCIBTUSB_BCM) && data->diag) {
@@ -4372,7 +4372,7 @@ static int btusb_probe(struct usb_interface *intf,
err = hci_register_dev(hdev);
if (err < 0)
- goto out_free_dev;
+ goto err_disable_wakeup;
usb_set_intfdata(intf, data);
@@ -4381,6 +4381,9 @@ static int btusb_probe(struct usb_interface *intf,
return 0;
+err_disable_wakeup:
+ if (data->oob_wake_irq)
+ device_init_wakeup(&data->udev->dev, false);
out_free_dev:
if (data->reset_gpio)
gpiod_put(data->reset_gpio);
--
2.52.0
^ permalink raw reply related [flat|nested] 6+ messages in thread* RE: Bluetooth: btusb: fix wakeup irq devres lifetime
2026-04-02 9:27 ` [PATCH v2 1/3] Bluetooth: btusb: fix wakeup source leak on probe failure Johan Hovold
@ 2026-04-02 10:17 ` bluez.test.bot
0 siblings, 0 replies; 6+ messages in thread
From: bluez.test.bot @ 2026-04-02 10:17 UTC (permalink / raw)
To: linux-bluetooth, johan
[-- Attachment #1: Type: text/plain, Size: 2593 bytes --]
This is automated email and please do not reply to this email!
Dear submitter,
Thank you for submitting the patches to the linux bluetooth mailing list.
This is a CI test results with your patch series:
PW Link:https://patchwork.kernel.org/project/bluetooth/list/?series=1076322
---Test result---
Test Summary:
CheckPatch PENDING 0.34 seconds
GitLint PENDING 0.29 seconds
SubjectPrefix PASS 0.33 seconds
BuildKernel PASS 26.00 seconds
CheckAllWarning PASS 28.76 seconds
CheckSparse PASS 28.08 seconds
BuildKernel32 PASS 25.80 seconds
TestRunnerSetup PASS 568.36 seconds
TestRunner_l2cap-tester PASS 28.28 seconds
TestRunner_iso-tester PASS 44.15 seconds
TestRunner_bnep-tester PASS 6.58 seconds
TestRunner_mgmt-tester FAIL 117.31 seconds
TestRunner_rfcomm-tester PASS 9.70 seconds
TestRunner_sco-tester FAIL 14.50 seconds
TestRunner_ioctl-tester PASS 10.31 seconds
TestRunner_mesh-tester FAIL 12.76 seconds
TestRunner_smp-tester PASS 8.81 seconds
TestRunner_userchan-tester PASS 6.80 seconds
IncrementalBuild PENDING 0.42 seconds
Details
##############################
Test: CheckPatch - PENDING
Desc: Run checkpatch.pl script
Output:
##############################
Test: GitLint - PENDING
Desc: Run gitlint
Output:
##############################
Test: TestRunner_mgmt-tester - FAIL
Desc: Run mgmt-tester with test-runner
Output:
Total: 494, Passed: 489 (99.0%), Failed: 1, Not Run: 4
Failed Test Cases
Read Exp Feature - Success Failed 0.104 seconds
##############################
Test: TestRunner_sco-tester - FAIL
Desc: Run sco-tester with test-runner
Output:
WARNING: possible circular locking dependency detected
BUG: sleeping function called from invalid context at net/core/sock.c:3782
Total: 30, Passed: 30 (100.0%), Failed: 0, Not Run: 0
##############################
Test: TestRunner_mesh-tester - FAIL
Desc: Run mesh-tester with test-runner
Output:
Total: 10, Passed: 8 (80.0%), Failed: 2, Not Run: 0
Failed Test Cases
Mesh - Send cancel - 1 Timed out 2.662 seconds
Mesh - Send cancel - 2 Timed out 1.996 seconds
##############################
Test: IncrementalBuild - PENDING
Desc: Incremental build with the patches in the series
Output:
---
Regards,
Linux Bluetooth
^ permalink raw reply [flat|nested] 6+ messages in thread
* [PATCH v2 2/3] Bluetooth: btusb: fix wakeup irq devres lifetime
2026-04-02 9:27 [PATCH v2 0/3] Bluetooth: btusb: fix wakeup irq devres lifetime Johan Hovold
2026-04-02 9:27 ` [PATCH v2 1/3] Bluetooth: btusb: fix wakeup source leak on probe failure Johan Hovold
@ 2026-04-02 9:27 ` Johan Hovold
2026-04-02 9:27 ` [PATCH v2 3/3] Bluetooth: btusb: clean up probe error handling Johan Hovold
2026-04-02 14:16 ` [PATCH v2 0/3] Bluetooth: btusb: fix wakeup irq devres lifetime Johan Hovold
3 siblings, 0 replies; 6+ messages in thread
From: Johan Hovold @ 2026-04-02 9:27 UTC (permalink / raw)
To: Luiz Augusto von Dentz, Marcel Holtmann
Cc: linux-bluetooth, linux-kernel, Johan Hovold, Rajat Jain
The OOB wakeup irq is device managed but its lifetime is incorrectly
tied to the child HCI device rather than the USB interface to which the
driver is bound.
This should not cause any trouble currently as the interrupt will be
disabled when the HCI device is deregistered on disconnect (but this was
not always the case, see [1]), and there should be no further references
if probe fails before registering it. But it is still technically wrong
as the reference counted HCI device could in theory remain after a probe
failure.
Explicitly free the interrupt on disconnect so that it is guaranteed to
be disabled before freeing the (non-managed) driver data (including if
disconnected while suspended).
[1] 699fb50d9903 ("drivers: base: Free devm resources when unregistering
a device")
Fixes: fd913ef7ce61 ("Bluetooth: btusb: Add out-of-band wakeup support")
Cc: Rajat Jain <rajatja@google.com>
Signed-off-by: Johan Hovold <johan@kernel.org>
---
drivers/bluetooth/btusb.c | 20 +++++++++++++++-----
1 file changed, 15 insertions(+), 5 deletions(-)
diff --git a/drivers/bluetooth/btusb.c b/drivers/bluetooth/btusb.c
index 9e4390ba82ba..0001477463a3 100644
--- a/drivers/bluetooth/btusb.c
+++ b/drivers/bluetooth/btusb.c
@@ -3784,8 +3784,7 @@ static int btusb_config_oob_wake(struct hci_dev *hdev)
}
irq_set_status_flags(irq, IRQ_NOAUTOEN);
- ret = devm_request_irq(&hdev->dev, irq, btusb_oob_wake_handler,
- 0, "OOB Wake-on-BT", data);
+ ret = request_irq(irq, btusb_oob_wake_handler, 0, "OOB Wake-on-BT", data);
if (ret) {
bt_dev_err(hdev, "%s: IRQ request failed", __func__);
return ret;
@@ -3794,12 +3793,18 @@ static int btusb_config_oob_wake(struct hci_dev *hdev)
ret = device_init_wakeup(dev, true);
if (ret) {
bt_dev_err(hdev, "%s: failed to init_wakeup", __func__);
- return ret;
+ goto err_free_irq;
}
data->oob_wake_irq = irq;
bt_dev_info(hdev, "OOB Wake-on-BT configured at IRQ %u", irq);
+
return 0;
+
+err_free_irq:
+ free_irq(irq, data);
+
+ return ret;
}
#endif
@@ -4382,8 +4387,10 @@ static int btusb_probe(struct usb_interface *intf,
return 0;
err_disable_wakeup:
- if (data->oob_wake_irq)
+ if (data->oob_wake_irq) {
device_init_wakeup(&data->udev->dev, false);
+ free_irq(data->oob_wake_irq, data);
+ }
out_free_dev:
if (data->reset_gpio)
gpiod_put(data->reset_gpio);
@@ -4416,8 +4423,11 @@ static void btusb_disconnect(struct usb_interface *intf)
hci_unregister_dev(hdev);
- if (data->oob_wake_irq)
+ if (data->oob_wake_irq) {
device_init_wakeup(&data->udev->dev, false);
+ free_irq(data->oob_wake_irq, data);
+ }
+
if (data->reset_gpio)
gpiod_put(data->reset_gpio);
--
2.52.0
^ permalink raw reply related [flat|nested] 6+ messages in thread* [PATCH v2 3/3] Bluetooth: btusb: clean up probe error handling
2026-04-02 9:27 [PATCH v2 0/3] Bluetooth: btusb: fix wakeup irq devres lifetime Johan Hovold
2026-04-02 9:27 ` [PATCH v2 1/3] Bluetooth: btusb: fix wakeup source leak on probe failure Johan Hovold
2026-04-02 9:27 ` [PATCH v2 2/3] " Johan Hovold
@ 2026-04-02 9:27 ` Johan Hovold
2026-04-02 14:16 ` [PATCH v2 0/3] Bluetooth: btusb: fix wakeup irq devres lifetime Johan Hovold
3 siblings, 0 replies; 6+ messages in thread
From: Johan Hovold @ 2026-04-02 9:27 UTC (permalink / raw)
To: Luiz Augusto von Dentz, Marcel Holtmann
Cc: linux-bluetooth, linux-kernel, Johan Hovold
Clean up probe error handling by using dedicated error labels with an
"err" prefix.
Note that the endpoint lookup helper returns -ENXIO when endpoints are
missing which is functionally equivalent to returning -ENODEV.
Signed-off-by: Johan Hovold <johan@kernel.org>
---
drivers/bluetooth/btusb.c | 19 ++++++++++---------
1 file changed, 10 insertions(+), 9 deletions(-)
diff --git a/drivers/bluetooth/btusb.c b/drivers/bluetooth/btusb.c
index 0001477463a3..28e2a536a309 100644
--- a/drivers/bluetooth/btusb.c
+++ b/drivers/bluetooth/btusb.c
@@ -4055,10 +4055,8 @@ static int btusb_probe(struct usb_interface *intf,
err = usb_find_common_endpoints(intf->cur_altsetting, &data->bulk_rx_ep,
&data->bulk_tx_ep, &data->intr_ep, NULL);
- if (err) {
- kfree(data);
- return -ENODEV;
- }
+ if (err)
+ goto err_free_data;
if (id->driver_info & BTUSB_AMP) {
data->cmdreq_type = USB_TYPE_CLASS | 0x01;
@@ -4114,8 +4112,8 @@ static int btusb_probe(struct usb_interface *intf,
hdev = hci_alloc_dev_priv(priv_size);
if (!hdev) {
- kfree(data);
- return -ENOMEM;
+ err = -ENOMEM;
+ goto err_free_data;
}
hdev->bus = HCI_USB;
@@ -4129,7 +4127,7 @@ static int btusb_probe(struct usb_interface *intf,
GPIOD_OUT_LOW);
if (IS_ERR(reset_gpio)) {
err = PTR_ERR(reset_gpio);
- goto out_free_dev;
+ goto err_free_hdev;
} else if (reset_gpio) {
data->reset_gpio = reset_gpio;
}
@@ -4145,7 +4143,7 @@ static int btusb_probe(struct usb_interface *intf,
#ifdef CONFIG_PM
err = btusb_config_oob_wake(hdev);
if (err)
- goto out_free_dev;
+ goto err_put_reset;
/* Marvell devices may need a specific chip configuration */
if (id->driver_info & BTUSB_MARVELL && data->oob_wake_irq) {
@@ -4391,11 +4389,14 @@ static int btusb_probe(struct usb_interface *intf,
device_init_wakeup(&data->udev->dev, false);
free_irq(data->oob_wake_irq, data);
}
-out_free_dev:
+err_put_reset:
if (data->reset_gpio)
gpiod_put(data->reset_gpio);
+err_free_hdev:
hci_free_dev(hdev);
+err_free_data:
kfree(data);
+
return err;
}
--
2.52.0
^ permalink raw reply related [flat|nested] 6+ messages in thread* Re: [PATCH v2 0/3] Bluetooth: btusb: fix wakeup irq devres lifetime
2026-04-02 9:27 [PATCH v2 0/3] Bluetooth: btusb: fix wakeup irq devres lifetime Johan Hovold
` (2 preceding siblings ...)
2026-04-02 9:27 ` [PATCH v2 3/3] Bluetooth: btusb: clean up probe error handling Johan Hovold
@ 2026-04-02 14:16 ` Johan Hovold
3 siblings, 0 replies; 6+ messages in thread
From: Johan Hovold @ 2026-04-02 14:16 UTC (permalink / raw)
To: Luiz Augusto von Dentz, Marcel Holtmann; +Cc: linux-bluetooth, linux-kernel
On Thu, Apr 02, 2026 at 11:27:01AM +0200, Johan Hovold wrote:
> This series fixes a wakeup source leak and a (currently benign) OOB
> wakeup interrupt devres lifetime issue.
>
> Included is also a related cleanup.
>
> Note that these are intended for 7.1 (e.g. as the fixes are not
> critical) and apply on top of linux-next which has commit 2db5a8b68e31
> ("Bluetooth: btusb: refactor endpoint lookup").
> Changes in v2:
> - fix wakeup source leak (new patch)
> - fix disconnect-while-suspended issue by making interrupt non-managed
> - amend devres lifetime fix commit message with a reference to changed
> devres behaviour
> - clean up error handling (new patch)
> Johan Hovold (3):
> Bluetooth: btusb: fix wakeup source leak on probe failure
> Bluetooth: btusb: fix wakeup irq devres lifetime
> Bluetooth: btusb: clean up probe error handling
Sashiko reported two pre-existing bugs related to these paths and I can
can take a look at fixing those as part of this series:
https://sashiko.dev/#/message/20260402092704.2346710-2-johan%40kernel.org
So please hold off with applying this one for a bit.
Johan
^ permalink raw reply [flat|nested] 6+ messages in thread