Bluetooth: Simplify check if L2CAP connection is AMP capable
authorMarcel Holtmann <marcel@holtmann.org>
Sat, 5 Oct 2013 18:47:49 +0000 (11:47 -0700)
committerJohan Hedberg <johan.hedberg@intel.com>
Sun, 6 Oct 2013 08:26:31 +0000 (10:26 +0200)
The check if a L2CAP connection is AMP capable was a little bit
complicated. This changes the code to make it simpler and more
readable.

Signed-off-by: Marcel Holtmann <marcel@holtmann.org>
Signed-off-by: Johan Hedberg <johan.hedberg@intel.com>
net/bluetooth/l2cap_core.c

index 2efdb17d87a3abfa279e4be7b965938fde418cff..a9a7df6639a7d8fc62ca97935831416077d95f10 100644 (file)
@@ -1012,30 +1012,30 @@ static inline int __l2cap_no_conn_pending(struct l2cap_chan *chan)
        return !test_bit(CONF_CONNECT_PEND, &chan->conf_state);
 }
 
-/* returns true if at least one AMP active */
-static inline bool hci_amp_capable(void)
+static bool __amp_capable(struct l2cap_chan *chan)
 {
+       struct l2cap_conn *conn = chan->conn;
        struct hci_dev *hdev;
-       bool ret = false;
+       bool amp_available = false;
+
+       if (!conn->hs_enabled)
+               return false;
+
+       if (!(conn->fixed_chan_mask & L2CAP_FC_A2MP))
+               return false;
 
        read_lock(&hci_dev_list_lock);
-       list_for_each_entry(hdev, &hci_dev_list, list)
+       list_for_each_entry(hdev, &hci_dev_list, list) {
                if (hdev->amp_type != AMP_TYPE_BREDR &&
-                   test_bit(HCI_UP, &hdev->flags))
-                       ret = true;
+                   test_bit(HCI_UP, &hdev->flags)) {
+                       amp_available = true;
+                       break;
+               }
+       }
        read_unlock(&hci_dev_list_lock);
 
-       return ret;
-}
-
-static bool __amp_capable(struct l2cap_chan *chan)
-{
-       struct l2cap_conn *conn = chan->conn;
-
-       if (conn->hs_enabled && hci_amp_capable() &&
-           chan->chan_policy == BT_CHANNEL_POLICY_AMP_PREFERRED &&
-           conn->fixed_chan_mask & L2CAP_FC_A2MP)
-               return true;
+       if (chan->chan_policy == BT_CHANNEL_POLICY_AMP_PREFERRED)
+               return amp_available;
 
        return false;
 }