diff options
Diffstat (limited to 'drivers/net/wireless/ath/ath9k/init.c')
-rw-r--r-- | drivers/net/wireless/ath/ath9k/init.c | 26 |
1 files changed, 16 insertions, 10 deletions
diff --git a/drivers/net/wireless/ath/ath9k/init.c b/drivers/net/wireless/ath/ath9k/init.c index 1956c611503e..58a87f7931df 100644 --- a/drivers/net/wireless/ath/ath9k/init.c +++ b/drivers/net/wireless/ath/ath9k/init.c | |||
@@ -233,31 +233,37 @@ static int ath9k_reg_notifier(struct wiphy *wiphy, | |||
233 | */ | 233 | */ |
234 | int ath_descdma_setup(struct ath_softc *sc, struct ath_descdma *dd, | 234 | int ath_descdma_setup(struct ath_softc *sc, struct ath_descdma *dd, |
235 | struct list_head *head, const char *name, | 235 | struct list_head *head, const char *name, |
236 | int nbuf, int ndesc) | 236 | int nbuf, int ndesc, bool is_tx) |
237 | { | 237 | { |
238 | #define DS2PHYS(_dd, _ds) \ | 238 | #define DS2PHYS(_dd, _ds) \ |
239 | ((_dd)->dd_desc_paddr + ((caddr_t)(_ds) - (caddr_t)(_dd)->dd_desc)) | 239 | ((_dd)->dd_desc_paddr + ((caddr_t)(_ds) - (caddr_t)(_dd)->dd_desc)) |
240 | #define ATH_DESC_4KB_BOUND_CHECK(_daddr) ((((_daddr) & 0xFFF) > 0xF7F) ? 1 : 0) | 240 | #define ATH_DESC_4KB_BOUND_CHECK(_daddr) ((((_daddr) & 0xFFF) > 0xF7F) ? 1 : 0) |
241 | #define ATH_DESC_4KB_BOUND_NUM_SKIPPED(_len) ((_len) / 4096) | 241 | #define ATH_DESC_4KB_BOUND_NUM_SKIPPED(_len) ((_len) / 4096) |
242 | struct ath_common *common = ath9k_hw_common(sc->sc_ah); | 242 | struct ath_common *common = ath9k_hw_common(sc->sc_ah); |
243 | struct ath_desc *ds; | 243 | u8 *ds; |
244 | struct ath_buf *bf; | 244 | struct ath_buf *bf; |
245 | int i, bsize, error; | 245 | int i, bsize, error, desc_len; |
246 | 246 | ||
247 | ath_print(common, ATH_DBG_CONFIG, "%s DMA: %u buffers %u desc/buf\n", | 247 | ath_print(common, ATH_DBG_CONFIG, "%s DMA: %u buffers %u desc/buf\n", |
248 | name, nbuf, ndesc); | 248 | name, nbuf, ndesc); |
249 | 249 | ||
250 | INIT_LIST_HEAD(head); | 250 | INIT_LIST_HEAD(head); |
251 | |||
252 | if (is_tx) | ||
253 | desc_len = sc->sc_ah->caps.tx_desc_len; | ||
254 | else | ||
255 | desc_len = sizeof(struct ath_desc); | ||
256 | |||
251 | /* ath_desc must be a multiple of DWORDs */ | 257 | /* ath_desc must be a multiple of DWORDs */ |
252 | if ((sizeof(struct ath_desc) % 4) != 0) { | 258 | if ((desc_len % 4) != 0) { |
253 | ath_print(common, ATH_DBG_FATAL, | 259 | ath_print(common, ATH_DBG_FATAL, |
254 | "ath_desc not DWORD aligned\n"); | 260 | "ath_desc not DWORD aligned\n"); |
255 | BUG_ON((sizeof(struct ath_desc) % 4) != 0); | 261 | BUG_ON((desc_len % 4) != 0); |
256 | error = -ENOMEM; | 262 | error = -ENOMEM; |
257 | goto fail; | 263 | goto fail; |
258 | } | 264 | } |
259 | 265 | ||
260 | dd->dd_desc_len = sizeof(struct ath_desc) * nbuf * ndesc; | 266 | dd->dd_desc_len = desc_len * nbuf * ndesc; |
261 | 267 | ||
262 | /* | 268 | /* |
263 | * Need additional DMA memory because we can't use | 269 | * Need additional DMA memory because we can't use |
@@ -270,7 +276,7 @@ int ath_descdma_setup(struct ath_softc *sc, struct ath_descdma *dd, | |||
270 | u32 dma_len; | 276 | u32 dma_len; |
271 | 277 | ||
272 | while (ndesc_skipped) { | 278 | while (ndesc_skipped) { |
273 | dma_len = ndesc_skipped * sizeof(struct ath_desc); | 279 | dma_len = ndesc_skipped * desc_len; |
274 | dd->dd_desc_len += dma_len; | 280 | dd->dd_desc_len += dma_len; |
275 | 281 | ||
276 | ndesc_skipped = ATH_DESC_4KB_BOUND_NUM_SKIPPED(dma_len); | 282 | ndesc_skipped = ATH_DESC_4KB_BOUND_NUM_SKIPPED(dma_len); |
@@ -284,7 +290,7 @@ int ath_descdma_setup(struct ath_softc *sc, struct ath_descdma *dd, | |||
284 | error = -ENOMEM; | 290 | error = -ENOMEM; |
285 | goto fail; | 291 | goto fail; |
286 | } | 292 | } |
287 | ds = dd->dd_desc; | 293 | ds = (u8 *) dd->dd_desc; |
288 | ath_print(common, ATH_DBG_CONFIG, "%s DMA map: %p (%u) -> %llx (%u)\n", | 294 | ath_print(common, ATH_DBG_CONFIG, "%s DMA map: %p (%u) -> %llx (%u)\n", |
289 | name, ds, (u32) dd->dd_desc_len, | 295 | name, ds, (u32) dd->dd_desc_len, |
290 | ito64(dd->dd_desc_paddr), /*XXX*/(u32) dd->dd_desc_len); | 296 | ito64(dd->dd_desc_paddr), /*XXX*/(u32) dd->dd_desc_len); |
@@ -298,7 +304,7 @@ int ath_descdma_setup(struct ath_softc *sc, struct ath_descdma *dd, | |||
298 | } | 304 | } |
299 | dd->dd_bufptr = bf; | 305 | dd->dd_bufptr = bf; |
300 | 306 | ||
301 | for (i = 0; i < nbuf; i++, bf++, ds += ndesc) { | 307 | for (i = 0; i < nbuf; i++, bf++, ds += (desc_len * ndesc)) { |
302 | bf->bf_desc = ds; | 308 | bf->bf_desc = ds; |
303 | bf->bf_daddr = DS2PHYS(dd, ds); | 309 | bf->bf_daddr = DS2PHYS(dd, ds); |
304 | 310 | ||
@@ -314,7 +320,7 @@ int ath_descdma_setup(struct ath_softc *sc, struct ath_descdma *dd, | |||
314 | ((caddr_t) dd->dd_desc + | 320 | ((caddr_t) dd->dd_desc + |
315 | dd->dd_desc_len)); | 321 | dd->dd_desc_len)); |
316 | 322 | ||
317 | ds += ndesc; | 323 | ds += (desc_len * ndesc); |
318 | bf->bf_desc = ds; | 324 | bf->bf_desc = ds; |
319 | bf->bf_daddr = DS2PHYS(dd, ds); | 325 | bf->bf_daddr = DS2PHYS(dd, ds); |
320 | } | 326 | } |