ionic: tame the filter no space message
authorShannon Nelson <snelson@pensando.io>
Sat, 9 Oct 2021 18:45:23 +0000 (11:45 -0700)
committerDavid S. Miller <davem@davemloft.net>
Sun, 10 Oct 2021 09:42:47 +0000 (10:42 +0100)
Override the automatic AdminQ error message in order to
capture the potential No Space message when we hit the
max vlan limit, and add additional messaging to detail
what filter failed.

Signed-off-by: Shannon Nelson <snelson@pensando.io>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/pensando/ionic/ionic_rx_filter.c

index 366f157..f6e785f 100644 (file)
@@ -357,7 +357,7 @@ static int ionic_lif_filter_add(struct ionic_lif *lif,
        }
 
        if (err != -ENOSPC)
-               err = ionic_adminq_post_wait(lif, &ctx);
+               err = ionic_adminq_post_wait_nomsg(lif, &ctx);
 
        spin_lock_bh(&lif->rx_filters.lock);
 
@@ -382,6 +382,19 @@ static int ionic_lif_filter_add(struct ionic_lif *lif,
                        return 0;
                }
 
+               ionic_adminq_netdev_err_print(lif, ctx.cmd.cmd.opcode,
+                                             ctx.comp.comp.status, err);
+               switch (le16_to_cpu(ctx.cmd.rx_filter_add.match)) {
+               case IONIC_RX_FILTER_MATCH_VLAN:
+                       netdev_info(lif->netdev, "rx_filter add failed: VLAN %d\n",
+                                   ctx.cmd.rx_filter_add.vlan.vlan);
+                       break;
+               case IONIC_RX_FILTER_MATCH_MAC:
+                       netdev_info(lif->netdev, "rx_filter add failed: ADDR %pM\n",
+                                   ctx.cmd.rx_filter_add.mac.addr);
+                       break;
+               }
+
                return err;
        }