OSDN Git Service

cxgb4: Don't return EAGAIN when TCAM is full.
authorVishal Kulkarni <vishal@chelsio.com>
Mon, 8 Apr 2019 12:33:49 +0000 (18:03 +0530)
committerDavid S. Miller <davem@davemloft.net>
Mon, 8 Apr 2019 17:01:50 +0000 (10:01 -0700)
During hash filter programming, driver needs to return ENOSPC error
intead of EAGAIN when TCAM is full.

Signed-off-by: Vishal Kulkarni <vishal@chelsio.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/chelsio/cxgb4/cxgb4_filter.c
drivers/net/ethernet/chelsio/cxgb4/cxgb4_tc_flower.c

index 5afb430..93ad4be 100644 (file)
@@ -1722,12 +1722,13 @@ void hash_filter_rpl(struct adapter *adap, const struct cpl_act_open_rpl *rpl)
                break;
 
        default:
-               dev_err(adap->pdev_dev, "%s: filter creation PROBLEM; status = %u\n",
-                       __func__, status);
+               if (status != CPL_ERR_TCAM_FULL)
+                       dev_err(adap->pdev_dev, "%s: filter creation PROBLEM; status = %u\n",
+                               __func__, status);
 
                if (ctx) {
                        if (status == CPL_ERR_TCAM_FULL)
-                               ctx->result = -EAGAIN;
+                               ctx->result = -ENOSPC;
                        else
                                ctx->result = -EINVAL;
                }
index 82a8d19..6e2d800 100644 (file)
@@ -687,11 +687,8 @@ int cxgb4_tc_flower_replace(struct net_device *dev,
 
        ret = ctx.result;
        /* Check if hw returned error for filter creation */
-       if (ret) {
-               netdev_err(dev, "%s: filter creation err %d\n",
-                          __func__, ret);
+       if (ret)
                goto free_entry;
-       }
 
        ch_flower->tc_flower_cookie = cls->cookie;
        ch_flower->filter_id = ctx.tid;