From: Andrew Rybchenko Date: Sat, 27 May 2017 07:55:34 +0000 (+0100) Subject: net/sfc: handle already flushed Tx queue gracefully X-Git-Tag: spdx-start~3096 X-Git-Url: http://git.droids-corp.org/?a=commitdiff_plain;h=69fbd1e923dc49d029625ce43e27d7f3b4177095;p=dpdk.git net/sfc: handle already flushed Tx queue gracefully Tx queue may be already flushed because of previous Tx error or MC reboot. Signed-off-by: Andrew Rybchenko --- diff --git a/drivers/net/sfc/sfc_tx.c b/drivers/net/sfc/sfc_tx.c index 9e426ca9d7..fc439cb6c9 100644 --- a/drivers/net/sfc/sfc_tx.c +++ b/drivers/net/sfc/sfc_tx.c @@ -479,6 +479,7 @@ sfc_tx_qstop(struct sfc_adapter *sa, unsigned int sw_index) struct sfc_txq *txq; unsigned int retry_count; unsigned int wait_count; + int rc; sfc_log_init(sa, "TxQ = %u", sw_index); @@ -502,8 +503,10 @@ sfc_tx_qstop(struct sfc_adapter *sa, unsigned int sw_index) ((txq->state & SFC_TXQ_FLUSHED) == 0) && (retry_count < SFC_TX_QFLUSH_ATTEMPTS); ++retry_count) { - if (efx_tx_qflush(txq->common) != 0) { - txq->state |= SFC_TXQ_FLUSH_FAILED; + rc = efx_tx_qflush(txq->common); + if (rc != 0) { + txq->state |= (rc == EALREADY) ? + SFC_TXQ_FLUSHED : SFC_TXQ_FLUSH_FAILED; break; }