Commit d5eddde5 authored by Shannon Nelson's avatar Shannon Nelson Committed by David S. Miller

ionic: check for queues before deleting

Make sure the queue structures exist before trying
to delete them.  This addresses a couple of error
recovery issues.
Signed-off-by: default avatarShannon Nelson <snelson@pensando.io>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent f9c00e2c
...@@ -1437,13 +1437,20 @@ static void ionic_txrx_disable(struct ionic_lif *lif) ...@@ -1437,13 +1437,20 @@ static void ionic_txrx_disable(struct ionic_lif *lif)
unsigned int i; unsigned int i;
int err; int err;
for (i = 0; i < lif->nxqs; i++) { if (lif->txqcqs) {
err = ionic_qcq_disable(lif->txqcqs[i].qcq); for (i = 0; i < lif->nxqs; i++) {
if (err == -ETIMEDOUT) err = ionic_qcq_disable(lif->txqcqs[i].qcq);
break; if (err == -ETIMEDOUT)
err = ionic_qcq_disable(lif->rxqcqs[i].qcq); break;
if (err == -ETIMEDOUT) }
break; }
if (lif->rxqcqs) {
for (i = 0; i < lif->nxqs; i++) {
err = ionic_qcq_disable(lif->rxqcqs[i].qcq);
if (err == -ETIMEDOUT)
break;
}
} }
} }
...@@ -1451,14 +1458,20 @@ static void ionic_txrx_deinit(struct ionic_lif *lif) ...@@ -1451,14 +1458,20 @@ static void ionic_txrx_deinit(struct ionic_lif *lif)
{ {
unsigned int i; unsigned int i;
for (i = 0; i < lif->nxqs; i++) { if (lif->txqcqs) {
ionic_lif_qcq_deinit(lif, lif->txqcqs[i].qcq); for (i = 0; i < lif->nxqs; i++) {
ionic_tx_flush(&lif->txqcqs[i].qcq->cq); ionic_lif_qcq_deinit(lif, lif->txqcqs[i].qcq);
ionic_tx_empty(&lif->txqcqs[i].qcq->q); ionic_tx_flush(&lif->txqcqs[i].qcq->cq);
ionic_tx_empty(&lif->txqcqs[i].qcq->q);
}
}
ionic_lif_qcq_deinit(lif, lif->rxqcqs[i].qcq); if (lif->rxqcqs) {
ionic_rx_flush(&lif->rxqcqs[i].qcq->cq); for (i = 0; i < lif->nxqs; i++) {
ionic_rx_empty(&lif->rxqcqs[i].qcq->q); ionic_lif_qcq_deinit(lif, lif->rxqcqs[i].qcq);
ionic_rx_flush(&lif->rxqcqs[i].qcq->cq);
ionic_rx_empty(&lif->rxqcqs[i].qcq->q);
}
} }
} }
...@@ -1466,12 +1479,18 @@ static void ionic_txrx_free(struct ionic_lif *lif) ...@@ -1466,12 +1479,18 @@ static void ionic_txrx_free(struct ionic_lif *lif)
{ {
unsigned int i; unsigned int i;
for (i = 0; i < lif->nxqs; i++) { if (lif->txqcqs) {
ionic_qcq_free(lif, lif->txqcqs[i].qcq); for (i = 0; i < lif->nxqs; i++) {
lif->txqcqs[i].qcq = NULL; ionic_qcq_free(lif, lif->txqcqs[i].qcq);
lif->txqcqs[i].qcq = NULL;
}
}
ionic_qcq_free(lif, lif->rxqcqs[i].qcq); if (lif->rxqcqs) {
lif->rxqcqs[i].qcq = NULL; for (i = 0; i < lif->nxqs; i++) {
ionic_qcq_free(lif, lif->rxqcqs[i].qcq);
lif->rxqcqs[i].qcq = NULL;
}
} }
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment