net/i40e: add QinQ filter create function
[dpdk.git] / drivers / net / enic / enic_clsf.c
index d2413d7..487f804 100644 (file)
@@ -155,7 +155,7 @@ copy_fltr_v2(struct filter_v2 *fltr, struct rte_eth_fdir_input *input,
                        udp_val.src_port = input->flow.udp4_flow.src_port;
                }
                if (input->flow.udp4_flow.dst_port) {
-                       udp_mask.src_port = masks->dst_port_mask;
+                       udp_mask.dst_port = masks->dst_port_mask;
                        udp_val.dst_port = input->flow.udp4_flow.dst_port;
                }
 
@@ -211,15 +211,15 @@ copy_fltr_v2(struct filter_v2 *fltr, struct rte_eth_fdir_input *input,
                memset(&ip4_val, 0, sizeof(struct ipv4_hdr));
 
                if (input->flow.ip4_flow.tos) {
-                       ip4_mask.type_of_service = 0xff;
+                       ip4_mask.type_of_service = masks->ipv4_mask.tos;
                        ip4_val.type_of_service = input->flow.ip4_flow.tos;
                }
                if (input->flow.ip4_flow.ttl) {
-                       ip4_mask.time_to_live = 0xff;
+                       ip4_mask.time_to_live = masks->ipv4_mask.ttl;
                        ip4_val.time_to_live = input->flow.ip4_flow.ttl;
                }
                if (input->flow.ip4_flow.proto) {
-                       ip4_mask.next_proto_id = 0xff;
+                       ip4_mask.next_proto_id = masks->ipv4_mask.proto;
                        ip4_val.next_proto_id = input->flow.ip4_flow.proto;
                }
                if (input->flow.ip4_flow.src_ip) {
@@ -299,7 +299,7 @@ copy_fltr_v2(struct filter_v2 *fltr, struct rte_eth_fdir_input *input,
                memset(&ipv6_val, 0, sizeof(struct ipv6_hdr));
 
                if (input->flow.ipv6_flow.proto) {
-                       ipv6_mask.proto = 0xff;
+                       ipv6_mask.proto = masks->ipv6_mask.proto;
                        ipv6_val.proto = input->flow.ipv6_flow.proto;
                }
                for (i = 0; i < 4; i++) {
@@ -315,11 +315,11 @@ copy_fltr_v2(struct filter_v2 *fltr, struct rte_eth_fdir_input *input,
                                        input->flow.ipv6_flow.dst_ip[i];
                }
                if (input->flow.ipv6_flow.tc) {
-                       ipv6_mask.vtc_flow = 0x00ff0000;
-                       ipv6_val.vtc_flow = input->flow.ipv6_flow.tc << 16;
+                       ipv6_mask.vtc_flow = masks->ipv6_mask.tc << 12;
+                       ipv6_val.vtc_flow = input->flow.ipv6_flow.tc << 12;
                }
                if (input->flow.ipv6_flow.hop_limits) {
-                       ipv6_mask.hop_limits = 0xff;
+                       ipv6_mask.hop_limits = masks->ipv6_mask.hop_limits;
                        ipv6_val.hop_limits = input->flow.ipv6_flow.hop_limits;
                }
 
@@ -382,7 +382,7 @@ int enic_fdir_add_fltr(struct enic *enic, struct rte_eth_fdir_filter *params)
        }
 
        /* Get the enicpmd RQ from the DPDK Rx queue */
-       queue = enic_sop_rq(params->action.rx_queue);
+       queue = enic_rte_rq_idx_to_sop_idx(params->action.rx_queue);
 
        if (!enic->rq[queue].in_use)
                return -EINVAL;