Lines Matching refs:spec

695 	struct efx_filter_spec spec;  in efx_ethtool_get_class_rule()  local
699 rule->location, &spec); in efx_ethtool_get_class_rule()
703 if (spec.dmaq_id == EFX_FILTER_RX_DMAQ_ID_DROP) in efx_ethtool_get_class_rule()
706 rule->ring_cookie = spec.dmaq_id; in efx_ethtool_get_class_rule()
708 if ((spec.match_flags & EFX_FILTER_MATCH_ETHER_TYPE) && in efx_ethtool_get_class_rule()
709 spec.ether_type == htons(ETH_P_IP) && in efx_ethtool_get_class_rule()
710 (spec.match_flags & EFX_FILTER_MATCH_IP_PROTO) && in efx_ethtool_get_class_rule()
711 (spec.ip_proto == IPPROTO_TCP || spec.ip_proto == IPPROTO_UDP) && in efx_ethtool_get_class_rule()
712 !(spec.match_flags & in efx_ethtool_get_class_rule()
717 rule->flow_type = ((spec.ip_proto == IPPROTO_TCP) ? in efx_ethtool_get_class_rule()
719 if (spec.match_flags & EFX_FILTER_MATCH_LOC_HOST) { in efx_ethtool_get_class_rule()
720 ip_entry->ip4dst = spec.loc_host[0]; in efx_ethtool_get_class_rule()
723 if (spec.match_flags & EFX_FILTER_MATCH_REM_HOST) { in efx_ethtool_get_class_rule()
724 ip_entry->ip4src = spec.rem_host[0]; in efx_ethtool_get_class_rule()
727 if (spec.match_flags & EFX_FILTER_MATCH_LOC_PORT) { in efx_ethtool_get_class_rule()
728 ip_entry->pdst = spec.loc_port; in efx_ethtool_get_class_rule()
731 if (spec.match_flags & EFX_FILTER_MATCH_REM_PORT) { in efx_ethtool_get_class_rule()
732 ip_entry->psrc = spec.rem_port; in efx_ethtool_get_class_rule()
735 } else if ((spec.match_flags & EFX_FILTER_MATCH_ETHER_TYPE) && in efx_ethtool_get_class_rule()
736 spec.ether_type == htons(ETH_P_IPV6) && in efx_ethtool_get_class_rule()
737 (spec.match_flags & EFX_FILTER_MATCH_IP_PROTO) && in efx_ethtool_get_class_rule()
738 (spec.ip_proto == IPPROTO_TCP || spec.ip_proto == IPPROTO_UDP) && in efx_ethtool_get_class_rule()
739 !(spec.match_flags & in efx_ethtool_get_class_rule()
744 rule->flow_type = ((spec.ip_proto == IPPROTO_TCP) ? in efx_ethtool_get_class_rule()
746 if (spec.match_flags & EFX_FILTER_MATCH_LOC_HOST) { in efx_ethtool_get_class_rule()
747 memcpy(ip6_entry->ip6dst, spec.loc_host, in efx_ethtool_get_class_rule()
751 if (spec.match_flags & EFX_FILTER_MATCH_REM_HOST) { in efx_ethtool_get_class_rule()
752 memcpy(ip6_entry->ip6src, spec.rem_host, in efx_ethtool_get_class_rule()
756 if (spec.match_flags & EFX_FILTER_MATCH_LOC_PORT) { in efx_ethtool_get_class_rule()
757 ip6_entry->pdst = spec.loc_port; in efx_ethtool_get_class_rule()
760 if (spec.match_flags & EFX_FILTER_MATCH_REM_PORT) { in efx_ethtool_get_class_rule()
761 ip6_entry->psrc = spec.rem_port; in efx_ethtool_get_class_rule()
764 } else if (!(spec.match_flags & in efx_ethtool_get_class_rule()
769 if (spec.match_flags & in efx_ethtool_get_class_rule()
771 ether_addr_copy(mac_entry->h_dest, spec.loc_mac); in efx_ethtool_get_class_rule()
772 if (spec.match_flags & EFX_FILTER_MATCH_LOC_MAC) in efx_ethtool_get_class_rule()
778 if (spec.match_flags & EFX_FILTER_MATCH_REM_MAC) { in efx_ethtool_get_class_rule()
779 ether_addr_copy(mac_entry->h_source, spec.rem_mac); in efx_ethtool_get_class_rule()
782 if (spec.match_flags & EFX_FILTER_MATCH_ETHER_TYPE) { in efx_ethtool_get_class_rule()
783 mac_entry->h_proto = spec.ether_type; in efx_ethtool_get_class_rule()
786 } else if (spec.match_flags & EFX_FILTER_MATCH_ETHER_TYPE && in efx_ethtool_get_class_rule()
787 spec.ether_type == htons(ETH_P_IP) && in efx_ethtool_get_class_rule()
788 !(spec.match_flags & in efx_ethtool_get_class_rule()
794 if (spec.match_flags & EFX_FILTER_MATCH_IP_PROTO) { in efx_ethtool_get_class_rule()
796 uip_entry->proto = spec.ip_proto; in efx_ethtool_get_class_rule()
798 if (spec.match_flags & EFX_FILTER_MATCH_LOC_HOST) { in efx_ethtool_get_class_rule()
799 uip_entry->ip4dst = spec.loc_host[0]; in efx_ethtool_get_class_rule()
802 if (spec.match_flags & EFX_FILTER_MATCH_REM_HOST) { in efx_ethtool_get_class_rule()
803 uip_entry->ip4src = spec.rem_host[0]; in efx_ethtool_get_class_rule()
806 } else if (spec.match_flags & EFX_FILTER_MATCH_ETHER_TYPE && in efx_ethtool_get_class_rule()
807 spec.ether_type == htons(ETH_P_IPV6) && in efx_ethtool_get_class_rule()
808 !(spec.match_flags & in efx_ethtool_get_class_rule()
813 if (spec.match_flags & EFX_FILTER_MATCH_IP_PROTO) { in efx_ethtool_get_class_rule()
815 uip6_entry->l4_proto = spec.ip_proto; in efx_ethtool_get_class_rule()
817 if (spec.match_flags & EFX_FILTER_MATCH_LOC_HOST) { in efx_ethtool_get_class_rule()
818 memcpy(uip6_entry->ip6dst, spec.loc_host, in efx_ethtool_get_class_rule()
822 if (spec.match_flags & EFX_FILTER_MATCH_REM_HOST) { in efx_ethtool_get_class_rule()
823 memcpy(uip6_entry->ip6src, spec.rem_host, in efx_ethtool_get_class_rule()
833 if (spec.match_flags & EFX_FILTER_MATCH_OUTER_VID) { in efx_ethtool_get_class_rule()
835 rule->h_ext.vlan_tci = spec.outer_vid; in efx_ethtool_get_class_rule()
839 if (spec.flags & EFX_FILTER_FLAG_RX_RSS) { in efx_ethtool_get_class_rule()
841 *rss_context = spec.rss_context; in efx_ethtool_get_class_rule()
969 struct efx_filter_spec spec; in efx_ethtool_set_class_rule() local
992 efx_filter_init_rx(&spec, EFX_FILTER_PRI_MANUAL, flags, in efx_ethtool_set_class_rule()
997 spec.rss_context = rss_context; in efx_ethtool_set_class_rule()
1002 spec.match_flags = (EFX_FILTER_MATCH_ETHER_TYPE | in efx_ethtool_set_class_rule()
1004 spec.ether_type = htons(ETH_P_IP); in efx_ethtool_set_class_rule()
1005 spec.ip_proto = flow_type == TCP_V4_FLOW ? IPPROTO_TCP in efx_ethtool_set_class_rule()
1010 spec.match_flags |= EFX_FILTER_MATCH_LOC_HOST; in efx_ethtool_set_class_rule()
1011 spec.loc_host[0] = ip_entry->ip4dst; in efx_ethtool_set_class_rule()
1016 spec.match_flags |= EFX_FILTER_MATCH_REM_HOST; in efx_ethtool_set_class_rule()
1017 spec.rem_host[0] = ip_entry->ip4src; in efx_ethtool_set_class_rule()
1022 spec.match_flags |= EFX_FILTER_MATCH_LOC_PORT; in efx_ethtool_set_class_rule()
1023 spec.loc_port = ip_entry->pdst; in efx_ethtool_set_class_rule()
1028 spec.match_flags |= EFX_FILTER_MATCH_REM_PORT; in efx_ethtool_set_class_rule()
1029 spec.rem_port = ip_entry->psrc; in efx_ethtool_set_class_rule()
1037 spec.match_flags = (EFX_FILTER_MATCH_ETHER_TYPE | in efx_ethtool_set_class_rule()
1039 spec.ether_type = htons(ETH_P_IPV6); in efx_ethtool_set_class_rule()
1040 spec.ip_proto = flow_type == TCP_V6_FLOW ? IPPROTO_TCP in efx_ethtool_set_class_rule()
1045 spec.match_flags |= EFX_FILTER_MATCH_LOC_HOST; in efx_ethtool_set_class_rule()
1046 memcpy(spec.loc_host, ip6_entry->ip6dst, sizeof(spec.loc_host)); in efx_ethtool_set_class_rule()
1051 spec.match_flags |= EFX_FILTER_MATCH_REM_HOST; in efx_ethtool_set_class_rule()
1052 memcpy(spec.rem_host, ip6_entry->ip6src, sizeof(spec.rem_host)); in efx_ethtool_set_class_rule()
1057 spec.match_flags |= EFX_FILTER_MATCH_LOC_PORT; in efx_ethtool_set_class_rule()
1058 spec.loc_port = ip6_entry->pdst; in efx_ethtool_set_class_rule()
1063 spec.match_flags |= EFX_FILTER_MATCH_REM_PORT; in efx_ethtool_set_class_rule()
1064 spec.rem_port = ip6_entry->psrc; in efx_ethtool_set_class_rule()
1074 spec.match_flags = EFX_FILTER_MATCH_ETHER_TYPE; in efx_ethtool_set_class_rule()
1075 spec.ether_type = htons(ETH_P_IP); in efx_ethtool_set_class_rule()
1079 spec.match_flags |= EFX_FILTER_MATCH_LOC_HOST; in efx_ethtool_set_class_rule()
1080 spec.loc_host[0] = uip_entry->ip4dst; in efx_ethtool_set_class_rule()
1085 spec.match_flags |= EFX_FILTER_MATCH_REM_HOST; in efx_ethtool_set_class_rule()
1086 spec.rem_host[0] = uip_entry->ip4src; in efx_ethtool_set_class_rule()
1091 spec.match_flags |= EFX_FILTER_MATCH_IP_PROTO; in efx_ethtool_set_class_rule()
1092 spec.ip_proto = uip_entry->proto; in efx_ethtool_set_class_rule()
1099 spec.match_flags = EFX_FILTER_MATCH_ETHER_TYPE; in efx_ethtool_set_class_rule()
1100 spec.ether_type = htons(ETH_P_IPV6); in efx_ethtool_set_class_rule()
1104 spec.match_flags |= EFX_FILTER_MATCH_LOC_HOST; in efx_ethtool_set_class_rule()
1105 memcpy(spec.loc_host, uip6_entry->ip6dst, sizeof(spec.loc_host)); in efx_ethtool_set_class_rule()
1110 spec.match_flags |= EFX_FILTER_MATCH_REM_HOST; in efx_ethtool_set_class_rule()
1111 memcpy(spec.rem_host, uip6_entry->ip6src, sizeof(spec.rem_host)); in efx_ethtool_set_class_rule()
1116 spec.match_flags |= EFX_FILTER_MATCH_IP_PROTO; in efx_ethtool_set_class_rule()
1117 spec.ip_proto = uip6_entry->l4_proto; in efx_ethtool_set_class_rule()
1125 spec.match_flags |= EFX_FILTER_MATCH_LOC_MAC_IG; in efx_ethtool_set_class_rule()
1127 spec.match_flags |= EFX_FILTER_MATCH_LOC_MAC; in efx_ethtool_set_class_rule()
1130 ether_addr_copy(spec.loc_mac, mac_entry->h_dest); in efx_ethtool_set_class_rule()
1135 spec.match_flags |= EFX_FILTER_MATCH_REM_MAC; in efx_ethtool_set_class_rule()
1136 ether_addr_copy(spec.rem_mac, mac_entry->h_source); in efx_ethtool_set_class_rule()
1141 spec.match_flags |= EFX_FILTER_MATCH_ETHER_TYPE; in efx_ethtool_set_class_rule()
1142 spec.ether_type = mac_entry->h_proto; in efx_ethtool_set_class_rule()
1153 spec.match_flags |= EFX_FILTER_MATCH_OUTER_VID; in efx_ethtool_set_class_rule()
1154 spec.outer_vid = rule->h_ext.vlan_tci; in efx_ethtool_set_class_rule()
1157 rc = efx_filter_insert_filter(efx, &spec, true); in efx_ethtool_set_class_rule()