HNAE3_DEV_SUPPORT_CQ_B,
 };
 
-#define hnae3_dev_fd_supported(hdev) \
-       test_bit(HNAE3_DEV_SUPPORT_FD_B, (hdev)->ae_dev->caps)
+#define hnae3_ae_dev_fd_supported(ae_dev) \
+               test_bit(HNAE3_DEV_SUPPORT_FD_B, (ae_dev)->caps)
 
-#define hnae3_dev_gro_supported(hdev) \
-       test_bit(HNAE3_DEV_SUPPORT_GRO_B, (hdev)->ae_dev->caps)
+#define hnae3_ae_dev_gro_supported(ae_dev) \
+               test_bit(HNAE3_DEV_SUPPORT_GRO_B, (ae_dev)->caps)
 
 #define hnae3_dev_fec_supported(hdev) \
        test_bit(HNAE3_DEV_SUPPORT_FEC_B, (hdev)->ae_dev->caps)
 
 static void hclge_comm_set_default_capability(struct hnae3_ae_dev *ae_dev,
                                              bool is_pf)
 {
-       set_bit(HNAE3_DEV_SUPPORT_FD_B, ae_dev->caps);
        set_bit(HNAE3_DEV_SUPPORT_GRO_B, ae_dev->caps);
-       if (is_pf && ae_dev->dev_version == HNAE3_DEVICE_VERSION_V2) {
+       if (is_pf) {
+               set_bit(HNAE3_DEV_SUPPORT_FD_B, ae_dev->caps);
                set_bit(HNAE3_DEV_SUPPORT_FEC_B, ae_dev->caps);
                set_bit(HNAE3_DEV_SUPPORT_PAUSE_B, ae_dev->caps);
        }
         HNAE3_DEV_SUPPORT_PORT_VLAN_BYPASS_B},
        {HCLGE_COMM_CAP_PORT_VLAN_BYPASS_B, HNAE3_DEV_SUPPORT_VLAN_FLTR_MDF_B},
        {HCLGE_COMM_CAP_CQ_B, HNAE3_DEV_SUPPORT_CQ_B},
+       {HCLGE_COMM_CAP_GRO_B, HNAE3_DEV_SUPPORT_GRO_B},
+       {HCLGE_COMM_CAP_FD_B, HNAE3_DEV_SUPPORT_FD_B},
 };
 
 static const struct hclge_comm_caps_bit_map hclge_vf_cmd_caps[] = {
        {HCLGE_COMM_CAP_TX_PUSH_B, HNAE3_DEV_SUPPORT_TX_PUSH_B},
        {HCLGE_COMM_CAP_RXD_ADV_LAYOUT_B, HNAE3_DEV_SUPPORT_RXD_ADV_LAYOUT_B},
        {HCLGE_COMM_CAP_CQ_B, HNAE3_DEV_SUPPORT_CQ_B},
+       {HCLGE_COMM_CAP_GRO_B, HNAE3_DEV_SUPPORT_GRO_B},
 };
 
 static void
                                         HNAE3_PCI_REVISION_BIT_SIZE;
        ae_dev->dev_version |= ae_dev->pdev->revision;
 
-       if (ae_dev->dev_version >= HNAE3_DEVICE_VERSION_V2)
+       if (ae_dev->dev_version == HNAE3_DEVICE_VERSION_V2) {
                hclge_comm_set_default_capability(ae_dev, is_pf);
+               return 0;
+       }
 
        hclge_comm_parse_capability(ae_dev, is_pf, resp);
 
 
        HCLGE_COMM_CAP_RXD_ADV_LAYOUT_B = 15,
        HCLGE_COMM_CAP_PORT_VLAN_BYPASS_B = 17,
        HCLGE_COMM_CAP_CQ_B = 18,
