Commit 014f7bc7 authored by Marcel Holtmann's avatar Marcel Holtmann Committed by Johan Hedberg

Bluetooth: Use hci_conn_num() instead of direct connection hash access

When changing the alternate setting for the ISOC endpoints, use the
hci_conn_num() helper function to count currently established SCO
and eSCO connections and store the the value. This avoids direct
access to the connection hash.

In addition use the stored value instead accessing the connection
hash over and over again.
Signed-off-by: default avatarMarcel Holtmann <marcel@holtmann.org>
Signed-off-by: default avatarJohan Hedberg <johan.hedberg@intel.com>
parent b145edcd
...@@ -774,7 +774,7 @@ static int btusb_send_frame(struct sk_buff *skb) ...@@ -774,7 +774,7 @@ static int btusb_send_frame(struct sk_buff *skb)
break; break;
case HCI_SCODATA_PKT: case HCI_SCODATA_PKT:
if (!data->isoc_tx_ep || hdev->conn_hash.sco_num < 1) if (!data->isoc_tx_ep || hci_conn_num(hdev, SCO_LINK) < 1)
return -ENODEV; return -ENODEV;
urb = usb_alloc_urb(BTUSB_MAX_ISOC_FRAMES, GFP_ATOMIC); urb = usb_alloc_urb(BTUSB_MAX_ISOC_FRAMES, GFP_ATOMIC);
...@@ -833,8 +833,8 @@ static void btusb_notify(struct hci_dev *hdev, unsigned int evt) ...@@ -833,8 +833,8 @@ static void btusb_notify(struct hci_dev *hdev, unsigned int evt)
BT_DBG("%s evt %d", hdev->name, evt); BT_DBG("%s evt %d", hdev->name, evt);
if (hdev->conn_hash.sco_num != data->sco_num) { if (hci_conn_num(hdev, SCO_LINK) != data->sco_num) {
data->sco_num = hdev->conn_hash.sco_num; data->sco_num = hci_conn_num(hdev, SCO_LINK);
schedule_work(&data->work); schedule_work(&data->work);
} }
} }
...@@ -889,7 +889,7 @@ static void btusb_work(struct work_struct *work) ...@@ -889,7 +889,7 @@ static void btusb_work(struct work_struct *work)
int new_alts; int new_alts;
int err; int err;
if (hdev->conn_hash.sco_num > 0) { if (data->sco_num > 0) {
if (!test_bit(BTUSB_DID_ISO_RESUME, &data->flags)) { if (!test_bit(BTUSB_DID_ISO_RESUME, &data->flags)) {
err = usb_autopm_get_interface(data->isoc ? data->isoc : data->intf); err = usb_autopm_get_interface(data->isoc ? data->isoc : data->intf);
if (err < 0) { if (err < 0) {
...@@ -903,9 +903,9 @@ static void btusb_work(struct work_struct *work) ...@@ -903,9 +903,9 @@ static void btusb_work(struct work_struct *work)
if (hdev->voice_setting & 0x0020) { if (hdev->voice_setting & 0x0020) {
static const int alts[3] = { 2, 4, 5 }; static const int alts[3] = { 2, 4, 5 };
new_alts = alts[hdev->conn_hash.sco_num - 1]; new_alts = alts[data->sco_num - 1];
} else { } else {
new_alts = hdev->conn_hash.sco_num; new_alts = data->sco_num;
} }
if (data->isoc_altsetting != new_alts) { if (data->isoc_altsetting != new_alts) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment