diff options
author | Felix Fietkau <nbd@openwrt.org> | 2011-03-23 15:57:28 -0400 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2011-03-30 14:15:20 -0400 |
commit | f4c607dc53ece4ac15afed163292425efa060775 (patch) | |
tree | b470ccace15677ea0e86c8b530eb2e9945240548 /drivers/net/wireless/ath/ath9k | |
parent | a9b6b2569cf107fe541381e82faa0a3c47a9a7fd (diff) |
ath9k_hw: remove pCap->total_queues
The EEPROM contains a field that can restrict the number of hardware queues,
however this is not only useless (all the known chips contain the same
number of hardware queues), but also potentially dangerous in case of a
misprogrammed EEPROM (could trigger driver crashes), so let's just ignore
it completely.
Signed-off-by: Felix Fietkau <nbd@openwrt.org>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless/ath/ath9k')
-rw-r--r-- | drivers/net/wireless/ath/ath9k/hw.c | 8 | ||||
-rw-r--r-- | drivers/net/wireless/ath/ath9k/hw.h | 1 | ||||
-rw-r--r-- | drivers/net/wireless/ath/ath9k/mac.c | 38 |
3 files changed, 6 insertions, 41 deletions
diff --git a/drivers/net/wireless/ath/ath9k/hw.c b/drivers/net/wireless/ath/ath9k/hw.c index bb9a3f3c1b71..de0d218195da 100644 --- a/drivers/net/wireless/ath/ath9k/hw.c +++ b/drivers/net/wireless/ath/ath9k/hw.c | |||
@@ -1437,7 +1437,7 @@ int ath9k_hw_reset(struct ath_hw *ah, struct ath9k_channel *chan, | |||
1437 | REGWRITE_BUFFER_FLUSH(ah); | 1437 | REGWRITE_BUFFER_FLUSH(ah); |
1438 | 1438 | ||
1439 | ah->intr_txqs = 0; | 1439 | ah->intr_txqs = 0; |
1440 | for (i = 0; i < ah->caps.total_queues; i++) | 1440 | for (i = 0; i < ATH9K_NUM_TX_QUEUES; i++) |
1441 | ath9k_hw_resettxqueue(ah, i); | 1441 | ath9k_hw_resettxqueue(ah, i); |
1442 | 1442 | ||
1443 | ath9k_hw_init_interrupt_masks(ah, ah->opmode); | 1443 | ath9k_hw_init_interrupt_masks(ah, ah->opmode); |
@@ -1885,12 +1885,6 @@ int ath9k_hw_fill_cap_info(struct ath_hw *ah) | |||
1885 | else | 1885 | else |
1886 | pCap->hw_caps &= ~ATH9K_HW_CAP_HT; | 1886 | pCap->hw_caps &= ~ATH9K_HW_CAP_HT; |
1887 | 1887 | ||
1888 | if (capField & AR_EEPROM_EEPCAP_MAXQCU) | ||
1889 | pCap->total_queues = | ||
1890 | MS(capField, AR_EEPROM_EEPCAP_MAXQCU); | ||
1891 | else | ||
1892 | pCap->total_queues = ATH9K_NUM_TX_QUEUES; | ||
1893 | |||
1894 | if (capField & AR_EEPROM_EEPCAP_KC_ENTRIES) | 1888 | if (capField & AR_EEPROM_EEPCAP_KC_ENTRIES) |
1895 | pCap->keycache_size = | 1889 | pCap->keycache_size = |
1896 | 1 << MS(capField, AR_EEPROM_EEPCAP_KC_ENTRIES); | 1890 | 1 << MS(capField, AR_EEPROM_EEPCAP_KC_ENTRIES); |
diff --git a/drivers/net/wireless/ath/ath9k/hw.h b/drivers/net/wireless/ath/ath9k/hw.h index dafbe97a969c..4e62ad858d8a 100644 --- a/drivers/net/wireless/ath/ath9k/hw.h +++ b/drivers/net/wireless/ath/ath9k/hw.h | |||
@@ -191,7 +191,6 @@ enum ath9k_hw_caps { | |||
191 | 191 | ||
192 | struct ath9k_hw_capabilities { | 192 | struct ath9k_hw_capabilities { |
193 | u32 hw_caps; /* ATH9K_HW_CAP_* from ath9k_hw_caps */ | 193 | u32 hw_caps; /* ATH9K_HW_CAP_* from ath9k_hw_caps */ |
194 | u16 total_queues; | ||
195 | u16 keycache_size; | 194 | u16 keycache_size; |
196 | u16 low_5ghz_chan, high_5ghz_chan; | 195 | u16 low_5ghz_chan, high_5ghz_chan; |
197 | u16 low_2ghz_chan, high_2ghz_chan; | 196 | u16 low_2ghz_chan, high_2ghz_chan; |
diff --git a/drivers/net/wireless/ath/ath9k/mac.c b/drivers/net/wireless/ath/ath9k/mac.c index db496f2e1f6b..05efcfbeeadc 100644 --- a/drivers/net/wireless/ath/ath9k/mac.c +++ b/drivers/net/wireless/ath/ath9k/mac.c | |||
@@ -209,15 +209,8 @@ bool ath9k_hw_set_txq_props(struct ath_hw *ah, int q, | |||
209 | { | 209 | { |
210 | u32 cw; | 210 | u32 cw; |
211 | struct ath_common *common = ath9k_hw_common(ah); | 211 | struct ath_common *common = ath9k_hw_common(ah); |
212 | struct ath9k_hw_capabilities *pCap = &ah->caps; | ||
213 | struct ath9k_tx_queue_info *qi; | 212 | struct ath9k_tx_queue_info *qi; |
214 | 213 | ||
215 | if (q >= pCap->total_queues) { | ||
216 | ath_dbg(common, ATH_DBG_QUEUE, | ||
217 | "Set TXQ properties, invalid queue: %u\n", q); | ||
218 | return false; | ||
219 | } | ||
220 | |||
221 | qi = &ah->txq[q]; | 214 | qi = &ah->txq[q]; |
222 | if (qi->tqi_type == ATH9K_TX_QUEUE_INACTIVE) { | 215 | if (qi->tqi_type == ATH9K_TX_QUEUE_INACTIVE) { |
223 | ath_dbg(common, ATH_DBG_QUEUE, | 216 | ath_dbg(common, ATH_DBG_QUEUE, |
@@ -280,15 +273,8 @@ bool ath9k_hw_get_txq_props(struct ath_hw *ah, int q, | |||
280 | struct ath9k_tx_queue_info *qinfo) | 273 | struct ath9k_tx_queue_info *qinfo) |
281 | { | 274 | { |
282 | struct ath_common *common = ath9k_hw_common(ah); | 275 | struct ath_common *common = ath9k_hw_common(ah); |
283 | struct ath9k_hw_capabilities *pCap = &ah->caps; | ||
284 | struct ath9k_tx_queue_info *qi; | 276 | struct ath9k_tx_queue_info *qi; |
285 | 277 | ||
286 | if (q >= pCap->total_queues) { | ||
287 | ath_dbg(common, ATH_DBG_QUEUE, | ||
288 | "Get TXQ properties, invalid queue: %u\n", q); | ||
289 | return false; | ||
290 | } | ||
291 | |||
292 | qi = &ah->txq[q]; | 278 | qi = &ah->txq[q]; |
293 | if (qi->tqi_type == ATH9K_TX_QUEUE_INACTIVE) { | 279 | if (qi->tqi_type == ATH9K_TX_QUEUE_INACTIVE) { |
294 | ath_dbg(common, ATH_DBG_QUEUE, | 280 | ath_dbg(common, ATH_DBG_QUEUE, |
@@ -320,28 +306,27 @@ int ath9k_hw_setuptxqueue(struct ath_hw *ah, enum ath9k_tx_queue type, | |||
320 | { | 306 | { |
321 | struct ath_common *common = ath9k_hw_common(ah); | 307 | struct ath_common *common = ath9k_hw_common(ah); |
322 | struct ath9k_tx_queue_info *qi; | 308 | struct ath9k_tx_queue_info *qi; |
323 | struct ath9k_hw_capabilities *pCap = &ah->caps; | ||
324 | int q; | 309 | int q; |
325 | 310 | ||
326 | switch (type) { | 311 | switch (type) { |
327 | case ATH9K_TX_QUEUE_BEACON: | 312 | case ATH9K_TX_QUEUE_BEACON: |
328 | q = pCap->total_queues - 1; | 313 | q = ATH9K_NUM_TX_QUEUES - 1; |
329 | break; | 314 | break; |
330 | case ATH9K_TX_QUEUE_CAB: | 315 | case ATH9K_TX_QUEUE_CAB: |
331 | q = pCap->total_queues - 2; | 316 | q = ATH9K_NUM_TX_QUEUES - 2; |
332 | break; | 317 | break; |
333 | case ATH9K_TX_QUEUE_PSPOLL: | 318 | case ATH9K_TX_QUEUE_PSPOLL: |
334 | q = 1; | 319 | q = 1; |
335 | break; | 320 | break; |
336 | case ATH9K_TX_QUEUE_UAPSD: | 321 | case ATH9K_TX_QUEUE_UAPSD: |
337 | q = pCap->total_queues - 3; | 322 | q = ATH9K_NUM_TX_QUEUES - 3; |
338 | break; | 323 | break; |
339 | case ATH9K_TX_QUEUE_DATA: | 324 | case ATH9K_TX_QUEUE_DATA: |
340 | for (q = 0; q < pCap->total_queues; q++) | 325 | for (q = 0; q < ATH9K_NUM_TX_QUEUES; q++) |
341 | if (ah->txq[q].tqi_type == | 326 | if (ah->txq[q].tqi_type == |
342 | ATH9K_TX_QUEUE_INACTIVE) | 327 | ATH9K_TX_QUEUE_INACTIVE) |
343 | break; | 328 | break; |
344 | if (q == pCap->total_queues) { | 329 | if (q == ATH9K_NUM_TX_QUEUES) { |
345 | ath_err(common, "No available TX queue\n"); | 330 | ath_err(common, "No available TX queue\n"); |
346 | return -1; | 331 | return -1; |
347 | } | 332 | } |
@@ -382,15 +367,9 @@ EXPORT_SYMBOL(ath9k_hw_setuptxqueue); | |||
382 | 367 | ||
383 | bool ath9k_hw_releasetxqueue(struct ath_hw *ah, u32 q) | 368 | bool ath9k_hw_releasetxqueue(struct ath_hw *ah, u32 q) |
384 | { | 369 | { |
385 | struct ath9k_hw_capabilities *pCap = &ah->caps; | ||
386 | struct ath_common *common = ath9k_hw_common(ah); | 370 | struct ath_common *common = ath9k_hw_common(ah); |
387 | struct ath9k_tx_queue_info *qi; | 371 | struct ath9k_tx_queue_info *qi; |
388 | 372 | ||
389 | if (q >= pCap->total_queues) { | ||
390 | ath_dbg(common, ATH_DBG_QUEUE, | ||
391 | "Release TXQ, invalid queue: %u\n", q); | ||
392 | return false; | ||
393 | } | ||
394 | qi = &ah->txq[q]; | 373 | qi = &ah->txq[q]; |
395 | if (qi->tqi_type == ATH9K_TX_QUEUE_INACTIVE) { | 374 | if (qi->tqi_type == ATH9K_TX_QUEUE_INACTIVE) { |
396 | ath_dbg(common, ATH_DBG_QUEUE, | 375 | ath_dbg(common, ATH_DBG_QUEUE, |
@@ -414,18 +393,11 @@ EXPORT_SYMBOL(ath9k_hw_releasetxqueue); | |||
414 | 393 | ||
415 | bool ath9k_hw_resettxqueue(struct ath_hw *ah, u32 q) | 394 | bool ath9k_hw_resettxqueue(struct ath_hw *ah, u32 q) |
416 | { | 395 | { |
417 | struct ath9k_hw_capabilities *pCap = &ah->caps; | ||
418 | struct ath_common *common = ath9k_hw_common(ah); | 396 | struct ath_common *common = ath9k_hw_common(ah); |
419 | struct ath9k_channel *chan = ah->curchan; | 397 | struct ath9k_channel *chan = ah->curchan; |
420 | struct ath9k_tx_queue_info *qi; | 398 | struct ath9k_tx_queue_info *qi; |
421 | u32 cwMin, chanCwMin, value; | 399 | u32 cwMin, chanCwMin, value; |
422 | 400 | ||
423 | if (q >= pCap->total_queues) { | ||
424 | ath_dbg(common, ATH_DBG_QUEUE, | ||
425 | "Reset TXQ, invalid queue: %u\n", q); | ||
426 | return false; | ||
427 | } | ||
428 | |||
429 | qi = &ah->txq[q]; | 401 | qi = &ah->txq[q]; |
430 | if (qi->tqi_type == ATH9K_TX_QUEUE_INACTIVE) { | 402 | if (qi->tqi_type == ATH9K_TX_QUEUE_INACTIVE) { |
431 | ath_dbg(common, ATH_DBG_QUEUE, | 403 | ath_dbg(common, ATH_DBG_QUEUE, |