mirror of
https://github.com/FEX-Emu/linux.git
synced 2025-01-07 01:51:42 +00:00
iwlwifi: error checking for number of tfds in queue
When receive reply_tx and ready to decrement the count for number of tfds in queue, do error checking to prevent error condition and tfds_in_queue become negative number. Signed-off-by: Wey-Yi Guy <wey-yi.w.guy@intel.com> Signed-off-by: Reinette Chatre <reinette.chatre@intel.com> CC: stable@kernel.org Signed-off-by: John W. Linville <linville@tuxdriver.com>
This commit is contained in:
parent
5e2f75b899
commit
a239a8b47c
@ -2008,7 +2008,7 @@ static void iwl4965_rx_reply_tx(struct iwl_priv *priv,
|
|||||||
IWL_DEBUG_TX_REPLY(priv, "Retry scheduler reclaim scd_ssn "
|
IWL_DEBUG_TX_REPLY(priv, "Retry scheduler reclaim scd_ssn "
|
||||||
"%d index %d\n", scd_ssn , index);
|
"%d index %d\n", scd_ssn , index);
|
||||||
freed = iwl_tx_queue_reclaim(priv, txq_id, index);
|
freed = iwl_tx_queue_reclaim(priv, txq_id, index);
|
||||||
priv->stations[sta_id].tid[tid].tfds_in_queue -= freed;
|
iwl_free_tfds_in_queue(priv, sta_id, tid, freed);
|
||||||
|
|
||||||
if (priv->mac80211_registered &&
|
if (priv->mac80211_registered &&
|
||||||
(iwl_queue_space(&txq->q) > txq->q.low_mark) &&
|
(iwl_queue_space(&txq->q) > txq->q.low_mark) &&
|
||||||
|
@ -1125,7 +1125,7 @@ static void iwl5000_rx_reply_tx(struct iwl_priv *priv,
|
|||||||
scd_ssn , index, txq_id, txq->swq_id);
|
scd_ssn , index, txq_id, txq->swq_id);
|
||||||
|
|
||||||
freed = iwl_tx_queue_reclaim(priv, txq_id, index);
|
freed = iwl_tx_queue_reclaim(priv, txq_id, index);
|
||||||
priv->stations[sta_id].tid[tid].tfds_in_queue -= freed;
|
iwl_free_tfds_in_queue(priv, sta_id, tid, freed);
|
||||||
|
|
||||||
if (priv->mac80211_registered &&
|
if (priv->mac80211_registered &&
|
||||||
(iwl_queue_space(&txq->q) > txq->q.low_mark) &&
|
(iwl_queue_space(&txq->q) > txq->q.low_mark) &&
|
||||||
@ -1154,7 +1154,7 @@ static void iwl5000_rx_reply_tx(struct iwl_priv *priv,
|
|||||||
|
|
||||||
freed = iwl_tx_queue_reclaim(priv, txq_id, index);
|
freed = iwl_tx_queue_reclaim(priv, txq_id, index);
|
||||||
if (ieee80211_is_data_qos(tx_resp->frame_ctrl))
|
if (ieee80211_is_data_qos(tx_resp->frame_ctrl))
|
||||||
priv->stations[sta_id].tid[tid].tfds_in_queue -= freed;
|
iwl_free_tfds_in_queue(priv, sta_id, tid, freed);
|
||||||
|
|
||||||
if (priv->mac80211_registered &&
|
if (priv->mac80211_registered &&
|
||||||
(iwl_queue_space(&txq->q) > txq->q.low_mark))
|
(iwl_queue_space(&txq->q) > txq->q.low_mark))
|
||||||
|
@ -446,6 +446,8 @@ void iwl_hw_txq_ctx_free(struct iwl_priv *priv);
|
|||||||
int iwl_hw_tx_queue_init(struct iwl_priv *priv,
|
int iwl_hw_tx_queue_init(struct iwl_priv *priv,
|
||||||
struct iwl_tx_queue *txq);
|
struct iwl_tx_queue *txq);
|
||||||
int iwl_txq_update_write_ptr(struct iwl_priv *priv, struct iwl_tx_queue *txq);
|
int iwl_txq_update_write_ptr(struct iwl_priv *priv, struct iwl_tx_queue *txq);
|
||||||
|
void iwl_free_tfds_in_queue(struct iwl_priv *priv,
|
||||||
|
int sta_id, int tid, int freed);
|
||||||
int iwl_tx_queue_init(struct iwl_priv *priv, struct iwl_tx_queue *txq,
|
int iwl_tx_queue_init(struct iwl_priv *priv, struct iwl_tx_queue *txq,
|
||||||
int slots_num, u32 txq_id);
|
int slots_num, u32 txq_id);
|
||||||
void iwl_tx_queue_free(struct iwl_priv *priv, int txq_id);
|
void iwl_tx_queue_free(struct iwl_priv *priv, int txq_id);
|
||||||
|
@ -120,6 +120,20 @@ int iwl_txq_update_write_ptr(struct iwl_priv *priv, struct iwl_tx_queue *txq)
|
|||||||
EXPORT_SYMBOL(iwl_txq_update_write_ptr);
|
EXPORT_SYMBOL(iwl_txq_update_write_ptr);
|
||||||
|
|
||||||
|
|
||||||
|
void iwl_free_tfds_in_queue(struct iwl_priv *priv,
|
||||||
|
int sta_id, int tid, int freed)
|
||||||
|
{
|
||||||
|
if (priv->stations[sta_id].tid[tid].tfds_in_queue >= freed)
|
||||||
|
priv->stations[sta_id].tid[tid].tfds_in_queue -= freed;
|
||||||
|
else {
|
||||||
|
IWL_ERR(priv, "free more than tfds_in_queue (%u:%d)\n",
|
||||||
|
priv->stations[sta_id].tid[tid].tfds_in_queue,
|
||||||
|
freed);
|
||||||
|
priv->stations[sta_id].tid[tid].tfds_in_queue = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL(iwl_free_tfds_in_queue);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* iwl_tx_queue_free - Deallocate DMA queue.
|
* iwl_tx_queue_free - Deallocate DMA queue.
|
||||||
* @txq: Transmit queue to deallocate.
|
* @txq: Transmit queue to deallocate.
|
||||||
@ -1559,7 +1573,7 @@ void iwl_rx_reply_compressed_ba(struct iwl_priv *priv,
|
|||||||
if (txq->q.read_ptr != (ba_resp_scd_ssn & 0xff)) {
|
if (txq->q.read_ptr != (ba_resp_scd_ssn & 0xff)) {
|
||||||
/* calculate mac80211 ampdu sw queue to wake */
|
/* calculate mac80211 ampdu sw queue to wake */
|
||||||
int freed = iwl_tx_queue_reclaim(priv, scd_flow, index);
|
int freed = iwl_tx_queue_reclaim(priv, scd_flow, index);
|
||||||
priv->stations[sta_id].tid[tid].tfds_in_queue -= freed;
|
iwl_free_tfds_in_queue(priv, sta_id, tid, freed);
|
||||||
|
|
||||||
if ((iwl_queue_space(&txq->q) > txq->q.low_mark) &&
|
if ((iwl_queue_space(&txq->q) > txq->q.low_mark) &&
|
||||||
priv->mac80211_registered &&
|
priv->mac80211_registered &&
|
||||||
|
Loading…
Reference in New Issue
Block a user