summaryrefslogtreecommitdiff
path: root/include/net/bluetooth
diff options
context:
space:
mode:
authorMat Martineau <mathewm@codeaurora.org>2012-07-10 05:47:07 -0700
committerGustavo Padovan <gustavo.padovan@collabora.co.uk>2012-07-15 12:18:29 -0300
commitc20f8e35ca8b0583323d310ec63a0f0d17cfdcf5 (patch)
treece775fec3821cc1cf9548b51ef10c980fe33c7e5 /include/net/bluetooth
parenta0dfe0ab6bf194805ce9d6a2dc81efab7a4a7fda (diff)
downloadlinux-3.10-c20f8e35ca8b0583323d310ec63a0f0d17cfdcf5.tar.gz
linux-3.10-c20f8e35ca8b0583323d310ec63a0f0d17cfdcf5.tar.bz2
linux-3.10-c20f8e35ca8b0583323d310ec63a0f0d17cfdcf5.zip
Bluetooth: Use tx window from config response for ack timing
This change addresses an L2CAP ERTM throughput problem when a remote device does not fully utilize the available transmit window. The L2CAP ERTM transmit window size determines the maximum number of unacked frames that may be outstanding at any time. It is configured separately for each direction of an ERTM connection. Each side sends a configuration request with a tx_win field indicating how many unacked frames it is capable of receiving before sending an ack. The configuration response's tx_win field shows how many frames the transmitter will actually send before waiting for an ack. It's important to trace both the actual transmit window (to check for validity of incoming frames) and the number of frames that the transmitter will send before waiting (to send acks at the appropriate time). Now there are separate tx_win and ack_win values. ack_win is updated based on configuration responses, and is used to determine when acks are sent. Signed-off-by: Mat Martineau <mathewm@codeaurora.org> Signed-off-by: Gustavo Padovan <gustavo.padovan@collabora.co.uk>
Diffstat (limited to 'include/net/bluetooth')
-rw-r--r--include/net/bluetooth/l2cap.h1
1 files changed, 1 insertions, 0 deletions
diff --git a/include/net/bluetooth/l2cap.h b/include/net/bluetooth/l2cap.h
index e5164ff55f2..a7679f8913d 100644
--- a/include/net/bluetooth/l2cap.h
+++ b/include/net/bluetooth/l2cap.h
@@ -464,6 +464,7 @@ struct l2cap_chan {
__u16 tx_win;
__u16 tx_win_max;
+ __u16 ack_win;
__u8 max_tx;
__u16 retrans_timeout;
__u16 monitor_timeout;