ionic: have ionic_qcq_disable decide on sending to hardware
authorShannon Nelson <snelson@pensando.io>
Fri, 1 Oct 2021 18:05:56 +0000 (11:05 -0700)
committerDavid S. Miller <davem@davemloft.net>
Sat, 2 Oct 2021 13:00:22 +0000 (14:00 +0100)
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: Shannon Nelson <snelson@pensando.io>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/pensando/ionic/ionic_lif.c

index 5efa9f1..16d98bb 100644 (file)
@@ -287,11 +287,10 @@ static int ionic_qcq_enable(struct ionic_qcq *qcq)
        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_lif *lif;
-       int err = 0;
 
        struct ionic_admin_ctx ctx = {
                .work = COMPLETION_INITIALIZER_ONSTACK(ctx.work),
@@ -318,17 +317,19 @@ static int ionic_qcq_disable(struct ionic_qcq *qcq, bool send_to_hw)
                napi_disable(&qcq->napi);
        }
 
-       if (send_to_hw) {
-               ctx.cmd.q_control.lif_index = cpu_to_le16(lif->index);
-               ctx.cmd.q_control.type = q->type;
-               ctx.cmd.q_control.index = cpu_to_le32(q->index);
-               dev_dbg(lif->ionic->dev, "q_disable.index %d q_disable.qtype %d\n",
-                       ctx.cmd.q_control.index, ctx.cmd.q_control.type);
+       /* 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;
 
-               err = ionic_adminq_post_wait(lif, &ctx);
-       }
+       ctx.cmd.q_control.lif_index = cpu_to_le16(lif->index);
+       ctx.cmd.q_control.type = q->type;
+       ctx.cmd.q_control.index = cpu_to_le32(q->index);
+       dev_dbg(lif->ionic->dev, "q_disable.index %d q_disable.qtype %d\n",
+               ctx.cmd.q_control.index, ctx.cmd.q_control.type);
 
-       return err;
+       return ionic_adminq_post_wait(lif, &ctx);
 }
 
 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)
 
        if (lif->txqcqs) {
                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)
-               err = ionic_qcq_disable(lif->hwstamp_txq, (err != -ETIMEDOUT));
+               err = ionic_qcq_disable(lif->hwstamp_txq, err);
 
        if (lif->rxqcqs) {
                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)
-               err = ionic_qcq_disable(lif->hwstamp_rxq, (err != -ETIMEDOUT));
+               err = ionic_qcq_disable(lif->hwstamp_rxq, err);
 
        ionic_lif_quiesce(lif);
 }
@@ -2159,7 +2160,7 @@ static int ionic_txrx_enable(struct ionic_lif *lif)
 
                err = ionic_qcq_enable(lif->txqcqs[i]);
                if (err) {
-                       derr = ionic_qcq_disable(lif->rxqcqs[i], (err != -ETIMEDOUT));
+                       derr = ionic_qcq_disable(lif->rxqcqs[i], err);
                        goto err_out;
                }
        }
@@ -2181,13 +2182,13 @@ static int ionic_txrx_enable(struct ionic_lif *lif)
 
 err_out_hwstamp_tx:
        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:
        i = lif->nxqs;
 err_out:
        while (i--) {
-               derr = ionic_qcq_disable(lif->txqcqs[i], (derr != -ETIMEDOUT));
-               derr = ionic_qcq_disable(lif->rxqcqs[i], (derr != -ETIMEDOUT));
+               derr = ionic_qcq_disable(lif->txqcqs[i], derr);
+               derr = ionic_qcq_disable(lif->rxqcqs[i], derr);
        }
 
        return err;