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

ionic: have ionic_qcq_disable decide on sending to hardware

Simplify the code a little by keeping the send_to_hw decision
inside of ionic_qcq_disable rather than in the callers.  Also,
add ENXIO to the decision expression.
Signed-off-by: default avatarShannon Nelson <snelson@pensando.io>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent a095e477
...@@ -287,11 +287,10 @@ static int ionic_qcq_enable(struct ionic_qcq *qcq) ...@@ -287,11 +287,10 @@ static int ionic_qcq_enable(struct ionic_qcq *qcq)
return ionic_adminq_post_wait(lif, &ctx); return ionic_adminq_post_wait(lif, &ctx);
} }
static int ionic_qcq_disable(struct ionic_qcq *qcq, bool send_to_hw) static int ionic_qcq_disable(struct ionic_qcq *qcq, int fw_err)
{ {
struct ionic_queue *q; struct ionic_queue *q;
struct ionic_lif *lif; struct ionic_lif *lif;
int err = 0;
struct ionic_admin_ctx ctx = { struct ionic_admin_ctx ctx = {
.work = COMPLETION_INITIALIZER_ONSTACK(ctx.work), .work = COMPLETION_INITIALIZER_ONSTACK(ctx.work),
...@@ -318,17 +317,19 @@ static int ionic_qcq_disable(struct ionic_qcq *qcq, bool send_to_hw) ...@@ -318,17 +317,19 @@ static int ionic_qcq_disable(struct ionic_qcq *qcq, bool send_to_hw)
napi_disable(&qcq->napi); napi_disable(&qcq->napi);
} }
if (send_to_hw) { /* If there was a previous fw communcation error, don't bother with
* sending the adminq command and just return the same error value.
*/
if (fw_err == -ETIMEDOUT || fw_err == -ENXIO)
return fw_err;
ctx.cmd.q_control.lif_index = cpu_to_le16(lif->index); ctx.cmd.q_control.lif_index = cpu_to_le16(lif->index);
ctx.cmd.q_control.type = q->type; ctx.cmd.q_control.type = q->type;
ctx.cmd.q_control.index = cpu_to_le32(q->index); ctx.cmd.q_control.index = cpu_to_le32(q->index);
dev_dbg(lif->ionic->dev, "q_disable.index %d q_disable.qtype %d\n", dev_dbg(lif->ionic->dev, "q_disable.index %d q_disable.qtype %d\n",
ctx.cmd.q_control.index, ctx.cmd.q_control.type); ctx.cmd.q_control.index, ctx.cmd.q_control.type);
err = ionic_adminq_post_wait(lif, &ctx); return ionic_adminq_post_wait(lif, &ctx);
}
return err;
} }
static void ionic_lif_qcq_deinit(struct ionic_lif *lif, struct ionic_qcq *qcq) static void ionic_lif_qcq_deinit(struct ionic_lif *lif, struct ionic_qcq *qcq)
...@@ -1947,19 +1948,19 @@ static void ionic_txrx_disable(struct ionic_lif *lif) ...@@ -1947,19 +1948,19 @@ static void ionic_txrx_disable(struct ionic_lif *lif)
if (lif->txqcqs) { if (lif->txqcqs) {
for (i = 0; i < lif->nxqs; i++) for (i = 0; i < lif->nxqs; i++)
err = ionic_qcq_disable(lif->txqcqs[i], (err != -ETIMEDOUT)); err = ionic_qcq_disable(lif->txqcqs[i], err);
} }
if (lif->hwstamp_txq) if (lif->hwstamp_txq)
err = ionic_qcq_disable(lif->hwstamp_txq, (err != -ETIMEDOUT)); err = ionic_qcq_disable(lif->hwstamp_txq, err);
if (lif->rxqcqs) { if (lif->rxqcqs) {
for (i = 0; i < lif->nxqs; i++) for (i = 0; i < lif->nxqs; i++)
err = ionic_qcq_disable(lif->rxqcqs[i], (err != -ETIMEDOUT)); err = ionic_qcq_disable(lif->rxqcqs[i], err);
} }
if (lif->hwstamp_rxq) if (lif->hwstamp_rxq)
err = ionic_qcq_disable(lif->hwstamp_rxq, (err != -ETIMEDOUT)); err = ionic_qcq_disable(lif->hwstamp_rxq, err);
ionic_lif_quiesce(lif); ionic_lif_quiesce(lif);
} }
...@@ -2159,7 +2160,7 @@ static int ionic_txrx_enable(struct ionic_lif *lif) ...@@ -2159,7 +2160,7 @@ static int ionic_txrx_enable(struct ionic_lif *lif)
err = ionic_qcq_enable(lif->txqcqs[i]); err = ionic_qcq_enable(lif->txqcqs[i]);
if (err) { if (err) {
derr = ionic_qcq_disable(lif->rxqcqs[i], (err != -ETIMEDOUT)); derr = ionic_qcq_disable(lif->rxqcqs[i], err);
goto err_out; goto err_out;
} }
} }
...@@ -2181,13 +2182,13 @@ static int ionic_txrx_enable(struct ionic_lif *lif) ...@@ -2181,13 +2182,13 @@ static int ionic_txrx_enable(struct ionic_lif *lif)
err_out_hwstamp_tx: err_out_hwstamp_tx:
if (lif->hwstamp_rxq) if (lif->hwstamp_rxq)
derr = ionic_qcq_disable(lif->hwstamp_rxq, (derr != -ETIMEDOUT)); derr = ionic_qcq_disable(lif->hwstamp_rxq, derr);
err_out_hwstamp_rx: err_out_hwstamp_rx:
i = lif->nxqs; i = lif->nxqs;
err_out: err_out:
while (i--) { while (i--) {
derr = ionic_qcq_disable(lif->txqcqs[i], (derr != -ETIMEDOUT)); derr = ionic_qcq_disable(lif->txqcqs[i], derr);
derr = ionic_qcq_disable(lif->rxqcqs[i], (derr != -ETIMEDOUT)); derr = ionic_qcq_disable(lif->rxqcqs[i], derr);
} }
return err; return err;
......
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