diff options
author | Gertjan van Wingerde <gwingerde@gmail.com> | 2010-05-11 17:51:40 -0400 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2010-05-12 16:41:44 -0400 |
commit | 85b7a8b3871bde7885516fed2a1c8da699913318 (patch) | |
tree | 80c488fc082b06c9278e8e30db0033306404e8a1 /drivers/net/wireless/rt2x00/rt2500pci.c | |
parent | e01f1ec35ff91c8a3f4a3e48a0c8ab476124b973 (diff) |
rt2x00: Simplify TXD handling of beacons.
The handling of tx descriptors for beacons can be simplified by updating
write_tx_desc implementations of each driver to write directly to the
queue entry descriptor instead of to a provided memory area.
This is also a preparation for further clean ups where descriptors are
properly reserved in the skb instead of fiddling with the skb data
pointer.
Signed-off-by: Gertjan van Wingerde <gwingerde@gmail.com>
Acked-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 | 21 |
1 files changed, 9 insertions, 12 deletions
diff --git a/drivers/net/wireless/rt2x00/rt2500pci.c b/drivers/net/wireless/rt2x00/rt2500pci.c index 8d3e95e0dcfe..070c23ed4013 100644 --- a/drivers/net/wireless/rt2x00/rt2500pci.c +++ b/drivers/net/wireless/rt2x00/rt2500pci.c | |||
@@ -1164,15 +1164,15 @@ static void rt2500pci_write_tx_desc(struct rt2x00_dev *rt2x00dev, | |||
1164 | { | 1164 | { |
1165 | struct skb_frame_desc *skbdesc = get_skb_frame_desc(skb); | 1165 | struct skb_frame_desc *skbdesc = get_skb_frame_desc(skb); |
1166 | struct queue_entry_priv_pci *entry_priv = skbdesc->entry->priv_data; | 1166 | struct queue_entry_priv_pci *entry_priv = skbdesc->entry->priv_data; |
1167 | __le32 *txd = skbdesc->desc; | 1167 | __le32 *txd = entry_priv->desc; |
1168 | u32 word; | 1168 | u32 word; |
1169 | 1169 | ||
1170 | /* | 1170 | /* |
1171 | * Start writing the descriptor words. | 1171 | * Start writing the descriptor words. |
1172 | */ | 1172 | */ |
1173 | rt2x00_desc_read(entry_priv->desc, 1, &word); | 1173 | rt2x00_desc_read(txd, 1, &word); |
1174 | rt2x00_set_field32(&word, TXD_W1_BUFFER_ADDRESS, skbdesc->skb_dma); | 1174 | rt2x00_set_field32(&word, TXD_W1_BUFFER_ADDRESS, skbdesc->skb_dma); |
1175 | rt2x00_desc_write(entry_priv->desc, 1, word); | 1175 | rt2x00_desc_write(txd, 1, word); |
1176 | 1176 | ||
1177 | rt2x00_desc_read(txd, 2, &word); | 1177 | rt2x00_desc_read(txd, 2, &word); |
1178 | rt2x00_set_field32(&word, TXD_W2_IV_OFFSET, IEEE80211_HEADER); | 1178 | rt2x00_set_field32(&word, TXD_W2_IV_OFFSET, IEEE80211_HEADER); |
@@ -1216,6 +1216,12 @@ static void rt2500pci_write_tx_desc(struct rt2x00_dev *rt2x00dev, | |||
1216 | rt2x00_set_field32(&word, TXD_W0_DATABYTE_COUNT, txdesc->length); | 1216 | rt2x00_set_field32(&word, TXD_W0_DATABYTE_COUNT, txdesc->length); |
1217 | rt2x00_set_field32(&word, TXD_W0_CIPHER_ALG, CIPHER_NONE); | 1217 | rt2x00_set_field32(&word, TXD_W0_CIPHER_ALG, CIPHER_NONE); |
1218 | rt2x00_desc_write(txd, 0, word); | 1218 | rt2x00_desc_write(txd, 0, word); |
1219 | |||
1220 | /* | ||
1221 | * Register descriptor details in skb frame descriptor. | ||
1222 | */ | ||
1223 | skbdesc->desc = txd; | ||
1224 | skbdesc->desc_len = TXD_DESC_SIZE; | ||
1219 | } | 1225 | } |
1220 | 1226 | ||
1221 | /* | 1227 | /* |
@@ -1238,15 +1244,6 @@ static void rt2500pci_write_beacon(struct queue_entry *entry, | |||
1238 | rt2x00_set_field32(®, CSR14_BEACON_GEN, 0); | 1244 | rt2x00_set_field32(®, CSR14_BEACON_GEN, 0); |
1239 | rt2x00pci_register_write(rt2x00dev, CSR14, reg); | 1245 | rt2x00pci_register_write(rt2x00dev, CSR14, reg); |
1240 | 1246 | ||
1241 | /* | ||
1242 | * Replace rt2x00lib allocated descriptor with the | ||
1243 | * pointer to the _real_ hardware descriptor. | ||
1244 | * After that, map the beacon to DMA and update the | ||
1245 | * descriptor. | ||
1246 | */ | ||
1247 | memcpy(entry_priv->desc, skbdesc->desc, skbdesc->desc_len); | ||
1248 | skbdesc->desc = entry_priv->desc; | ||
1249 | |||
1250 | rt2x00queue_map_txskb(rt2x00dev, entry->skb); | 1247 | rt2x00queue_map_txskb(rt2x00dev, entry->skb); |
1251 | 1248 | ||
1252 | rt2x00_desc_read(entry_priv->desc, 1, &word); | 1249 | rt2x00_desc_read(entry_priv->desc, 1, &word); |