net: hns3: remove useless proto_support field in struct hclge_fd_cfg
authorGuojia Liao <liaoguojia@huawei.com>
Mon, 20 Apr 2020 02:17:29 +0000 (10:17 +0800)
committerDavid S. Miller <davem@davemloft.net>
Mon, 20 Apr 2020 19:49:17 +0000 (12:49 -0700)
proto_support field in struct hclge_fd_cfg shows what protocols
in flow direct table are supported now. It is unnecessary since
checking which one is unsupported will be more efficient,
so this patch removes it.

Signed-off-by: Guojia Liao <liaoguojia@huawei.com>
Signed-off-by: Huazhong Tan <tanhuazhong@huawei.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_main.c
drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_main.h

index 999f056..e238a9d 100644 (file)
@@ -4876,9 +4876,6 @@ static int hclge_init_fd_config(struct hclge_dev *hdev)
                return -EOPNOTSUPP;
        }
 
-       hdev->fd_cfg.proto_support =
-               TCP_V4_FLOW | UDP_V4_FLOW | SCTP_V4_FLOW | TCP_V6_FLOW |
-               UDP_V6_FLOW | SCTP_V6_FLOW | IPV4_USER_FLOW | IPV6_USER_FLOW;
        key_cfg = &hdev->fd_cfg.key_cfg[HCLGE_FD_STAGE_1];
        key_cfg->key_sel = HCLGE_FD_KEY_BASE_ON_TUPLE,
        key_cfg->inner_sipv6_word_en = LOW_2_WORDS;
@@ -4892,11 +4889,9 @@ static int hclge_init_fd_config(struct hclge_dev *hdev)
                                BIT(INNER_SRC_PORT) | BIT(INNER_DST_PORT);
 
        /* If use max 400bit key, we can support tuples for ether type */
-       if (hdev->fd_cfg.max_key_length == MAX_KEY_LENGTH) {
-               hdev->fd_cfg.proto_support |= ETHER_FLOW;
+       if (hdev->fd_cfg.fd_mode == HCLGE_FD_MODE_DEPTH_2K_WIDTH_400B_STAGE_1)
                key_cfg->tuple_active |=
                                BIT(INNER_DST_MAC) | BIT(INNER_SRC_MAC);
-       }
 
        /* roce_type is used to filter roce frames
         * dst_vport is used to specify the rule
@@ -5397,7 +5392,8 @@ static int hclge_fd_check_ext_tuple(struct hclge_dev *hdev,
        }
 
        if (fs->flow_type & FLOW_MAC_EXT) {
-               if (!(hdev->fd_cfg.proto_support & ETHER_FLOW))
+               if (hdev->fd_cfg.fd_mode !=
+                   HCLGE_FD_MODE_DEPTH_2K_WIDTH_400B_STAGE_1)
                        return -EOPNOTSUPP;
 
                if (is_zero_ether_addr(fs->h_ext.h_dest))
@@ -5413,21 +5409,20 @@ static int hclge_fd_check_spec(struct hclge_dev *hdev,
                               struct ethtool_rx_flow_spec *fs,
                               u32 *unused_tuple)
 {
+       u32 flow_type;
        int ret;
 
        if (fs->location >= hdev->fd_cfg.rule_num[HCLGE_FD_STAGE_1])
                return -EINVAL;
 
-       if (!(fs->flow_type & hdev->fd_cfg.proto_support))
-               return -EOPNOTSUPP;
-
        if ((fs->flow_type & FLOW_EXT) &&
            (fs->h_ext.data[0] != 0 || fs->h_ext.data[1] != 0)) {
                dev_err(&hdev->pdev->dev, "user-def bytes are not supported\n");
                return -EOPNOTSUPP;
        }
 
-       switch (fs->flow_type & ~(FLOW_EXT | FLOW_MAC_EXT)) {
+       flow_type = fs->flow_type & ~(FLOW_EXT | FLOW_MAC_EXT);
+       switch (flow_type) {
        case SCTP_V4_FLOW:
        case TCP_V4_FLOW:
        case UDP_V4_FLOW:
index 71df23d..a58c262 100644 (file)
@@ -580,7 +580,6 @@ struct hclge_fd_key_cfg {
 struct hclge_fd_cfg {
        u8 fd_mode;
        u16 max_key_length; /* use bit as unit */
-       u32 proto_support;
        u32 rule_num[MAX_STAGE_NUM]; /* rule entry number */
        u16 cnt_num[MAX_STAGE_NUM]; /* rule hit counter number */
        struct hclge_fd_key_cfg key_cfg[MAX_STAGE_NUM];