Bluetooth: Add ACL MTU, available buffers and total buffers to hci_conn_info.
authorNick Pelly <npelly@google.com>
Wed, 9 Dec 2009 08:15:41 +0000 (00:15 -0800)
committerColin Cross <ccross@android.com>
Thu, 30 Sep 2010 00:49:23 +0000 (17:49 -0700)
This provides userspace debugging tools access to ACL flow control state.

Signed-off-by: Nick Pelly <npelly@google.com>
include/net/bluetooth/hci.h
net/bluetooth/hci_conn.c

index bcbdd6d4e6dd43f1dfb4196a5eb3998309cf5909..84ae84074973e8ea30724271f8404b52f4a94f80 100644 (file)
@@ -998,6 +998,9 @@ struct hci_conn_info {
        __u8     out;
        __u16    state;
        __u32    link_mode;
+       __u32    mtu;
+       __u32    cnt;
+       __u32    pkts;
 };
 
 struct hci_dev_req {
index 0b1e460fe440cfb07a86c0a15e87b7e98c03ba0f..9f4ebc187dccbec63ed855134e98d40a8f93e31c 100644 (file)
@@ -668,6 +668,15 @@ int hci_get_conn_list(void __user *arg)
                (ci + n)->out   = c->out;
                (ci + n)->state = c->state;
                (ci + n)->link_mode = c->link_mode;
+               if (c->type == SCO_LINK) {
+                       (ci + n)->mtu = hdev->sco_mtu;
+                       (ci + n)->cnt = hdev->sco_cnt;
+                       (ci + n)->pkts = hdev->sco_pkts;
+               } else {
+                       (ci + n)->mtu = hdev->acl_mtu;
+                       (ci + n)->cnt = hdev->acl_cnt;
+                       (ci + n)->pkts = hdev->acl_pkts;
+               }
                if (++n >= req.conn_num)
                        break;
        }
@@ -704,6 +713,15 @@ int hci_get_conn_info(struct hci_dev *hdev, void __user *arg)
                ci.out   = conn->out;
                ci.state = conn->state;
                ci.link_mode = conn->link_mode;
+               if (req.type == SCO_LINK) {
+                       ci.mtu = hdev->sco_mtu;
+                       ci.cnt = hdev->sco_cnt;
+                       ci.pkts = hdev->sco_pkts;
+               } else {
+                       ci.mtu = hdev->acl_mtu;
+                       ci.cnt = hdev->acl_cnt;
+                       ci.pkts = hdev->acl_pkts;
+               }
        }
        hci_dev_unlock_bh(hdev);