+       HCLGE_COMM_CAP_GRO_B = 20,
+       HCLGE_COMM_CAP_FD_B = 21,
 };
 
 enum HCLGE_COMM_API_CAP_BITS {
 
                NETIF_F_GSO_GRE_CSUM | NETIF_F_GSO_UDP_TUNNEL |
                NETIF_F_SCTP_CRC | NETIF_F_FRAGLIST;
 
-       if (ae_dev->dev_version >= HNAE3_DEVICE_VERSION_V2) {
+       if (hnae3_ae_dev_gro_supported(ae_dev))
                netdev->features |= NETIF_F_GRO_HW;
 
-               if (!(h->flags & HNAE3_SUPPORT_VF))
-                       netdev->features |= NETIF_F_NTUPLE;
-       }
+       if (hnae3_ae_dev_fd_supported(ae_dev))
+               netdev->features |= NETIF_F_NTUPLE;
 
        if (test_bit(HNAE3_DEV_SUPPORT_UDP_GSO_B, ae_dev->caps))
                netdev->features |= NETIF_F_GSO_UDP_L4;
 
        char *tcam_buf;
        int pos = 0;
 
-       if (!hnae3_dev_fd_supported(hdev)) {
+       if (!hnae3_ae_dev_fd_supported(hdev->ae_dev)) {
                dev_err(&hdev->pdev->dev,
                        "Only FD-supported dev supports dump fd tcam\n");
                return -EOPNOTSUPP;
        u64 cnt;
        u8 i;
 
+       if (!hnae3_ae_dev_fd_supported(hdev->ae_dev))
+               return -EOPNOTSUPP;
+
        pos += scnprintf(buf + pos, len - pos,
                         "func_id\thit_times\n");
 
 
        if (cfg.vlan_fliter_cap == HCLGE_VLAN_FLTR_CAN_MDF)
                set_bit(HNAE3_DEV_SUPPORT_VLAN_FLTR_MDF_B, ae_dev->caps);
 
-       if (hnae3_dev_fd_supported(hdev)) {
+       if (hnae3_ae_dev_fd_supported(hdev->ae_dev)) {
                hdev->fd_en = true;
                hdev->fd_active_type = HCLGE_FD_RULE_NONE;
        }
        struct hclge_desc desc;
        int ret;
 
-       if (!hnae3_dev_gro_supported(hdev))
+       if (!hnae3_ae_dev_gro_supported(hdev->ae_dev))
                return 0;
 
        hclge_cmd_setup_basic_desc(&desc, HCLGE_OPC_GRO_GENERIC_CONFIG, false);
        struct hclge_fd_key_cfg *key_cfg;
        int ret;
 
-       if (!hnae3_dev_fd_supported(hdev))
+       if (!hnae3_ae_dev_fd_supported(hdev->ae_dev))
                return 0;
 
        ret = hclge_get_fd_mode(hdev, &hdev->fd_cfg.fd_mode);
        u8 action;
        int ret;
 
-       if (!hnae3_dev_fd_supported(hdev)) {
+       if (!hnae3_ae_dev_fd_supported(hdev->ae_dev)) {
                dev_err(&hdev->pdev->dev,
                        "flow table director is not supported\n");
                return -EOPNOTSUPP;
        struct ethtool_rx_flow_spec *fs;
        int ret;
 
-       if (!hnae3_dev_fd_supported(hdev))
+       if (!hnae3_ae_dev_fd_supported(hdev->ae_dev))
                return -EOPNOTSUPP;
 
        fs = (struct ethtool_rx_flow_spec *)&cmd->fs;
        struct hlist_node *node;
        u16 location;
 
-       if (!hnae3_dev_fd_supported(hdev))
+       if (!hnae3_ae_dev_fd_supported(hdev->ae_dev))
                return;
 
        spin_lock_bh(&hdev->fd_rule_lock);
         * return value. If error is returned here, the reset process will
         * fail.
         */
-       if (!hnae3_dev_fd_supported(hdev))
+       if (!hnae3_ae_dev_fd_supported(hdev->ae_dev))
                return 0;
 
        /* if fd is disabled, should not restore it when reset */
        struct hclge_vport *vport = hclge_get_vport(handle);
        struct hclge_dev *hdev = vport->back;
 
-       if (!hnae3_dev_fd_supported(hdev) || hclge_is_cls_flower_active(handle))
+       if (!hnae3_ae_dev_fd_supported(hdev->ae_dev) || hclge_is_cls_flower_active(handle))
                return -EOPNOTSUPP;
 
        cmd->rule_cnt = hdev->hclge_fd_rule_num;
        struct hclge_dev *hdev = vport->back;
        struct ethtool_rx_flow_spec *fs;
 
-       if (!hnae3_dev_fd_supported(hdev))
+       if (!hnae3_ae_dev_fd_supported(hdev->ae_dev))
                return -EOPNOTSUPP;
 
        fs = (struct ethtool_rx_flow_spec *)&cmd->fs;
        struct hlist_node *node2;
        int cnt = 0;
 
-       if (!hnae3_dev_fd_supported(hdev))
+       if (!hnae3_ae_dev_fd_supported(hdev->ae_dev))
                return -EOPNOTSUPP;
 
        cmd->data = hdev->fd_cfg.rule_num[HCLGE_FD_STAGE_1];
        struct hclge_fd_rule *rule;
        u16 bit_id;
 
-       if (!hnae3_dev_fd_supported(hdev))
+       if (!hnae3_ae_dev_fd_supported(hdev->ae_dev))
                return -EOPNOTSUPP;
 
        /* when there is already fd rule existed add by user,
        struct hclge_fd_rule *rule;
        int ret;
 
+       if (!hnae3_ae_dev_fd_supported(hdev->ae_dev)) {
+               dev_err(&hdev->pdev->dev,
+                       "cls flower is not supported\n");
+               return -EOPNOTSUPP;
+       }
+
        ret = hclge_check_cls_flower(hdev, cls_flower, tc);
        if (ret) {
                dev_err(&hdev->pdev->dev,
        struct hclge_fd_rule *rule;
        int ret;
 
+       if (!hnae3_ae_dev_fd_supported(hdev->ae_dev))
+               return -EOPNOTSUPP;
+
        spin_lock_bh(&hdev->fd_rule_lock);
 
        rule = hclge_find_cls_flower(hdev, cls_flower->cookie);
 
        struct hclge_desc desc;
        int ret;
 
-       if (!hnae3_dev_gro_supported(hdev))
+       if (!hnae3_ae_dev_gro_supported(hdev->ae_dev))
                return 0;
 
        hclgevf_cmd_setup_basic_desc(&desc, HCLGE_OPC_GRO_GENERIC_CONFIG,