diff options
author | Ivo van Doorn <ivdoorn@gmail.com> | 2007-11-12 09:02:40 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2008-01-28 18:04:40 -0500 |
commit | 3957ccb56e17ca839265ccb292c4c6850dcf5d32 (patch) | |
tree | bf579438b2f8e0d81160059e16eae97aa1254b77 /drivers/net/wireless/rt2x00/rt2500pci.c | |
parent | 797a54c68e0eb551c60e3dc843627f967919a951 (diff) |
rt2x00: Move duplicate code into rt2x00pci_txdone()
rt2400pci, rt2500pci and rt61 require different
txdone handling, but the code that pushes the frame
upstream and cleans up the entry is identical to
all of them.
This will create the function rt2x00pci_txdone()
to remove the duplicate code.
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/rt2500pci.c')
-rw-r--r-- | drivers/net/wireless/rt2x00/rt2500pci.c | 20 |
1 files changed, 1 insertions, 19 deletions
diff --git a/drivers/net/wireless/rt2x00/rt2500pci.c b/drivers/net/wireless/rt2x00/rt2500pci.c index e6a0c37d9195..b6bb9644e25f 100644 --- a/drivers/net/wireless/rt2x00/rt2500pci.c +++ b/drivers/net/wireless/rt2x00/rt2500pci.c | |||
@@ -1298,26 +1298,8 @@ static void rt2500pci_txdone(struct rt2x00_dev *rt2x00dev, const int queue) | |||
1298 | tx_status = rt2x00_get_field32(word, TXD_W0_RESULT); | 1298 | tx_status = rt2x00_get_field32(word, TXD_W0_RESULT); |
1299 | retry = rt2x00_get_field32(word, TXD_W0_RETRY_COUNT); | 1299 | retry = rt2x00_get_field32(word, TXD_W0_RETRY_COUNT); |
1300 | 1300 | ||
1301 | rt2x00lib_txdone(entry, tx_status, retry); | 1301 | rt2x00pci_txdone(rt2x00dev, entry, tx_status, retry); |
1302 | |||
1303 | /* | ||
1304 | * Make this entry available for reuse. | ||
1305 | */ | ||
1306 | entry->flags = 0; | ||
1307 | rt2x00_set_field32(&word, TXD_W0_VALID, 0); | ||
1308 | rt2x00_desc_write(txd, 0, word); | ||
1309 | rt2x00_ring_index_done_inc(ring); | ||
1310 | } | 1302 | } |
1311 | |||
1312 | /* | ||
1313 | * If the data ring was full before the txdone handler | ||
1314 | * we must make sure the packet queue in the mac80211 stack | ||
1315 | * is reenabled when the txdone handler has finished. | ||
1316 | */ | ||
1317 | entry = ring->entry; | ||
1318 | if (!rt2x00_ring_full(ring)) | ||
1319 | ieee80211_wake_queue(rt2x00dev->hw, | ||
1320 | entry->tx_status.control.queue); | ||
1321 | } | 1303 | } |
1322 | 1304 | ||
1323 | static irqreturn_t rt2500pci_interrupt(int irq, void *dev_instance) | 1305 | static irqreturn_t rt2500pci_interrupt(int irq, void *dev_instance) |