ethdev: add namespace
[dpdk.git] / drivers / net / qede / qede_filter.c
index 283e732..4404404 100644 (file)
@@ -20,97 +20,97 @@ const struct _qede_udp_tunn_types {
        const char *string;
 } qede_tunn_types[] = {
        {
-               ETH_TUNNEL_FILTER_OMAC,
+               RTE_ETH_TUNNEL_FILTER_OMAC,
                ECORE_FILTER_MAC,
                ECORE_TUNN_CLSS_MAC_VLAN,
                "outer-mac"
        },
        {
-               ETH_TUNNEL_FILTER_TENID,
+               RTE_ETH_TUNNEL_FILTER_TENID,
                ECORE_FILTER_VNI,
                ECORE_TUNN_CLSS_MAC_VNI,
                "vni"
        },
        {
-               ETH_TUNNEL_FILTER_IMAC,
+               RTE_ETH_TUNNEL_FILTER_IMAC,
                ECORE_FILTER_INNER_MAC,
                ECORE_TUNN_CLSS_INNER_MAC_VLAN,
                "inner-mac"
        },
        {
-               ETH_TUNNEL_FILTER_IVLAN,
+               RTE_ETH_TUNNEL_FILTER_IVLAN,
                ECORE_FILTER_INNER_VLAN,
                ECORE_TUNN_CLSS_INNER_MAC_VLAN,
                "inner-vlan"
        },
        {
-               ETH_TUNNEL_FILTER_OMAC | ETH_TUNNEL_FILTER_TENID,
+               RTE_ETH_TUNNEL_FILTER_OMAC | RTE_ETH_TUNNEL_FILTER_TENID,
                ECORE_FILTER_MAC_VNI_PAIR,
                ECORE_TUNN_CLSS_MAC_VNI,
                "outer-mac and vni"
        },
        {
-               ETH_TUNNEL_FILTER_OMAC | ETH_TUNNEL_FILTER_IMAC,
+               RTE_ETH_TUNNEL_FILTER_OMAC | RTE_ETH_TUNNEL_FILTER_IMAC,
                ECORE_FILTER_UNUSED,
                MAX_ECORE_TUNN_CLSS,
                "outer-mac and inner-mac"
        },
        {
-               ETH_TUNNEL_FILTER_OMAC | ETH_TUNNEL_FILTER_IVLAN,
+               RTE_ETH_TUNNEL_FILTER_OMAC | RTE_ETH_TUNNEL_FILTER_IVLAN,
                ECORE_FILTER_UNUSED,
                MAX_ECORE_TUNN_CLSS,
                "outer-mac and inner-vlan"
        },
        {
-               ETH_TUNNEL_FILTER_TENID | ETH_TUNNEL_FILTER_IMAC,
+               RTE_ETH_TUNNEL_FILTER_TENID | RTE_ETH_TUNNEL_FILTER_IMAC,
                ECORE_FILTER_INNER_MAC_VNI_PAIR,
                ECORE_TUNN_CLSS_INNER_MAC_VNI,
                "vni and inner-mac",
        },
        {
-               ETH_TUNNEL_FILTER_TENID | ETH_TUNNEL_FILTER_IVLAN,
+               RTE_ETH_TUNNEL_FILTER_TENID | RTE_ETH_TUNNEL_FILTER_IVLAN,
                ECORE_FILTER_UNUSED,
                MAX_ECORE_TUNN_CLSS,
                "vni and inner-vlan",
        },
        {
-               ETH_TUNNEL_FILTER_IMAC | ETH_TUNNEL_FILTER_IVLAN,
+               RTE_ETH_TUNNEL_FILTER_IMAC | RTE_ETH_TUNNEL_FILTER_IVLAN,
                ECORE_FILTER_INNER_PAIR,
                ECORE_TUNN_CLSS_INNER_MAC_VLAN,
                "inner-mac and inner-vlan",
        },
        {
-               ETH_TUNNEL_FILTER_OIP,
+               RTE_ETH_TUNNEL_FILTER_OIP,
                ECORE_FILTER_UNUSED,
                MAX_ECORE_TUNN_CLSS,
                "outer-IP"
        },
        {
-               ETH_TUNNEL_FILTER_IIP,
+               RTE_ETH_TUNNEL_FILTER_IIP,
                ECORE_FILTER_UNUSED,
                MAX_ECORE_TUNN_CLSS,
                "inner-IP"
        },
        {
-               RTE_TUNNEL_FILTER_IMAC_IVLAN,
+               RTE_ETH_TUNNEL_FILTER_IMAC_IVLAN,
                ECORE_FILTER_UNUSED,
                MAX_ECORE_TUNN_CLSS,
                "IMAC_IVLAN"
        },
        {
-               RTE_TUNNEL_FILTER_IMAC_IVLAN_TENID,
+               RTE_ETH_TUNNEL_FILTER_IMAC_IVLAN_TENID,
                ECORE_FILTER_UNUSED,
                MAX_ECORE_TUNN_CLSS,
                "IMAC_IVLAN_TENID"
        },
        {
-               RTE_TUNNEL_FILTER_IMAC_TENID,
+               RTE_ETH_TUNNEL_FILTER_IMAC_TENID,
                ECORE_FILTER_UNUSED,
                MAX_ECORE_TUNN_CLSS,
                "IMAC_TENID"
        },
        {
-               RTE_TUNNEL_FILTER_OMAC_TENID_IMAC,
+               RTE_ETH_TUNNEL_FILTER_OMAC_TENID_IMAC,
                ECORE_FILTER_UNUSED,
                MAX_ECORE_TUNN_CLSS,
                "OMAC_TENID_IMAC"
@@ -130,14 +130,6 @@ const struct _qede_udp_tunn_types {
  */
 #define QEDE_MAX_FDIR_PKT_LEN                  (86)
 
-static inline bool qede_valid_flow(uint16_t flow_type)
-{
-       return  ((flow_type == RTE_ETH_FLOW_NONFRAG_IPV4_TCP) ||
-                (flow_type == RTE_ETH_FLOW_NONFRAG_IPV4_UDP) ||
-                (flow_type == RTE_ETH_FLOW_NONFRAG_IPV6_TCP) ||
-                (flow_type == RTE_ETH_FLOW_NONFRAG_IPV6_UDP));
-}
-
 static uint16_t
 qede_arfs_construct_pkt(struct rte_eth_dev *eth_dev,
                        struct qede_arfs_entry *arfs,
@@ -152,7 +144,7 @@ int qede_check_fdir_support(struct rte_eth_dev *eth_dev)
 {
        struct qede_dev *qdev = QEDE_INIT_QDEV(eth_dev);
        struct ecore_dev *edev = QEDE_INIT_EDEV(qdev);
-       struct rte_fdir_conf *fdir = &eth_dev->data->dev_conf.fdir_conf;
+       struct rte_eth_fdir_conf *fdir = &eth_dev->data->dev_conf.fdir_conf;
 
        /* check FDIR modes */
        switch (fdir->mode) {
@@ -197,74 +189,6 @@ void qede_fdir_dealloc_resc(struct rte_eth_dev *eth_dev)
        }
 }
 
-static int
-qede_fdir_to_arfs_filter(struct rte_eth_dev *eth_dev,
-                        struct rte_eth_fdir_filter *fdir,
-                        struct qede_arfs_entry *arfs)
-{
-       struct qede_dev *qdev = QEDE_INIT_QDEV(eth_dev);
-       struct ecore_dev *edev = QEDE_INIT_EDEV(qdev);
-       struct rte_eth_fdir_input *input;
-
-       static const uint8_t next_proto[] = {
-               [RTE_ETH_FLOW_NONFRAG_IPV4_TCP] = IPPROTO_TCP,
-               [RTE_ETH_FLOW_NONFRAG_IPV4_UDP] = IPPROTO_UDP,
-               [RTE_ETH_FLOW_NONFRAG_IPV6_TCP] = IPPROTO_TCP,
-               [RTE_ETH_FLOW_NONFRAG_IPV6_UDP] = IPPROTO_UDP,
-       };
-
-       input = &fdir->input;
-
-       DP_INFO(edev, "flow_type %d\n", input->flow_type);
-
-       switch (input->flow_type) {
-       case RTE_ETH_FLOW_NONFRAG_IPV4_TCP:
-       case RTE_ETH_FLOW_NONFRAG_IPV4_UDP:
-               /* fill the common ip header */
-               arfs->tuple.eth_proto = RTE_ETHER_TYPE_IPV4;
-               arfs->tuple.dst_ipv4 = input->flow.ip4_flow.dst_ip;
-               arfs->tuple.src_ipv4 = input->flow.ip4_flow.src_ip;
-               arfs->tuple.ip_proto = next_proto[input->flow_type];
-
-               /* UDP */
-               if (input->flow_type == RTE_ETH_FLOW_NONFRAG_IPV4_UDP) {
-                       arfs->tuple.dst_port = input->flow.udp4_flow.dst_port;
-                       arfs->tuple.src_port = input->flow.udp4_flow.src_port;
-               } else { /* TCP */
-                       arfs->tuple.dst_port = input->flow.tcp4_flow.dst_port;
-                       arfs->tuple.src_port = input->flow.tcp4_flow.src_port;
-               }
-               break;
-       case RTE_ETH_FLOW_NONFRAG_IPV6_TCP:
-       case RTE_ETH_FLOW_NONFRAG_IPV6_UDP:
-               arfs->tuple.eth_proto = RTE_ETHER_TYPE_IPV6;
-               arfs->tuple.ip_proto = next_proto[input->flow_type];
-               rte_memcpy(arfs->tuple.dst_ipv6,
-                          &input->flow.ipv6_flow.dst_ip,
-                          IPV6_ADDR_LEN);
-               rte_memcpy(arfs->tuple.src_ipv6,
-                          &input->flow.ipv6_flow.src_ip,
-                          IPV6_ADDR_LEN);
-
-               /* UDP */
-               if (input->flow_type == RTE_ETH_FLOW_NONFRAG_IPV6_UDP) {
-                       arfs->tuple.dst_port = input->flow.udp6_flow.dst_port;
-                       arfs->tuple.src_port = input->flow.udp6_flow.src_port;
-               } else { /* TCP */
-                       arfs->tuple.dst_port = input->flow.tcp6_flow.dst_port;
-                       arfs->tuple.src_port = input->flow.tcp6_flow.src_port;
-               }
-               break;
-       default:
-               DP_ERR(edev, "Unsupported flow_type %u\n",
-                      input->flow_type);
-               return -ENOTSUP;
-       }
-
-       arfs->rx_queue = fdir->action.rx_queue;
-       return 0;
-}
-
 static int
 qede_config_arfs_filter(struct rte_eth_dev *eth_dev,
                        struct qede_arfs_entry *arfs,
@@ -397,61 +321,6 @@ err1:
        return rc;
 }
 
-static int
-qede_config_cmn_fdir_filter(struct rte_eth_dev *eth_dev,
-                           struct rte_eth_fdir_filter *fdir_filter,
-                           bool add)
-{
-       struct qede_dev *qdev = QEDE_INIT_QDEV(eth_dev);
-       struct ecore_dev *edev = QEDE_INIT_EDEV(qdev);
-       struct qede_arfs_entry *arfs = NULL;
-       int rc = 0;
-
-       arfs = rte_malloc(NULL, sizeof(struct qede_arfs_entry),
-                                 RTE_CACHE_LINE_SIZE);
-       if (!arfs) {
-               DP_ERR(edev, "Did not allocate memory for arfs\n");
-               return -ENOMEM;
-       }
-
-       rc = qede_fdir_to_arfs_filter(eth_dev, fdir_filter, arfs);
-       if (rc < 0)
-               return rc;
-
-       rc = qede_config_arfs_filter(eth_dev, arfs, add);
-       if (rc < 0)
-               rte_free(arfs);
-
-       return rc;
-}
-
-static int
-qede_fdir_filter_add(struct rte_eth_dev *eth_dev,
-                    struct rte_eth_fdir_filter *fdir,
-                    bool add)
-{
-       struct qede_dev *qdev = QEDE_INIT_QDEV(eth_dev);
-       struct ecore_dev *edev = QEDE_INIT_EDEV(qdev);
-
-       if (!qede_valid_flow(fdir->input.flow_type)) {
-               DP_ERR(edev, "invalid flow_type input\n");
-               return -EINVAL;
-       }
-
-       if (fdir->action.rx_queue >= QEDE_RSS_COUNT(eth_dev)) {
-               DP_ERR(edev, "invalid queue number %u\n",
-                      fdir->action.rx_queue);
-               return -EINVAL;
-       }
-
-       if (fdir->input.flow_ext.is_vf) {
-               DP_ERR(edev, "flowdir is not supported over VF\n");
-               return -EINVAL;
-       }
-
-       return qede_config_cmn_fdir_filter(eth_dev, fdir, add);
-}
-
 /* Fills the L3/L4 headers and returns the actual length  of flowdir packet */
 static uint16_t
 qede_arfs_construct_pkt(struct rte_eth_dev *eth_dev,
@@ -552,44 +421,6 @@ qede_arfs_construct_pkt(struct rte_eth_dev *eth_dev,
        return len;
 }
 
-static int
-qede_fdir_filter_conf(struct rte_eth_dev *eth_dev,
-                     enum rte_filter_op filter_op,
-                     void *arg)
-{
-       struct qede_dev *qdev = QEDE_INIT_QDEV(eth_dev);
-       struct ecore_dev *edev = QEDE_INIT_EDEV(qdev);
-       struct rte_eth_fdir_filter *fdir;
-       int ret;
-
-       fdir = (struct rte_eth_fdir_filter *)arg;
-       switch (filter_op) {
-       case RTE_ETH_FILTER_NOP:
-               /* Typically used to query flowdir support */
-               if (ECORE_IS_CMT(edev)) {
-                       DP_ERR(edev, "flowdir is not supported in 100G mode\n");
-                       return -ENOTSUP;
-               }
-               return 0; /* means supported */
-       case RTE_ETH_FILTER_ADD:
-               ret = qede_fdir_filter_add(eth_dev, fdir, 1);
-       break;
-       case RTE_ETH_FILTER_DELETE:
-               ret = qede_fdir_filter_add(eth_dev, fdir, 0);
-       break;
-       case RTE_ETH_FILTER_FLUSH:
-       case RTE_ETH_FILTER_UPDATE:
-       case RTE_ETH_FILTER_INFO:
-               return -ENOTSUP;
-       break;
-       default:
-               DP_ERR(edev, "unknown operation %u", filter_op);
-               ret = -EINVAL;
-       }
-
-       return ret;
-}
-
 static int
 qede_tunnel_update(struct qede_dev *qdev,
                   struct ecore_tunnel_info *tunn_info)
@@ -711,7 +542,7 @@ qede_udp_dst_port_del(struct rte_eth_dev *eth_dev,
        memset(&tunn, 0, sizeof(tunn));
 
        switch (tunnel_udp->prot_type) {
-       case RTE_TUNNEL_TYPE_VXLAN:
+       case RTE_ETH_TUNNEL_TYPE_VXLAN:
                if (qdev->vxlan.udp_port != tunnel_udp->udp_port) {
                        DP_ERR(edev, "UDP port %u doesn't exist\n",
                                tunnel_udp->udp_port);
@@ -739,7 +570,7 @@ qede_udp_dst_port_del(struct rte_eth_dev *eth_dev,
                                        ECORE_TUNN_CLSS_MAC_VLAN, false);
 
                break;
-       case RTE_TUNNEL_TYPE_GENEVE:
+       case RTE_ETH_TUNNEL_TYPE_GENEVE:
                if (qdev->geneve.udp_port != tunnel_udp->udp_port) {
                        DP_ERR(edev, "UDP port %u doesn't exist\n",
                                tunnel_udp->udp_port);
@@ -791,7 +622,7 @@ qede_udp_dst_port_add(struct rte_eth_dev *eth_dev,
        memset(&tunn, 0, sizeof(tunn));
 
        switch (tunnel_udp->prot_type) {
-       case RTE_TUNNEL_TYPE_VXLAN:
+       case RTE_ETH_TUNNEL_TYPE_VXLAN:
                if (qdev->vxlan.udp_port == tunnel_udp->udp_port) {
                        DP_INFO(edev,
                                "UDP port %u for VXLAN was already configured\n",
@@ -828,7 +659,7 @@ qede_udp_dst_port_add(struct rte_eth_dev *eth_dev,
 
                qdev->vxlan.udp_port = udp_port;
                break;
-       case RTE_TUNNEL_TYPE_GENEVE:
+       case RTE_ETH_TUNNEL_TYPE_GENEVE:
                if (qdev->geneve.udp_port == tunnel_udp->udp_port) {
                        DP_INFO(edev,
                                "UDP port %u for GENEVE was already configured\n",
@@ -1219,35 +1050,18 @@ const struct rte_flow_ops qede_flow_ops = {
        .flush = qede_flow_flush,
 };
 
-int qede_dev_filter_ctrl(struct rte_eth_dev *eth_dev,
-                        enum rte_filter_type filter_type,
-                        enum rte_filter_op filter_op,
-                        void *arg)
+int
+qede_dev_flow_ops_get(struct rte_eth_dev *eth_dev,
+                     const struct rte_flow_ops **ops)
 {
        struct qede_dev *qdev = QEDE_INIT_QDEV(eth_dev);
        struct ecore_dev *edev = QEDE_INIT_EDEV(qdev);
 
-       switch (filter_type) {
-       case RTE_ETH_FILTER_FDIR:
-               return qede_fdir_filter_conf(eth_dev, filter_op, arg);
-       case RTE_ETH_FILTER_GENERIC:
-               if (ECORE_IS_CMT(edev)) {
-                       DP_ERR(edev, "flowdir is not supported in 100G mode\n");
-                       return -ENOTSUP;
-               }
-
-               if (filter_op != RTE_ETH_FILTER_GET)
-                       return -EINVAL;
-
-               *(const void **)arg = &qede_flow_ops;
-               return 0;
-       case RTE_ETH_FILTER_L2_TUNNEL:
-       case RTE_ETH_FILTER_MAX:
-       default:
-               DP_ERR(edev, "Unsupported filter type %d\n",
-                       filter_type);
-               return -EINVAL;
+       if (ECORE_IS_CMT(edev)) {
+               DP_ERR(edev, "flowdir is not supported in 100G mode\n");
+               return -ENOTSUP;
        }
 
+       *ops = &qede_flow_ops;
        return 0;
 }