Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
25 changes: 25 additions & 0 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
name: CI

on: [pull_request]

jobs:
ci:
runs-on: ubuntu-latest
name: CI for Pull Request
steps:
- name: Checkout the source code
uses: actions/checkout@v3
with:
path: src/src

- name: CI
uses: tedd-an/bzcafe@main
with:
task: ci
base_folder: src
space: kernel
github_token: ${{ secrets.GITHUB_TOKEN }}
email_token: ${{ secrets.EMAIL_TOKEN }}
patchwork_token: ${{ secrets.PATCHWORK_TOKEN }}
patchwork_user: ${{ secrets.PATCHWORK_USER }}

43 changes: 43 additions & 0 deletions .github/workflows/sync.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
name: Sync

on:
schedule:
- cron: "*/30 * * * *"

jobs:
sync_repo:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
with:
ref: master

- name: Sync Repo
uses: tedd-an/bzcafe@main
with:
task: sync
upstream_repo: 'https://git.kernel.org/pub/scm/linux/kernel/git/bluetooth/bluetooth-next.git'
github_token: ${{ secrets.GITHUB_TOKEN }}

- name: Cleanup PR
uses: tedd-an/bzcafe@main
with:
task: cleanup
github_token: ${{ secrets.ACTION_TOKEN }}

sync_patchwork:
needs: sync_repo
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3

- name: Sync Patchwork
uses: tedd-an/bzcafe@main
with:
task: patchwork
space: kernel
github_token: ${{ secrets.ACTION_TOKEN }}
email_token: ${{ secrets.EMAIL_TOKEN }}
patchwork_token: ${{ secrets.PATCHWORK_TOKEN }}
patchwork_user: ${{ secrets.PATCHWORK_USER }}

61 changes: 43 additions & 18 deletions drivers/bluetooth/btusb.c
Original file line number Diff line number Diff line change
Expand Up @@ -3811,8 +3811,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;
Expand All @@ -3821,12 +3820,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

Expand Down Expand Up @@ -4077,10 +4082,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;
Expand Down Expand Up @@ -4136,8 +4139,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;
Expand All @@ -4151,7 +4154,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;
}
Expand All @@ -4167,13 +4170,13 @@ 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) {
err = marvell_config_oob_wake(hdev);
if (err)
goto out_free_dev;
goto err_disable_wakeup;
}
#endif
if (id->driver_info & BTUSB_CW6622)
Expand Down Expand Up @@ -4210,7 +4213,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_kill_tx_urbs;

/* Transport specific configuration */
hdev->send = btusb_send_frame_intel;
Expand Down Expand Up @@ -4373,15 +4376,15 @@ 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_kill_tx_urbs;
}
}

if (data->isoc) {
err = usb_driver_claim_interface(&btusb_driver,
data->isoc, data);
if (err < 0)
goto out_free_dev;
goto err_kill_tx_urbs;
}

if (IS_ENABLED(CONFIG_BT_HCIBTUSB_BCM) && data->diag) {
Expand All @@ -4399,7 +4402,7 @@ static int btusb_probe(struct usb_interface *intf,

err = hci_register_dev(hdev);
if (err < 0)
goto out_free_dev;
goto err_release_siblings;

usb_set_intfdata(intf, data);

Expand All @@ -4408,11 +4411,30 @@ static int btusb_probe(struct usb_interface *intf,

return 0;

out_free_dev:
err_release_siblings:
if (data->diag) {
usb_set_intfdata(data->diag, NULL);
usb_driver_release_interface(&btusb_driver, data->diag);
}
if (data->isoc) {
usb_set_intfdata(data->isoc, NULL);
usb_driver_release_interface(&btusb_driver, data->isoc);
}
err_kill_tx_urbs:
usb_kill_anchored_urbs(&data->tx_anchor);
err_disable_wakeup:
if (data->oob_wake_irq) {
device_init_wakeup(&data->udev->dev, false);
free_irq(data->oob_wake_irq, data);
}
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;
}

Expand Down Expand Up @@ -4440,8 +4462,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);

Expand Down
Loading