diff options
author | Andrei Emeltchenko <andrei.emeltchenko@nokia.com> | 2011-01-03 04:14:36 -0500 |
---|---|---|
committer | Gustavo F. Padovan <padovan@profusion.mobi> | 2011-02-07 22:40:04 -0500 |
commit | e702112ff68a554bcac16bb03ddc2b8e5425bcbf (patch) | |
tree | 872f93640d646326167d41b7797d5a7eea75b751 /net/bluetooth/hci_core.c | |
parent | b2c60d42db0fea1e6c4345739601024863566a13 (diff) |
Bluetooth: Use non-flushable by default L2CAP data packets
Modification of Nick Pelly <npelly@google.com> patch.
With Bluetooth 2.1 ACL packets can be flushable or non-flushable. This commit
makes ACL data packets non-flushable by default on compatible chipsets, and
adds the BT_FLUSHABLE socket option to explicitly request flushable ACL
data packets for a given L2CAP socket. This is useful for A2DP data which can
be safely discarded if it can not be delivered within a short time (while
other ACL data should not be discarded).
Note that making ACL data flushable has no effect unless the automatic flush
timeout for that ACL link is changed from its default of 0 (infinite).
Default packet types (for compatible chipsets):
Frame 34: 13 bytes on wire (104 bits), 13 bytes captured (104 bits)
Bluetooth HCI H4
Bluetooth HCI ACL Packet
.... 0000 0000 0010 = Connection Handle: 0x0002
..00 .... .... .... = PB Flag: First Non-automatically Flushable Packet (0)
00.. .... .... .... = BC Flag: Point-To-Point (0)
Data Total Length: 8
Bluetooth L2CAP Packet
After setting BT_FLUSHABLE
(sock.setsockopt(274 /*SOL_BLUETOOTH*/, 8 /* BT_FLUSHABLE */, 1 /* flush */))
Frame 34: 13 bytes on wire (104 bits), 13 bytes captured (104 bits)
Bluetooth HCI H4
Bluetooth HCI ACL Packet
.... 0000 0000 0010 = Connection Handle: 0x0002
..10 .... .... .... = PB Flag: First Automatically Flushable Packet (2)
00.. .... .... .... = BC Flag: Point-To-Point (0)
Data Total Length: 8
Bluetooth L2CAP Packet
Signed-off-by: Andrei Emeltchenko <andrei.emeltchenko@nokia.com>
Signed-off-by: Gustavo F. Padovan <padovan@profusion.mobi>
Diffstat (limited to 'net/bluetooth/hci_core.c')
-rw-r--r-- | net/bluetooth/hci_core.c | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/net/bluetooth/hci_core.c b/net/bluetooth/hci_core.c index 9c4541bc488..9ba92adaa9a 100644 --- a/net/bluetooth/hci_core.c +++ b/net/bluetooth/hci_core.c | |||
@@ -1395,7 +1395,7 @@ void hci_send_acl(struct hci_conn *conn, struct sk_buff *skb, __u16 flags) | |||
1395 | 1395 | ||
1396 | skb->dev = (void *) hdev; | 1396 | skb->dev = (void *) hdev; |
1397 | bt_cb(skb)->pkt_type = HCI_ACLDATA_PKT; | 1397 | bt_cb(skb)->pkt_type = HCI_ACLDATA_PKT; |
1398 | hci_add_acl_hdr(skb, conn->handle, flags | ACL_START); | 1398 | hci_add_acl_hdr(skb, conn->handle, flags); |
1399 | 1399 | ||
1400 | list = skb_shinfo(skb)->frag_list; | 1400 | list = skb_shinfo(skb)->frag_list; |
1401 | if (!list) { | 1401 | if (!list) { |
@@ -1413,12 +1413,15 @@ void hci_send_acl(struct hci_conn *conn, struct sk_buff *skb, __u16 flags) | |||
1413 | spin_lock_bh(&conn->data_q.lock); | 1413 | spin_lock_bh(&conn->data_q.lock); |
1414 | 1414 | ||
1415 | __skb_queue_tail(&conn->data_q, skb); | 1415 | __skb_queue_tail(&conn->data_q, skb); |
1416 | |||
1417 | flags &= ~ACL_START; | ||
1418 | flags |= ACL_CONT; | ||
1416 | do { | 1419 | do { |
1417 | skb = list; list = list->next; | 1420 | skb = list; list = list->next; |
1418 | 1421 | ||
1419 | skb->dev = (void *) hdev; | 1422 | skb->dev = (void *) hdev; |
1420 | bt_cb(skb)->pkt_type = HCI_ACLDATA_PKT; | 1423 | bt_cb(skb)->pkt_type = HCI_ACLDATA_PKT; |
1421 | hci_add_acl_hdr(skb, conn->handle, flags | ACL_CONT); | 1424 | hci_add_acl_hdr(skb, conn->handle, flags); |
1422 | 1425 | ||
1423 | BT_DBG("%s frag %p len %d", hdev->name, skb, skb->len); | 1426 | BT_DBG("%s frag %p len %d", hdev->name, skb, skb->len); |
1424 | 1427 | ||