diff options
author | Ivo van Doorn <IvDoorn@gmail.com> | 2008-06-06 16:53:14 -0400 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2008-06-14 12:17:56 -0400 |
commit | b869767b6f5049f1d1ede2bb3e48832e0722ca5a (patch) | |
tree | a75e43aad931ffdaea889af7b2275f12a16f077a /drivers/net/wireless/rt2x00/rt2500usb.c | |
parent | 6db3786aee36b32e5ed072ed67fad6d5341b0991 (diff) |
rt2x00: Don't kick TX queue after each frame
TX queues shouldn't be kicked after each frame that is put into the
queue. This could cause problems during RTS and CTS-to-self as well
as with fragmentation. In all those cases you want all frames to be
send out in a single burst. Off course we shouldn't let the queue fill
up entirely, thus we introduce a 10% threshold which, when reached,
will force the frames to be send out regardless of the frame.
In addition we should prevent queues to become full in such a way
that the tx() handler can fail. Instead of stopping the queue when
it is full, we should stop it when it is below the threshold.
Signed-off-by: Ivo van Doorn <IvDoorn@gmail.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless/rt2x00/rt2500usb.c')
-rw-r--r-- | drivers/net/wireless/rt2x00/rt2500usb.c | 1 |
1 files changed, 0 insertions, 1 deletions
diff --git a/drivers/net/wireless/rt2x00/rt2500usb.c b/drivers/net/wireless/rt2x00/rt2500usb.c index 6abb4c5338f5..076221413db7 100644 --- a/drivers/net/wireless/rt2x00/rt2500usb.c +++ b/drivers/net/wireless/rt2x00/rt2500usb.c | |||
@@ -1711,7 +1711,6 @@ static int rt2500usb_beacon_update(struct ieee80211_hw *hw, struct sk_buff *skb) | |||
1711 | */ | 1711 | */ |
1712 | skbdesc = get_skb_frame_desc(skb); | 1712 | skbdesc = get_skb_frame_desc(skb); |
1713 | memset(skbdesc, 0, sizeof(*skbdesc)); | 1713 | memset(skbdesc, 0, sizeof(*skbdesc)); |
1714 | skbdesc->flags |= FRAME_DESC_DRIVER_GENERATED; | ||
1715 | skbdesc->data = skb->data + intf->beacon->queue->desc_size; | 1714 | skbdesc->data = skb->data + intf->beacon->queue->desc_size; |
1716 | skbdesc->data_len = skb->len - intf->beacon->queue->desc_size; | 1715 | skbdesc->data_len = skb->len - intf->beacon->queue->desc_size; |
1717 | skbdesc->desc = skb->data; | 1716 | skbdesc->desc = skb->data; |