diff options
Diffstat (limited to 'drivers/net/wireless/rt2x00/rt2x00queue.c')
-rw-r--r-- | drivers/net/wireless/rt2x00/rt2x00queue.c | 11 |
1 files changed, 5 insertions, 6 deletions
diff --git a/drivers/net/wireless/rt2x00/rt2x00queue.c b/drivers/net/wireless/rt2x00/rt2x00queue.c index 458bb489bc7c..df8817fed09e 100644 --- a/drivers/net/wireless/rt2x00/rt2x00queue.c +++ b/drivers/net/wireless/rt2x00/rt2x00queue.c | |||
@@ -561,7 +561,7 @@ int rt2x00queue_write_tx_frame(struct data_queue *queue, struct sk_buff *skb, | |||
561 | 561 | ||
562 | set_bit(ENTRY_DATA_PENDING, &entry->flags); | 562 | set_bit(ENTRY_DATA_PENDING, &entry->flags); |
563 | 563 | ||
564 | rt2x00queue_index_inc(queue, Q_INDEX); | 564 | rt2x00queue_index_inc(entry, Q_INDEX); |
565 | rt2x00queue_write_tx_descriptor(entry, &txdesc); | 565 | rt2x00queue_write_tx_descriptor(entry, &txdesc); |
566 | rt2x00queue_kick_tx_queue(queue, &txdesc); | 566 | rt2x00queue_kick_tx_queue(queue, &txdesc); |
567 | 567 | ||
@@ -727,8 +727,9 @@ struct queue_entry *rt2x00queue_get_entry(struct data_queue *queue, | |||
727 | } | 727 | } |
728 | EXPORT_SYMBOL_GPL(rt2x00queue_get_entry); | 728 | EXPORT_SYMBOL_GPL(rt2x00queue_get_entry); |
729 | 729 | ||
730 | void rt2x00queue_index_inc(struct data_queue *queue, enum queue_index index) | 730 | void rt2x00queue_index_inc(struct queue_entry *entry, enum queue_index index) |
731 | { | 731 | { |
732 | struct data_queue *queue = entry->queue; | ||
732 | unsigned long irqflags; | 733 | unsigned long irqflags; |
733 | 734 | ||
734 | if (unlikely(index >= Q_INDEX_MAX)) { | 735 | if (unlikely(index >= Q_INDEX_MAX)) { |
@@ -743,7 +744,7 @@ void rt2x00queue_index_inc(struct data_queue *queue, enum queue_index index) | |||
743 | if (queue->index[index] >= queue->limit) | 744 | if (queue->index[index] >= queue->limit) |
744 | queue->index[index] = 0; | 745 | queue->index[index] = 0; |
745 | 746 | ||
746 | queue->last_action[index] = jiffies; | 747 | entry->last_action = jiffies; |
747 | 748 | ||
748 | if (index == Q_INDEX) { | 749 | if (index == Q_INDEX) { |
749 | queue->length++; | 750 | queue->length++; |
@@ -969,10 +970,8 @@ static void rt2x00queue_reset(struct data_queue *queue) | |||
969 | queue->count = 0; | 970 | queue->count = 0; |
970 | queue->length = 0; | 971 | queue->length = 0; |
971 | 972 | ||
972 | for (i = 0; i < Q_INDEX_MAX; i++) { | 973 | for (i = 0; i < Q_INDEX_MAX; i++) |
973 | queue->index[i] = 0; | 974 | queue->index[i] = 0; |
974 | queue->last_action[i] = jiffies; | ||
975 | } | ||
976 | 975 | ||
977 | spin_unlock_irqrestore(&queue->index_lock, irqflags); | 976 | spin_unlock_irqrestore(&queue->index_lock, irqflags); |
978 | } | 977 | } |