diff options
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-3945.h | 3 | ||||
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-helpers.h | 20 | ||||
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl3945-base.c | 45 | ||||
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl4965-base.c | 37 |
4 files changed, 45 insertions, 60 deletions
diff --git a/drivers/net/wireless/iwlwifi/iwl-3945.h b/drivers/net/wireless/iwlwifi/iwl-3945.h index a238e833251f..0ab22d366d93 100644 --- a/drivers/net/wireless/iwlwifi/iwl-3945.h +++ b/drivers/net/wireless/iwlwifi/iwl-3945.h | |||
@@ -116,6 +116,9 @@ struct iwl3945_queue { | |||
116 | * space less than this */ | 116 | * space less than this */ |
117 | } __attribute__ ((packed)); | 117 | } __attribute__ ((packed)); |
118 | 118 | ||
119 | int iwl3945_queue_space(const struct iwl3945_queue *q); | ||
120 | int iwl3945_x2_queue_used(const struct iwl3945_queue *q, int i); | ||
121 | |||
119 | #define MAX_NUM_OF_TBS (20) | 122 | #define MAX_NUM_OF_TBS (20) |
120 | 123 | ||
121 | /* One for each TFD */ | 124 | /* One for each TFD */ |
diff --git a/drivers/net/wireless/iwlwifi/iwl-helpers.h b/drivers/net/wireless/iwlwifi/iwl-helpers.h index 8993cca81b40..736b88881b03 100644 --- a/drivers/net/wireless/iwlwifi/iwl-helpers.h +++ b/drivers/net/wireless/iwlwifi/iwl-helpers.h | |||
@@ -254,6 +254,26 @@ static inline u8 iwl_get_dma_hi_address(dma_addr_t addr) | |||
254 | return sizeof(addr) > sizeof(u32) ? (addr >> 16) >> 16 : 0; | 254 | return sizeof(addr) > sizeof(u32) ? (addr >> 16) >> 16 : 0; |
255 | } | 255 | } |
256 | 256 | ||
257 | /** | ||
258 | * iwl_queue_inc_wrap - increment queue index, wrap back to beginning | ||
259 | * @index -- current index | ||
260 | * @n_bd -- total number of entries in queue (must be power of 2) | ||
261 | */ | ||
262 | static inline int iwl_queue_inc_wrap(int index, int n_bd) | ||
263 | { | ||
264 | return ++index & (n_bd - 1); | ||
265 | } | ||
266 | |||
267 | /** | ||
268 | * iwl_queue_dec_wrap - decrement queue index, wrap back to end | ||
269 | * @index -- current index | ||
270 | * @n_bd -- total number of entries in queue (must be power of 2) | ||
271 | */ | ||
272 | static inline int iwl_queue_dec_wrap(int index, int n_bd) | ||
273 | { | ||
274 | return --index & (n_bd - 1); | ||
275 | } | ||
276 | |||
257 | /* TODO: Move fw_desc functions to iwl-pci.ko */ | 277 | /* TODO: Move fw_desc functions to iwl-pci.ko */ |
258 | static inline void iwl_free_fw_desc(struct pci_dev *pci_dev, | 278 | static inline void iwl_free_fw_desc(struct pci_dev *pci_dev, |
259 | struct fw_desc *desc) | 279 | struct fw_desc *desc) |
diff --git a/drivers/net/wireless/iwlwifi/iwl3945-base.c b/drivers/net/wireless/iwlwifi/iwl3945-base.c index 4aaced0b9f26..39fd5440a248 100644 --- a/drivers/net/wireless/iwlwifi/iwl3945-base.c +++ b/drivers/net/wireless/iwlwifi/iwl3945-base.c | |||
@@ -183,7 +183,7 @@ static const char *iwl3945_escape_essid(const char *essid, u8 essid_len) | |||
183 | * (#0-3) for data tx via EDCA. An additional 2 HCCA queues are unused. | 183 | * (#0-3) for data tx via EDCA. An additional 2 HCCA queues are unused. |
184 | ***************************************************/ | 184 | ***************************************************/ |
185 | 185 | ||
186 | static int iwl3945_queue_space(const struct iwl3945_queue *q) | 186 | int iwl3945_queue_space(const struct iwl3945_queue *q) |
187 | { | 187 | { |
188 | int s = q->read_ptr - q->write_ptr; | 188 | int s = q->read_ptr - q->write_ptr; |
189 | 189 | ||
@@ -199,33 +199,14 @@ static int iwl3945_queue_space(const struct iwl3945_queue *q) | |||
199 | return s; | 199 | return s; |
200 | } | 200 | } |
201 | 201 | ||
202 | /** | 202 | int iwl3945_x2_queue_used(const struct iwl3945_queue *q, int i) |
203 | * iwl3945_queue_inc_wrap - increment queue index, wrap back to beginning | ||
204 | * @index -- current index | ||
205 | * @n_bd -- total number of entries in queue (must be power of 2) | ||
206 | */ | ||
207 | static inline int iwl3945_queue_inc_wrap(int index, int n_bd) | ||
208 | { | ||
209 | return ++index & (n_bd - 1); | ||
210 | } | ||
211 | |||
212 | /** | ||
213 | * iwl3945_queue_dec_wrap - increment queue index, wrap back to end | ||
214 | * @index -- current index | ||
215 | * @n_bd -- total number of entries in queue (must be power of 2) | ||
216 | */ | ||
217 | static inline int iwl3945_queue_dec_wrap(int index, int n_bd) | ||
218 | { | ||
219 | return --index & (n_bd - 1); | ||
220 | } | ||
221 | |||
222 | static inline int x2_queue_used(const struct iwl3945_queue *q, int i) | ||
223 | { | 203 | { |
224 | return q->write_ptr > q->read_ptr ? | 204 | return q->write_ptr > q->read_ptr ? |
225 | (i >= q->read_ptr && i < q->write_ptr) : | 205 | (i >= q->read_ptr && i < q->write_ptr) : |
226 | !(i < q->read_ptr && i >= q->write_ptr); | 206 | !(i < q->read_ptr && i >= q->write_ptr); |
227 | } | 207 | } |
228 | 208 | ||
209 | |||
229 | static inline u8 get_cmd_index(struct iwl3945_queue *q, u32 index, int is_huge) | 210 | static inline u8 get_cmd_index(struct iwl3945_queue *q, u32 index, int is_huge) |
230 | { | 211 | { |
231 | /* This is for scan command, the big buffer at end of command array */ | 212 | /* This is for scan command, the big buffer at end of command array */ |
@@ -246,8 +227,8 @@ static int iwl3945_queue_init(struct iwl3945_priv *priv, struct iwl3945_queue *q | |||
246 | q->n_window = slots_num; | 227 | q->n_window = slots_num; |
247 | q->id = id; | 228 | q->id = id; |
248 | 229 | ||
249 | /* count must be power-of-two size, otherwise iwl3945_queue_inc_wrap | 230 | /* count must be power-of-two size, otherwise iwl_queue_inc_wrap |
250 | * and iwl3945_queue_dec_wrap are broken. */ | 231 | * and iwl_queue_dec_wrap are broken. */ |
251 | BUG_ON(!is_power_of_2(count)); | 232 | BUG_ON(!is_power_of_2(count)); |
252 | 233 | ||
253 | /* slots_num must be power-of-two size, otherwise | 234 | /* slots_num must be power-of-two size, otherwise |
@@ -347,7 +328,7 @@ int iwl3945_tx_queue_init(struct iwl3945_priv *priv, | |||
347 | txq->need_update = 0; | 328 | txq->need_update = 0; |
348 | 329 | ||
349 | /* TFD_QUEUE_SIZE_MAX must be power-of-two size, otherwise | 330 | /* TFD_QUEUE_SIZE_MAX must be power-of-two size, otherwise |
350 | * iwl3945_queue_inc_wrap and iwl3945_queue_dec_wrap are broken. */ | 331 | * iwl_queue_inc_wrap and iwl_queue_dec_wrap are broken. */ |
351 | BUILD_BUG_ON(TFD_QUEUE_SIZE_MAX & (TFD_QUEUE_SIZE_MAX - 1)); | 332 | BUILD_BUG_ON(TFD_QUEUE_SIZE_MAX & (TFD_QUEUE_SIZE_MAX - 1)); |
352 | 333 | ||
353 | /* Initialize queue high/low-water, head/tail indexes */ | 334 | /* Initialize queue high/low-water, head/tail indexes */ |
@@ -378,7 +359,7 @@ void iwl3945_tx_queue_free(struct iwl3945_priv *priv, struct iwl3945_tx_queue *t | |||
378 | 359 | ||
379 | /* first, empty all BD's */ | 360 | /* first, empty all BD's */ |
380 | for (; q->write_ptr != q->read_ptr; | 361 | for (; q->write_ptr != q->read_ptr; |
381 | q->read_ptr = iwl3945_queue_inc_wrap(q->read_ptr, q->n_bd)) | 362 | q->read_ptr = iwl_queue_inc_wrap(q->read_ptr, q->n_bd)) |
382 | iwl3945_hw_txq_free_tfd(priv, txq); | 363 | iwl3945_hw_txq_free_tfd(priv, txq); |
383 | 364 | ||
384 | len = sizeof(struct iwl3945_cmd) * q->n_window; | 365 | len = sizeof(struct iwl3945_cmd) * q->n_window; |
@@ -717,7 +698,7 @@ static int iwl3945_enqueue_hcmd(struct iwl3945_priv *priv, struct iwl3945_host_c | |||
717 | txq->need_update = 1; | 698 | txq->need_update = 1; |
718 | 699 | ||
719 | /* Increment and update queue's write index */ | 700 | /* Increment and update queue's write index */ |
720 | q->write_ptr = iwl3945_queue_inc_wrap(q->write_ptr, q->n_bd); | 701 | q->write_ptr = iwl_queue_inc_wrap(q->write_ptr, q->n_bd); |
721 | ret = iwl3945_tx_queue_update_write_ptr(priv, txq); | 702 | ret = iwl3945_tx_queue_update_write_ptr(priv, txq); |
722 | 703 | ||
723 | spin_unlock_irqrestore(&priv->hcmd_lock, flags); | 704 | spin_unlock_irqrestore(&priv->hcmd_lock, flags); |
@@ -2797,7 +2778,7 @@ static int iwl3945_tx_skb(struct iwl3945_priv *priv, | |||
2797 | ieee80211_get_hdrlen(fc)); | 2778 | ieee80211_get_hdrlen(fc)); |
2798 | 2779 | ||
2799 | /* Tell device the write index *just past* this latest filled TFD */ | 2780 | /* Tell device the write index *just past* this latest filled TFD */ |
2800 | q->write_ptr = iwl3945_queue_inc_wrap(q->write_ptr, q->n_bd); | 2781 | q->write_ptr = iwl_queue_inc_wrap(q->write_ptr, q->n_bd); |
2801 | rc = iwl3945_tx_queue_update_write_ptr(priv, txq); | 2782 | rc = iwl3945_tx_queue_update_write_ptr(priv, txq); |
2802 | spin_unlock_irqrestore(&priv->lock, flags); | 2783 | spin_unlock_irqrestore(&priv->lock, flags); |
2803 | 2784 | ||
@@ -3189,16 +3170,16 @@ static int iwl3945_tx_queue_reclaim(struct iwl3945_priv *priv, int txq_id, int i | |||
3189 | struct iwl3945_queue *q = &txq->q; | 3170 | struct iwl3945_queue *q = &txq->q; |
3190 | int nfreed = 0; | 3171 | int nfreed = 0; |
3191 | 3172 | ||
3192 | if ((index >= q->n_bd) || (x2_queue_used(q, index) == 0)) { | 3173 | if ((index >= q->n_bd) || (iwl3945_x2_queue_used(q, index) == 0)) { |
3193 | IWL_ERROR("Read index for DMA queue txq id (%d), index %d, " | 3174 | IWL_ERROR("Read index for DMA queue txq id (%d), index %d, " |
3194 | "is out of range [0-%d] %d %d.\n", txq_id, | 3175 | "is out of range [0-%d] %d %d.\n", txq_id, |
3195 | index, q->n_bd, q->write_ptr, q->read_ptr); | 3176 | index, q->n_bd, q->write_ptr, q->read_ptr); |
3196 | return 0; | 3177 | return 0; |
3197 | } | 3178 | } |
3198 | 3179 | ||
3199 | for (index = iwl3945_queue_inc_wrap(index, q->n_bd); | 3180 | for (index = iwl_queue_inc_wrap(index, q->n_bd); |
3200 | q->read_ptr != index; | 3181 | q->read_ptr != index; |
3201 | q->read_ptr = iwl3945_queue_inc_wrap(q->read_ptr, q->n_bd)) { | 3182 | q->read_ptr = iwl_queue_inc_wrap(q->read_ptr, q->n_bd)) { |
3202 | if (txq_id != IWL_CMD_QUEUE_NUM) { | 3183 | if (txq_id != IWL_CMD_QUEUE_NUM) { |
3203 | iwl3945_txstatus_to_ieee(priv, | 3184 | iwl3945_txstatus_to_ieee(priv, |
3204 | &(txq->txb[txq->q.read_ptr])); | 3185 | &(txq->txb[txq->q.read_ptr])); |
@@ -3245,7 +3226,7 @@ static void iwl3945_rx_reply_tx(struct iwl3945_priv *priv, | |||
3245 | struct iwl3945_tx_resp *tx_resp = (void *)&pkt->u.raw[0]; | 3226 | struct iwl3945_tx_resp *tx_resp = (void *)&pkt->u.raw[0]; |
3246 | u32 status = le32_to_cpu(tx_resp->status); | 3227 | u32 status = le32_to_cpu(tx_resp->status); |
3247 | 3228 | ||
3248 | if ((index >= txq->q.n_bd) || (x2_queue_used(&txq->q, index) == 0)) { | 3229 | if ((index >= txq->q.n_bd) || (iwl3945_x2_queue_used(&txq->q, index) == 0)) { |
3249 | IWL_ERROR("Read index for DMA queue txq_id (%d) index %d " | 3230 | IWL_ERROR("Read index for DMA queue txq_id (%d) index %d " |
3250 | "is out of range [0-%d] %d %d\n", txq_id, | 3231 | "is out of range [0-%d] %d %d\n", txq_id, |
3251 | index, txq->q.n_bd, txq->q.write_ptr, | 3232 | index, txq->q.n_bd, txq->q.write_ptr, |
diff --git a/drivers/net/wireless/iwlwifi/iwl4965-base.c b/drivers/net/wireless/iwlwifi/iwl4965-base.c index af95626a6112..28c64c39ef02 100644 --- a/drivers/net/wireless/iwlwifi/iwl4965-base.c +++ b/drivers/net/wireless/iwlwifi/iwl4965-base.c | |||
@@ -194,25 +194,6 @@ int iwl4965_queue_space(const struct iwl4965_queue *q) | |||
194 | return s; | 194 | return s; |
195 | } | 195 | } |
196 | 196 | ||
197 | /** | ||
198 | * iwl4965_queue_inc_wrap - increment queue index, wrap back to beginning | ||
199 | * @index -- current index | ||
200 | * @n_bd -- total number of entries in queue (must be power of 2) | ||
201 | */ | ||
202 | static inline int iwl4965_queue_inc_wrap(int index, int n_bd) | ||
203 | { | ||
204 | return ++index & (n_bd - 1); | ||
205 | } | ||
206 | |||
207 | /** | ||
208 | * iwl4965_queue_dec_wrap - decrement queue index, wrap back to end | ||
209 | * @index -- current index | ||
210 | * @n_bd -- total number of entries in queue (must be power of 2) | ||
211 | */ | ||
212 | static inline int iwl4965_queue_dec_wrap(int index, int n_bd) | ||
213 | { | ||
214 | return --index & (n_bd - 1); | ||
215 | } | ||
216 | 197 | ||
217 | static inline int x2_queue_used(const struct iwl4965_queue *q, int i) | 198 | static inline int x2_queue_used(const struct iwl4965_queue *q, int i) |
218 | { | 199 | { |
@@ -241,8 +222,8 @@ static int iwl4965_queue_init(struct iwl4965_priv *priv, struct iwl4965_queue *q | |||
241 | q->n_window = slots_num; | 222 | q->n_window = slots_num; |
242 | q->id = id; | 223 | q->id = id; |
243 | 224 | ||
244 | /* count must be power-of-two size, otherwise iwl4965_queue_inc_wrap | 225 | /* count must be power-of-two size, otherwise iwl_queue_inc_wrap |
245 | * and iwl4965_queue_dec_wrap are broken. */ | 226 | * and iwl_queue_dec_wrap are broken. */ |
246 | BUG_ON(!is_power_of_2(count)); | 227 | BUG_ON(!is_power_of_2(count)); |
247 | 228 | ||
248 | /* slots_num must be power-of-two size, otherwise | 229 | /* slots_num must be power-of-two size, otherwise |
@@ -342,7 +323,7 @@ int iwl4965_tx_queue_init(struct iwl4965_priv *priv, | |||
342 | txq->need_update = 0; | 323 | txq->need_update = 0; |
343 | 324 | ||
344 | /* TFD_QUEUE_SIZE_MAX must be power-of-two size, otherwise | 325 | /* TFD_QUEUE_SIZE_MAX must be power-of-two size, otherwise |
345 | * iwl4965_queue_inc_wrap and iwl4965_queue_dec_wrap are broken. */ | 326 | * iwl_queue_inc_wrap and iwl_queue_dec_wrap are broken. */ |
346 | BUILD_BUG_ON(TFD_QUEUE_SIZE_MAX & (TFD_QUEUE_SIZE_MAX - 1)); | 327 | BUILD_BUG_ON(TFD_QUEUE_SIZE_MAX & (TFD_QUEUE_SIZE_MAX - 1)); |
347 | 328 | ||
348 | /* Initialize queue's high/low-water marks, and head/tail indexes */ | 329 | /* Initialize queue's high/low-water marks, and head/tail indexes */ |
@@ -373,7 +354,7 @@ void iwl4965_tx_queue_free(struct iwl4965_priv *priv, struct iwl4965_tx_queue *t | |||
373 | 354 | ||
374 | /* first, empty all BD's */ | 355 | /* first, empty all BD's */ |
375 | for (; q->write_ptr != q->read_ptr; | 356 | for (; q->write_ptr != q->read_ptr; |
376 | q->read_ptr = iwl4965_queue_inc_wrap(q->read_ptr, q->n_bd)) | 357 | q->read_ptr = iwl_queue_inc_wrap(q->read_ptr, q->n_bd)) |
377 | iwl4965_hw_txq_free_tfd(priv, txq); | 358 | iwl4965_hw_txq_free_tfd(priv, txq); |
378 | 359 | ||
379 | len = sizeof(struct iwl4965_cmd) * q->n_window; | 360 | len = sizeof(struct iwl4965_cmd) * q->n_window; |
@@ -714,7 +695,7 @@ static int iwl4965_enqueue_hcmd(struct iwl4965_priv *priv, struct iwl4965_host_c | |||
714 | ret = iwl4965_tx_queue_update_wr_ptr(priv, txq, 0); | 695 | ret = iwl4965_tx_queue_update_wr_ptr(priv, txq, 0); |
715 | 696 | ||
716 | /* Increment and update queue's write index */ | 697 | /* Increment and update queue's write index */ |
717 | q->write_ptr = iwl4965_queue_inc_wrap(q->write_ptr, q->n_bd); | 698 | q->write_ptr = iwl_queue_inc_wrap(q->write_ptr, q->n_bd); |
718 | iwl4965_tx_queue_update_write_ptr(priv, txq); | 699 | iwl4965_tx_queue_update_write_ptr(priv, txq); |
719 | 700 | ||
720 | spin_unlock_irqrestore(&priv->hcmd_lock, flags); | 701 | spin_unlock_irqrestore(&priv->hcmd_lock, flags); |
@@ -2897,7 +2878,7 @@ static int iwl4965_tx_skb(struct iwl4965_priv *priv, | |||
2897 | iwl4965_tx_queue_update_wr_ptr(priv, txq, len); | 2878 | iwl4965_tx_queue_update_wr_ptr(priv, txq, len); |
2898 | 2879 | ||
2899 | /* Tell device the write index *just past* this latest filled TFD */ | 2880 | /* Tell device the write index *just past* this latest filled TFD */ |
2900 | q->write_ptr = iwl4965_queue_inc_wrap(q->write_ptr, q->n_bd); | 2881 | q->write_ptr = iwl_queue_inc_wrap(q->write_ptr, q->n_bd); |
2901 | rc = iwl4965_tx_queue_update_write_ptr(priv, txq); | 2882 | rc = iwl4965_tx_queue_update_write_ptr(priv, txq); |
2902 | spin_unlock_irqrestore(&priv->lock, flags); | 2883 | spin_unlock_irqrestore(&priv->lock, flags); |
2903 | 2884 | ||
@@ -3291,9 +3272,9 @@ int iwl4965_tx_queue_reclaim(struct iwl4965_priv *priv, int txq_id, int index) | |||
3291 | return 0; | 3272 | return 0; |
3292 | } | 3273 | } |
3293 | 3274 | ||
3294 | for (index = iwl4965_queue_inc_wrap(index, q->n_bd); | 3275 | for (index = iwl_queue_inc_wrap(index, q->n_bd); |
3295 | q->read_ptr != index; | 3276 | q->read_ptr != index; |
3296 | q->read_ptr = iwl4965_queue_inc_wrap(q->read_ptr, q->n_bd)) { | 3277 | q->read_ptr = iwl_queue_inc_wrap(q->read_ptr, q->n_bd)) { |
3297 | if (txq_id != IWL_CMD_QUEUE_NUM) { | 3278 | if (txq_id != IWL_CMD_QUEUE_NUM) { |
3298 | iwl4965_txstatus_to_ieee(priv, | 3279 | iwl4965_txstatus_to_ieee(priv, |
3299 | &(txq->txb[txq->q.read_ptr])); | 3280 | &(txq->txb[txq->q.read_ptr])); |
@@ -3538,7 +3519,7 @@ static void iwl4965_rx_reply_tx(struct iwl4965_priv *priv, | |||
3538 | 3519 | ||
3539 | if (txq->q.read_ptr != (scd_ssn & 0xff)) { | 3520 | if (txq->q.read_ptr != (scd_ssn & 0xff)) { |
3540 | int freed; | 3521 | int freed; |
3541 | index = iwl4965_queue_dec_wrap(scd_ssn & 0xff, txq->q.n_bd); | 3522 | index = iwl_queue_dec_wrap(scd_ssn & 0xff, txq->q.n_bd); |
3542 | IWL_DEBUG_TX_REPLY("Retry scheduler reclaim scd_ssn " | 3523 | IWL_DEBUG_TX_REPLY("Retry scheduler reclaim scd_ssn " |
3543 | "%d index %d\n", scd_ssn , index); | 3524 | "%d index %d\n", scd_ssn , index); |
3544 | freed = iwl4965_tx_queue_reclaim(priv, txq_id, index); | 3525 | freed = iwl4965_tx_queue_reclaim(priv, txq_id, index); |