diff options
author | Johan Hedberg <johan.hedberg@nokia.com> | 2010-07-12 10:37:04 -0400 |
---|---|---|
committer | Marcel Holtmann <marcel@holtmann.org> | 2010-07-21 13:39:11 -0400 |
commit | 63c7d09cd52fe23ad2baee26bcc10a590944cfa4 (patch) | |
tree | 0d9d12e077f2f9612c6736fad45a69fda4b182d5 /drivers/bluetooth/hci_ldisc.c | |
parent | 47731de789749c9ed3c54751db28fd9c9eeaf019 (diff) |
Bluetooth: Add HCIUARTSETFLAGS and HCIUARTGETFLAGS ioctls
This patch introduces two new ioctls: HCIUARTSETFLAGS and
HCIUARTGETFLAGS. The only flag available for now is HCI_UART_RAW_DEVICE
which allows to initialize a UART device into RAW mode from userspace.
This is particularly useful for experimenting with Bluetooth controllers
that don't yet have proper support in BlueZ.
Signed-off-by: Johan Hedberg <johan.hedberg@nokia.com>
Signed-off-by: Marcel Holtmann <marcel@holtmann.org>
Diffstat (limited to 'drivers/bluetooth/hci_ldisc.c')
-rw-r--r-- | drivers/bluetooth/hci_ldisc.c | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/drivers/bluetooth/hci_ldisc.c b/drivers/bluetooth/hci_ldisc.c index e8beffe80b31..a57dbfccb3fb 100644 --- a/drivers/bluetooth/hci_ldisc.c +++ b/drivers/bluetooth/hci_ldisc.c | |||
@@ -395,6 +395,9 @@ static int hci_uart_register_dev(struct hci_uart *hu) | |||
395 | if (!reset) | 395 | if (!reset) |
396 | set_bit(HCI_QUIRK_NO_RESET, &hdev->quirks); | 396 | set_bit(HCI_QUIRK_NO_RESET, &hdev->quirks); |
397 | 397 | ||
398 | if (test_bit(HCI_UART_RAW_DEVICE, &hu->hdev_flags)) | ||
399 | set_bit(HCI_QUIRK_RAW_DEVICE, &hdev->quirks); | ||
400 | |||
398 | if (hci_register_dev(hdev) < 0) { | 401 | if (hci_register_dev(hdev) < 0) { |
399 | BT_ERR("Can't register HCI device"); | 402 | BT_ERR("Can't register HCI device"); |
400 | hci_free_dev(hdev); | 403 | hci_free_dev(hdev); |
@@ -475,6 +478,15 @@ static int hci_uart_tty_ioctl(struct tty_struct *tty, struct file * file, | |||
475 | return hu->hdev->id; | 478 | return hu->hdev->id; |
476 | return -EUNATCH; | 479 | return -EUNATCH; |
477 | 480 | ||
481 | case HCIUARTSETFLAGS: | ||
482 | if (test_bit(HCI_UART_PROTO_SET, &hu->flags)) | ||
483 | return -EBUSY; | ||
484 | hu->hdev_flags = arg; | ||
485 | break; | ||
486 | |||
487 | case HCIUARTGETFLAGS: | ||
488 | return hu->hdev_flags; | ||
489 | |||
478 | default: | 490 | default: |
479 | err = n_tty_ioctl_helper(tty, file, cmd, arg); | 491 | err = n_tty_ioctl_helper(tty, file, cmd, arg); |
480 | break; | 492 | break; |