|
@@ -257,7 +257,7 @@ static int read_controller_info(struct sock *sk, u16 index)
|
|
|
if (test_and_clear_bit(HCI_AUTO_OFF, &hdev->flags))
|
|
|
cancel_delayed_work_sync(&hdev->power_off);
|
|
|
|
|
|
- hci_dev_lock_bh(hdev);
|
|
|
+ hci_dev_lock(hdev);
|
|
|
|
|
|
set_bit(HCI_MGMT, &hdev->flags);
|
|
|
|
|
@@ -286,7 +286,7 @@ static int read_controller_info(struct sock *sk, u16 index)
|
|
|
|
|
|
memcpy(rp.name, hdev->dev_name, sizeof(hdev->dev_name));
|
|
|
|
|
|
- hci_dev_unlock_bh(hdev);
|
|
|
+ hci_dev_unlock(hdev);
|
|
|
hci_dev_put(hdev);
|
|
|
|
|
|
return cmd_complete(sk, index, MGMT_OP_READ_INFO, &rp, sizeof(rp));
|
|
@@ -394,7 +394,7 @@ static int set_powered(struct sock *sk, u16 index, unsigned char *data, u16 len)
|
|
|
return cmd_status(sk, index, MGMT_OP_SET_POWERED,
|
|
|
MGMT_STATUS_INVALID_PARAMS);
|
|
|
|
|
|
- hci_dev_lock_bh(hdev);
|
|
|
+ hci_dev_lock(hdev);
|
|
|
|
|
|
up = test_bit(HCI_UP, &hdev->flags);
|
|
|
if ((cp->val && up) || (!cp->val && !up)) {
|
|
@@ -422,7 +422,7 @@ static int set_powered(struct sock *sk, u16 index, unsigned char *data, u16 len)
|
|
|
err = 0;
|
|
|
|
|
|
failed:
|
|
|
- hci_dev_unlock_bh(hdev);
|
|
|
+ hci_dev_unlock(hdev);
|
|
|
hci_dev_put(hdev);
|
|
|
return err;
|
|
|
}
|
|
@@ -449,7 +449,7 @@ static int set_discoverable(struct sock *sk, u16 index, unsigned char *data,
|
|
|
return cmd_status(sk, index, MGMT_OP_SET_DISCOVERABLE,
|
|
|
MGMT_STATUS_INVALID_PARAMS);
|
|
|
|
|
|
- hci_dev_lock_bh(hdev);
|
|
|
+ hci_dev_lock(hdev);
|
|
|
|
|
|
if (!test_bit(HCI_UP, &hdev->flags)) {
|
|
|
err = cmd_status(sk, index, MGMT_OP_SET_DISCOVERABLE,
|
|
@@ -492,7 +492,7 @@ static int set_discoverable(struct sock *sk, u16 index, unsigned char *data,
|
|
|
hdev->discov_timeout = get_unaligned_le16(&cp->timeout);
|
|
|
|
|
|
failed:
|
|
|
- hci_dev_unlock_bh(hdev);
|
|
|
+ hci_dev_unlock(hdev);
|
|
|
hci_dev_put(hdev);
|
|
|
|
|
|
return err;
|
|
@@ -520,7 +520,7 @@ static int set_connectable(struct sock *sk, u16 index, unsigned char *data,
|
|
|
return cmd_status(sk, index, MGMT_OP_SET_CONNECTABLE,
|
|
|
MGMT_STATUS_INVALID_PARAMS);
|
|
|
|
|
|
- hci_dev_lock_bh(hdev);
|
|
|
+ hci_dev_lock(hdev);
|
|
|
|
|
|
if (!test_bit(HCI_UP, &hdev->flags)) {
|
|
|
err = cmd_status(sk, index, MGMT_OP_SET_CONNECTABLE,
|
|
@@ -557,7 +557,7 @@ static int set_connectable(struct sock *sk, u16 index, unsigned char *data,
|
|
|
mgmt_pending_remove(cmd);
|
|
|
|
|
|
failed:
|
|
|
- hci_dev_unlock_bh(hdev);
|
|
|
+ hci_dev_unlock(hdev);
|
|
|
hci_dev_put(hdev);
|
|
|
|
|
|
return err;
|
|
@@ -612,7 +612,7 @@ static int set_pairable(struct sock *sk, u16 index, unsigned char *data,
|
|
|
return cmd_status(sk, index, MGMT_OP_SET_PAIRABLE,
|
|
|
MGMT_STATUS_INVALID_PARAMS);
|
|
|
|
|
|
- hci_dev_lock_bh(hdev);
|
|
|
+ hci_dev_lock(hdev);
|
|
|
|
|
|
if (cp->val)
|
|
|
set_bit(HCI_PAIRABLE, &hdev->flags);
|
|
@@ -628,7 +628,7 @@ static int set_pairable(struct sock *sk, u16 index, unsigned char *data,
|
|
|
err = mgmt_event(MGMT_EV_PAIRABLE, hdev, &ev, sizeof(ev), sk);
|
|
|
|
|
|
failed:
|
|
|
- hci_dev_unlock_bh(hdev);
|
|
|
+ hci_dev_unlock(hdev);
|
|
|
hci_dev_put(hdev);
|
|
|
|
|
|
return err;
|
|
@@ -827,7 +827,7 @@ static int add_uuid(struct sock *sk, u16 index, unsigned char *data, u16 len)
|
|
|
return cmd_status(sk, index, MGMT_OP_ADD_UUID,
|
|
|
MGMT_STATUS_INVALID_PARAMS);
|
|
|
|
|
|
- hci_dev_lock_bh(hdev);
|
|
|
+ hci_dev_lock(hdev);
|
|
|
|
|
|
uuid = kmalloc(sizeof(*uuid), GFP_ATOMIC);
|
|
|
if (!uuid) {
|
|
@@ -851,7 +851,7 @@ static int add_uuid(struct sock *sk, u16 index, unsigned char *data, u16 len)
|
|
|
err = cmd_complete(sk, index, MGMT_OP_ADD_UUID, NULL, 0);
|
|
|
|
|
|
failed:
|
|
|
- hci_dev_unlock_bh(hdev);
|
|
|
+ hci_dev_unlock(hdev);
|
|
|
hci_dev_put(hdev);
|
|
|
|
|
|
return err;
|
|
@@ -878,7 +878,7 @@ static int remove_uuid(struct sock *sk, u16 index, unsigned char *data, u16 len)
|
|
|
return cmd_status(sk, index, MGMT_OP_REMOVE_UUID,
|
|
|
MGMT_STATUS_INVALID_PARAMS);
|
|
|
|
|
|
- hci_dev_lock_bh(hdev);
|
|
|
+ hci_dev_lock(hdev);
|
|
|
|
|
|
if (memcmp(cp->uuid, bt_uuid_any, 16) == 0) {
|
|
|
err = hci_uuids_clear(hdev);
|
|
@@ -914,7 +914,7 @@ static int remove_uuid(struct sock *sk, u16 index, unsigned char *data, u16 len)
|
|
|
err = cmd_complete(sk, index, MGMT_OP_REMOVE_UUID, NULL, 0);
|
|
|
|
|
|
unlock:
|
|
|
- hci_dev_unlock_bh(hdev);
|
|
|
+ hci_dev_unlock(hdev);
|
|
|
hci_dev_put(hdev);
|
|
|
|
|
|
return err;
|
|
@@ -940,7 +940,7 @@ static int set_dev_class(struct sock *sk, u16 index, unsigned char *data,
|
|
|
return cmd_status(sk, index, MGMT_OP_SET_DEV_CLASS,
|
|
|
MGMT_STATUS_INVALID_PARAMS);
|
|
|
|
|
|
- hci_dev_lock_bh(hdev);
|
|
|
+ hci_dev_lock(hdev);
|
|
|
|
|
|
hdev->major_class = cp->major;
|
|
|
hdev->minor_class = cp->minor;
|
|
@@ -950,7 +950,7 @@ static int set_dev_class(struct sock *sk, u16 index, unsigned char *data,
|
|
|
if (err == 0)
|
|
|
err = cmd_complete(sk, index, MGMT_OP_SET_DEV_CLASS, NULL, 0);
|
|
|
|
|
|
- hci_dev_unlock_bh(hdev);
|
|
|
+ hci_dev_unlock(hdev);
|
|
|
hci_dev_put(hdev);
|
|
|
|
|
|
return err;
|
|
@@ -974,7 +974,7 @@ static int set_service_cache(struct sock *sk, u16 index, unsigned char *data,
|
|
|
return cmd_status(sk, index, MGMT_OP_SET_SERVICE_CACHE,
|
|
|
MGMT_STATUS_INVALID_PARAMS);
|
|
|
|
|
|
- hci_dev_lock_bh(hdev);
|
|
|
+ hci_dev_lock(hdev);
|
|
|
|
|
|
BT_DBG("hci%u enable %d", index, cp->enable);
|
|
|
|
|
@@ -995,7 +995,7 @@ static int set_service_cache(struct sock *sk, u16 index, unsigned char *data,
|
|
|
cmd_status(sk, index, MGMT_OP_SET_SERVICE_CACHE, -err);
|
|
|
|
|
|
|
|
|
- hci_dev_unlock_bh(hdev);
|
|
|
+ hci_dev_unlock(hdev);
|
|
|
hci_dev_put(hdev);
|
|
|
|
|
|
return err;
|
|
@@ -1034,7 +1034,7 @@ static int load_link_keys(struct sock *sk, u16 index, unsigned char *data,
|
|
|
BT_DBG("hci%u debug_keys %u key_count %u", index, cp->debug_keys,
|
|
|
key_count);
|
|
|
|
|
|
- hci_dev_lock_bh(hdev);
|
|
|
+ hci_dev_lock(hdev);
|
|
|
|
|
|
hci_link_keys_clear(hdev);
|
|
|
|
|
@@ -1054,7 +1054,7 @@ static int load_link_keys(struct sock *sk, u16 index, unsigned char *data,
|
|
|
|
|
|
cmd_complete(sk, index, MGMT_OP_LOAD_LINK_KEYS, NULL, 0);
|
|
|
|
|
|
- hci_dev_unlock_bh(hdev);
|
|
|
+ hci_dev_unlock(hdev);
|
|
|
hci_dev_put(hdev);
|
|
|
|
|
|
return 0;
|
|
@@ -1082,7 +1082,7 @@ static int remove_keys(struct sock *sk, u16 index, unsigned char *data,
|
|
|
return cmd_status(sk, index, MGMT_OP_REMOVE_KEYS,
|
|
|
MGMT_STATUS_INVALID_PARAMS);
|
|
|
|
|
|
- hci_dev_lock_bh(hdev);
|
|
|
+ hci_dev_lock(hdev);
|
|
|
|
|
|
memset(&rp, 0, sizeof(rp));
|
|
|
bacpy(&rp.bdaddr, &cp->bdaddr);
|
|
@@ -1123,7 +1123,7 @@ unlock:
|
|
|
if (err < 0)
|
|
|
err = cmd_complete(sk, index, MGMT_OP_REMOVE_KEYS, &rp,
|
|
|
sizeof(rp));
|
|
|
- hci_dev_unlock_bh(hdev);
|
|
|
+ hci_dev_unlock(hdev);
|
|
|
hci_dev_put(hdev);
|
|
|
|
|
|
return err;
|
|
@@ -1151,7 +1151,7 @@ static int disconnect(struct sock *sk, u16 index, unsigned char *data, u16 len)
|
|
|
return cmd_status(sk, index, MGMT_OP_DISCONNECT,
|
|
|
MGMT_STATUS_INVALID_PARAMS);
|
|
|
|
|
|
- hci_dev_lock_bh(hdev);
|
|
|
+ hci_dev_lock(hdev);
|
|
|
|
|
|
if (!test_bit(HCI_UP, &hdev->flags)) {
|
|
|
err = cmd_status(sk, index, MGMT_OP_DISCONNECT,
|
|
@@ -1189,7 +1189,7 @@ static int disconnect(struct sock *sk, u16 index, unsigned char *data, u16 len)
|
|
|
mgmt_pending_remove(cmd);
|
|
|
|
|
|
failed:
|
|
|
- hci_dev_unlock_bh(hdev);
|
|
|
+ hci_dev_unlock(hdev);
|
|
|
hci_dev_put(hdev);
|
|
|
|
|
|
return err;
|
|
@@ -1231,7 +1231,7 @@ static int get_connections(struct sock *sk, u16 index)
|
|
|
return cmd_status(sk, index, MGMT_OP_GET_CONNECTIONS,
|
|
|
MGMT_STATUS_INVALID_PARAMS);
|
|
|
|
|
|
- hci_dev_lock_bh(hdev);
|
|
|
+ hci_dev_lock(hdev);
|
|
|
|
|
|
count = 0;
|
|
|
list_for_each(p, &hdev->conn_hash.list) {
|
|
@@ -1263,7 +1263,7 @@ static int get_connections(struct sock *sk, u16 index)
|
|
|
|
|
|
unlock:
|
|
|
kfree(rp);
|
|
|
- hci_dev_unlock_bh(hdev);
|
|
|
+ hci_dev_unlock(hdev);
|
|
|
hci_dev_put(hdev);
|
|
|
return err;
|
|
|
}
|
|
@@ -1311,7 +1311,7 @@ static int pin_code_reply(struct sock *sk, u16 index, unsigned char *data,
|
|
|
return cmd_status(sk, index, MGMT_OP_PIN_CODE_REPLY,
|
|
|
MGMT_STATUS_INVALID_PARAMS);
|
|
|
|
|
|
- hci_dev_lock_bh(hdev);
|
|
|
+ hci_dev_lock(hdev);
|
|
|
|
|
|
if (!test_bit(HCI_UP, &hdev->flags)) {
|
|
|
err = cmd_status(sk, index, MGMT_OP_PIN_CODE_REPLY,
|
|
@@ -1354,7 +1354,7 @@ static int pin_code_reply(struct sock *sk, u16 index, unsigned char *data,
|
|
|
mgmt_pending_remove(cmd);
|
|
|
|
|
|
failed:
|
|
|
- hci_dev_unlock_bh(hdev);
|
|
|
+ hci_dev_unlock(hdev);
|
|
|
hci_dev_put(hdev);
|
|
|
|
|
|
return err;
|
|
@@ -1380,7 +1380,7 @@ static int pin_code_neg_reply(struct sock *sk, u16 index, unsigned char *data,
|
|
|
return cmd_status(sk, index, MGMT_OP_PIN_CODE_NEG_REPLY,
|
|
|
MGMT_STATUS_INVALID_PARAMS);
|
|
|
|
|
|
- hci_dev_lock_bh(hdev);
|
|
|
+ hci_dev_lock(hdev);
|
|
|
|
|
|
if (!test_bit(HCI_UP, &hdev->flags)) {
|
|
|
err = cmd_status(sk, index, MGMT_OP_PIN_CODE_NEG_REPLY,
|
|
@@ -1391,7 +1391,7 @@ static int pin_code_neg_reply(struct sock *sk, u16 index, unsigned char *data,
|
|
|
err = send_pin_code_neg_reply(sk, index, hdev, cp);
|
|
|
|
|
|
failed:
|
|
|
- hci_dev_unlock_bh(hdev);
|
|
|
+ hci_dev_unlock(hdev);
|
|
|
hci_dev_put(hdev);
|
|
|
|
|
|
return err;
|
|
@@ -1416,14 +1416,14 @@ static int set_io_capability(struct sock *sk, u16 index, unsigned char *data,
|
|
|
return cmd_status(sk, index, MGMT_OP_SET_IO_CAPABILITY,
|
|
|
MGMT_STATUS_INVALID_PARAMS);
|
|
|
|
|
|
- hci_dev_lock_bh(hdev);
|
|
|
+ hci_dev_lock(hdev);
|
|
|
|
|
|
hdev->io_capability = cp->io_capability;
|
|
|
|
|
|
BT_DBG("%s IO capability set to 0x%02x", hdev->name,
|
|
|
hdev->io_capability);
|
|
|
|
|
|
- hci_dev_unlock_bh(hdev);
|
|
|
+ hci_dev_unlock(hdev);
|
|
|
hci_dev_put(hdev);
|
|
|
|
|
|
return cmd_complete(sk, index, MGMT_OP_SET_IO_CAPABILITY, NULL, 0);
|
|
@@ -1504,7 +1504,7 @@ static int pair_device(struct sock *sk, u16 index, unsigned char *data, u16 len)
|
|
|
return cmd_status(sk, index, MGMT_OP_PAIR_DEVICE,
|
|
|
MGMT_STATUS_INVALID_PARAMS);
|
|
|
|
|
|
- hci_dev_lock_bh(hdev);
|
|
|
+ hci_dev_lock(hdev);
|
|
|
|
|
|
sec_level = BT_SECURITY_MEDIUM;
|
|
|
if (cp->io_cap == 0x03)
|
|
@@ -1561,7 +1561,7 @@ static int pair_device(struct sock *sk, u16 index, unsigned char *data, u16 len)
|
|
|
err = 0;
|
|
|
|
|
|
unlock:
|
|
|
- hci_dev_unlock_bh(hdev);
|
|
|
+ hci_dev_unlock(hdev);
|
|
|
hci_dev_put(hdev);
|
|
|
|
|
|
return err;
|
|
@@ -1580,7 +1580,7 @@ static int user_pairing_resp(struct sock *sk, u16 index, bdaddr_t *bdaddr,
|
|
|
return cmd_status(sk, index, mgmt_op,
|
|
|
MGMT_STATUS_INVALID_PARAMS);
|
|
|
|
|
|
- hci_dev_lock_bh(hdev);
|
|
|
+ hci_dev_lock(hdev);
|
|
|
|
|
|
if (!test_bit(HCI_UP, &hdev->flags)) {
|
|
|
err = cmd_status(sk, index, mgmt_op, MGMT_STATUS_NOT_POWERED);
|
|
@@ -1631,7 +1631,7 @@ static int user_pairing_resp(struct sock *sk, u16 index, bdaddr_t *bdaddr,
|
|
|
mgmt_pending_remove(cmd);
|
|
|
|
|
|
done:
|
|
|
- hci_dev_unlock_bh(hdev);
|
|
|
+ hci_dev_unlock(hdev);
|
|
|
hci_dev_put(hdev);
|
|
|
|
|
|
return err;
|
|
@@ -1719,7 +1719,7 @@ static int set_local_name(struct sock *sk, u16 index, unsigned char *data,
|
|
|
return cmd_status(sk, index, MGMT_OP_SET_LOCAL_NAME,
|
|
|
MGMT_STATUS_INVALID_PARAMS);
|
|
|
|
|
|
- hci_dev_lock_bh(hdev);
|
|
|
+ hci_dev_lock(hdev);
|
|
|
|
|
|
cmd = mgmt_pending_add(sk, MGMT_OP_SET_LOCAL_NAME, hdev, data, len);
|
|
|
if (!cmd) {
|
|
@@ -1734,7 +1734,7 @@ static int set_local_name(struct sock *sk, u16 index, unsigned char *data,
|
|
|
mgmt_pending_remove(cmd);
|
|
|
|
|
|
failed:
|
|
|
- hci_dev_unlock_bh(hdev);
|
|
|
+ hci_dev_unlock(hdev);
|
|
|
hci_dev_put(hdev);
|
|
|
|
|
|
return err;
|
|
@@ -1753,7 +1753,7 @@ static int read_local_oob_data(struct sock *sk, u16 index)
|
|
|
return cmd_status(sk, index, MGMT_OP_READ_LOCAL_OOB_DATA,
|
|
|
MGMT_STATUS_INVALID_PARAMS);
|
|
|
|
|
|
- hci_dev_lock_bh(hdev);
|
|
|
+ hci_dev_lock(hdev);
|
|
|
|
|
|
if (!test_bit(HCI_UP, &hdev->flags)) {
|
|
|
err = cmd_status(sk, index, MGMT_OP_READ_LOCAL_OOB_DATA,
|
|
@@ -1784,7 +1784,7 @@ static int read_local_oob_data(struct sock *sk, u16 index)
|
|
|
mgmt_pending_remove(cmd);
|
|
|
|
|
|
unlock:
|
|
|
- hci_dev_unlock_bh(hdev);
|
|
|
+ hci_dev_unlock(hdev);
|
|
|
hci_dev_put(hdev);
|
|
|
|
|
|
return err;
|
|
@@ -1808,7 +1808,7 @@ static int add_remote_oob_data(struct sock *sk, u16 index, unsigned char *data,
|
|
|
return cmd_status(sk, index, MGMT_OP_ADD_REMOTE_OOB_DATA,
|
|
|
MGMT_STATUS_INVALID_PARAMS);
|
|
|
|
|
|
- hci_dev_lock_bh(hdev);
|
|
|
+ hci_dev_lock(hdev);
|
|
|
|
|
|
err = hci_add_remote_oob_data(hdev, &cp->bdaddr, cp->hash,
|
|
|
cp->randomizer);
|
|
@@ -1819,7 +1819,7 @@ static int add_remote_oob_data(struct sock *sk, u16 index, unsigned char *data,
|
|
|
err = cmd_complete(sk, index, MGMT_OP_ADD_REMOTE_OOB_DATA, NULL,
|
|
|
0);
|
|
|
|
|
|
- hci_dev_unlock_bh(hdev);
|
|
|
+ hci_dev_unlock(hdev);
|
|
|
hci_dev_put(hdev);
|
|
|
|
|
|
return err;
|
|
@@ -1843,7 +1843,7 @@ static int remove_remote_oob_data(struct sock *sk, u16 index,
|
|
|
return cmd_status(sk, index, MGMT_OP_REMOVE_REMOTE_OOB_DATA,
|
|
|
MGMT_STATUS_INVALID_PARAMS);
|
|
|
|
|
|
- hci_dev_lock_bh(hdev);
|
|
|
+ hci_dev_lock(hdev);
|
|
|
|
|
|
err = hci_remove_remote_oob_data(hdev, &cp->bdaddr);
|
|
|
if (err < 0)
|
|
@@ -1853,7 +1853,7 @@ static int remove_remote_oob_data(struct sock *sk, u16 index,
|
|
|
err = cmd_complete(sk, index, MGMT_OP_REMOVE_REMOTE_OOB_DATA,
|
|
|
NULL, 0);
|
|
|
|
|
|
- hci_dev_unlock_bh(hdev);
|
|
|
+ hci_dev_unlock(hdev);
|
|
|
hci_dev_put(hdev);
|
|
|
|
|
|
return err;
|
|
@@ -1878,7 +1878,7 @@ static int start_discovery(struct sock *sk, u16 index,
|
|
|
return cmd_status(sk, index, MGMT_OP_START_DISCOVERY,
|
|
|
MGMT_STATUS_INVALID_PARAMS);
|
|
|
|
|
|
- hci_dev_lock_bh(hdev);
|
|
|
+ hci_dev_lock(hdev);
|
|
|
|
|
|
if (!test_bit(HCI_UP, &hdev->flags)) {
|
|
|
err = cmd_status(sk, index, MGMT_OP_START_DISCOVERY,
|
|
@@ -1897,7 +1897,7 @@ static int start_discovery(struct sock *sk, u16 index,
|
|
|
mgmt_pending_remove(cmd);
|
|
|
|
|
|
failed:
|
|
|
- hci_dev_unlock_bh(hdev);
|
|
|
+ hci_dev_unlock(hdev);
|
|
|
hci_dev_put(hdev);
|
|
|
|
|
|
return err;
|
|
@@ -1916,7 +1916,7 @@ static int stop_discovery(struct sock *sk, u16 index)
|
|
|
return cmd_status(sk, index, MGMT_OP_STOP_DISCOVERY,
|
|
|
MGMT_STATUS_INVALID_PARAMS);
|
|
|
|
|
|
- hci_dev_lock_bh(hdev);
|
|
|
+ hci_dev_lock(hdev);
|
|
|
|
|
|
cmd = mgmt_pending_add(sk, MGMT_OP_STOP_DISCOVERY, hdev, NULL, 0);
|
|
|
if (!cmd) {
|
|
@@ -1929,7 +1929,7 @@ static int stop_discovery(struct sock *sk, u16 index)
|
|
|
mgmt_pending_remove(cmd);
|
|
|
|
|
|
failed:
|
|
|
- hci_dev_unlock_bh(hdev);
|
|
|
+ hci_dev_unlock(hdev);
|
|
|
hci_dev_put(hdev);
|
|
|
|
|
|
return err;
|
|
@@ -1953,7 +1953,7 @@ static int block_device(struct sock *sk, u16 index, unsigned char *data,
|
|
|
return cmd_status(sk, index, MGMT_OP_BLOCK_DEVICE,
|
|
|
MGMT_STATUS_INVALID_PARAMS);
|
|
|
|
|
|
- hci_dev_lock_bh(hdev);
|
|
|
+ hci_dev_lock(hdev);
|
|
|
|
|
|
err = hci_blacklist_add(hdev, &cp->bdaddr);
|
|
|
if (err < 0)
|
|
@@ -1963,7 +1963,7 @@ static int block_device(struct sock *sk, u16 index, unsigned char *data,
|
|
|
err = cmd_complete(sk, index, MGMT_OP_BLOCK_DEVICE,
|
|
|
NULL, 0);
|
|
|
|
|
|
- hci_dev_unlock_bh(hdev);
|
|
|
+ hci_dev_unlock(hdev);
|
|
|
hci_dev_put(hdev);
|
|
|
|
|
|
return err;
|
|
@@ -1987,7 +1987,7 @@ static int unblock_device(struct sock *sk, u16 index, unsigned char *data,
|
|
|
return cmd_status(sk, index, MGMT_OP_UNBLOCK_DEVICE,
|
|
|
MGMT_STATUS_INVALID_PARAMS);
|
|
|
|
|
|
- hci_dev_lock_bh(hdev);
|
|
|
+ hci_dev_lock(hdev);
|
|
|
|
|
|
err = hci_blacklist_del(hdev, &cp->bdaddr);
|
|
|
|
|
@@ -1998,7 +1998,7 @@ static int unblock_device(struct sock *sk, u16 index, unsigned char *data,
|
|
|
err = cmd_complete(sk, index, MGMT_OP_UNBLOCK_DEVICE,
|
|
|
NULL, 0);
|
|
|
|
|
|
- hci_dev_unlock_bh(hdev);
|
|
|
+ hci_dev_unlock(hdev);
|
|
|
hci_dev_put(hdev);
|
|
|
|
|
|
return err;
|