Lines Matching refs:spec

824 	struct efx_filter_spec spec;  in efx_ethtool_get_class_rule()  local
828 rule->location, &spec); in efx_ethtool_get_class_rule()
832 if (spec.dmaq_id == EFX_FILTER_RX_DMAQ_ID_DROP) in efx_ethtool_get_class_rule()
835 rule->ring_cookie = spec.dmaq_id; in efx_ethtool_get_class_rule()
837 if ((spec.match_flags & EFX_FILTER_MATCH_ETHER_TYPE) && in efx_ethtool_get_class_rule()
838 spec.ether_type == htons(ETH_P_IP) && in efx_ethtool_get_class_rule()
839 (spec.match_flags & EFX_FILTER_MATCH_IP_PROTO) && in efx_ethtool_get_class_rule()
840 (spec.ip_proto == IPPROTO_TCP || spec.ip_proto == IPPROTO_UDP) && in efx_ethtool_get_class_rule()
841 !(spec.match_flags & in efx_ethtool_get_class_rule()
846 rule->flow_type = ((spec.ip_proto == IPPROTO_TCP) ? in efx_ethtool_get_class_rule()
848 if (spec.match_flags & EFX_FILTER_MATCH_LOC_HOST) { in efx_ethtool_get_class_rule()
849 ip_entry->ip4dst = spec.loc_host[0]; in efx_ethtool_get_class_rule()
852 if (spec.match_flags & EFX_FILTER_MATCH_REM_HOST) { in efx_ethtool_get_class_rule()
853 ip_entry->ip4src = spec.rem_host[0]; in efx_ethtool_get_class_rule()
856 if (spec.match_flags & EFX_FILTER_MATCH_LOC_PORT) { in efx_ethtool_get_class_rule()
857 ip_entry->pdst = spec.loc_port; in efx_ethtool_get_class_rule()
860 if (spec.match_flags & EFX_FILTER_MATCH_REM_PORT) { in efx_ethtool_get_class_rule()
861 ip_entry->psrc = spec.rem_port; in efx_ethtool_get_class_rule()
864 } else if ((spec.match_flags & EFX_FILTER_MATCH_ETHER_TYPE) && in efx_ethtool_get_class_rule()
865 spec.ether_type == htons(ETH_P_IPV6) && in efx_ethtool_get_class_rule()
866 (spec.match_flags & EFX_FILTER_MATCH_IP_PROTO) && in efx_ethtool_get_class_rule()
867 (spec.ip_proto == IPPROTO_TCP || spec.ip_proto == IPPROTO_UDP) && in efx_ethtool_get_class_rule()
868 !(spec.match_flags & in efx_ethtool_get_class_rule()
873 rule->flow_type = ((spec.ip_proto == IPPROTO_TCP) ? in efx_ethtool_get_class_rule()
875 if (spec.match_flags & EFX_FILTER_MATCH_LOC_HOST) { in efx_ethtool_get_class_rule()
876 memcpy(ip6_entry->ip6dst, spec.loc_host, in efx_ethtool_get_class_rule()
880 if (spec.match_flags & EFX_FILTER_MATCH_REM_HOST) { in efx_ethtool_get_class_rule()
881 memcpy(ip6_entry->ip6src, spec.rem_host, in efx_ethtool_get_class_rule()
885 if (spec.match_flags & EFX_FILTER_MATCH_LOC_PORT) { in efx_ethtool_get_class_rule()
886 ip6_entry->pdst = spec.loc_port; in efx_ethtool_get_class_rule()
889 if (spec.match_flags & EFX_FILTER_MATCH_REM_PORT) { in efx_ethtool_get_class_rule()
890 ip6_entry->psrc = spec.rem_port; in efx_ethtool_get_class_rule()
893 } else if (!(spec.match_flags & in efx_ethtool_get_class_rule()
898 if (spec.match_flags & in efx_ethtool_get_class_rule()
900 ether_addr_copy(mac_entry->h_dest, spec.loc_mac); in efx_ethtool_get_class_rule()
901 if (spec.match_flags & EFX_FILTER_MATCH_LOC_MAC) in efx_ethtool_get_class_rule()
907 if (spec.match_flags & EFX_FILTER_MATCH_REM_MAC) { in efx_ethtool_get_class_rule()
908 ether_addr_copy(mac_entry->h_source, spec.rem_mac); in efx_ethtool_get_class_rule()
911 if (spec.match_flags & EFX_FILTER_MATCH_ETHER_TYPE) { in efx_ethtool_get_class_rule()
912 mac_entry->h_proto = spec.ether_type; in efx_ethtool_get_class_rule()
915 } else if (spec.match_flags & EFX_FILTER_MATCH_ETHER_TYPE && in efx_ethtool_get_class_rule()
916 spec.ether_type == htons(ETH_P_IP) && in efx_ethtool_get_class_rule()
917 !(spec.match_flags & in efx_ethtool_get_class_rule()
923 if (spec.match_flags & EFX_FILTER_MATCH_IP_PROTO) { in efx_ethtool_get_class_rule()
925 uip_entry->proto = spec.ip_proto; in efx_ethtool_get_class_rule()
927 if (spec.match_flags & EFX_FILTER_MATCH_LOC_HOST) { in efx_ethtool_get_class_rule()
928 uip_entry->ip4dst = spec.loc_host[0]; in efx_ethtool_get_class_rule()
931 if (spec.match_flags & EFX_FILTER_MATCH_REM_HOST) { in efx_ethtool_get_class_rule()
932 uip_entry->ip4src = spec.rem_host[0]; in efx_ethtool_get_class_rule()
935 } else if (spec.match_flags & EFX_FILTER_MATCH_ETHER_TYPE && in efx_ethtool_get_class_rule()
936 spec.ether_type == htons(ETH_P_IPV6) && in efx_ethtool_get_class_rule()
937 !(spec.match_flags & in efx_ethtool_get_class_rule()
942 if (spec.match_flags & EFX_FILTER_MATCH_IP_PROTO) { in efx_ethtool_get_class_rule()
944 uip6_entry->l4_proto = spec.ip_proto; in efx_ethtool_get_class_rule()
946 if (spec.match_flags & EFX_FILTER_MATCH_LOC_HOST) { in efx_ethtool_get_class_rule()
947 memcpy(uip6_entry->ip6dst, spec.loc_host, in efx_ethtool_get_class_rule()
951 if (spec.match_flags & EFX_FILTER_MATCH_REM_HOST) { in efx_ethtool_get_class_rule()
952 memcpy(uip6_entry->ip6src, spec.rem_host, in efx_ethtool_get_class_rule()
962 if (spec.match_flags & EFX_FILTER_MATCH_OUTER_VID) { in efx_ethtool_get_class_rule()
964 rule->h_ext.vlan_tci = spec.outer_vid; in efx_ethtool_get_class_rule()
968 if (spec.flags & EFX_FILTER_FLAG_RX_RSS) { in efx_ethtool_get_class_rule()
970 *rss_context = spec.rss_context; in efx_ethtool_get_class_rule()
1095 struct efx_filter_spec spec; in efx_ethtool_set_class_rule() local
1118 efx_filter_init_rx(&spec, EFX_FILTER_PRI_MANUAL, flags, in efx_ethtool_set_class_rule()
1123 spec.rss_context = rss_context; in efx_ethtool_set_class_rule()
1128 spec.match_flags = (EFX_FILTER_MATCH_ETHER_TYPE | in efx_ethtool_set_class_rule()
1130 spec.ether_type = htons(ETH_P_IP); in efx_ethtool_set_class_rule()
1131 spec.ip_proto = flow_type == TCP_V4_FLOW ? IPPROTO_TCP in efx_ethtool_set_class_rule()
1136 spec.match_flags |= EFX_FILTER_MATCH_LOC_HOST; in efx_ethtool_set_class_rule()
1137 spec.loc_host[0] = ip_entry->ip4dst; in efx_ethtool_set_class_rule()
1142 spec.match_flags |= EFX_FILTER_MATCH_REM_HOST; in efx_ethtool_set_class_rule()
1143 spec.rem_host[0] = ip_entry->ip4src; in efx_ethtool_set_class_rule()
1148 spec.match_flags |= EFX_FILTER_MATCH_LOC_PORT; in efx_ethtool_set_class_rule()
1149 spec.loc_port = ip_entry->pdst; in efx_ethtool_set_class_rule()
1154 spec.match_flags |= EFX_FILTER_MATCH_REM_PORT; in efx_ethtool_set_class_rule()
1155 spec.rem_port = ip_entry->psrc; in efx_ethtool_set_class_rule()
1163 spec.match_flags = (EFX_FILTER_MATCH_ETHER_TYPE | in efx_ethtool_set_class_rule()
1165 spec.ether_type = htons(ETH_P_IPV6); in efx_ethtool_set_class_rule()
1166 spec.ip_proto = flow_type == TCP_V6_FLOW ? IPPROTO_TCP in efx_ethtool_set_class_rule()
1171 spec.match_flags |= EFX_FILTER_MATCH_LOC_HOST; in efx_ethtool_set_class_rule()
1172 memcpy(spec.loc_host, ip6_entry->ip6dst, sizeof(spec.loc_host)); in efx_ethtool_set_class_rule()
1177 spec.match_flags |= EFX_FILTER_MATCH_REM_HOST; in efx_ethtool_set_class_rule()
1178 memcpy(spec.rem_host, ip6_entry->ip6src, sizeof(spec.rem_host)); in efx_ethtool_set_class_rule()
1183 spec.match_flags |= EFX_FILTER_MATCH_LOC_PORT; in efx_ethtool_set_class_rule()
1184 spec.loc_port = ip6_entry->pdst; in efx_ethtool_set_class_rule()
1189 spec.match_flags |= EFX_FILTER_MATCH_REM_PORT; in efx_ethtool_set_class_rule()
1190 spec.rem_port = ip6_entry->psrc; in efx_ethtool_set_class_rule()
1200 spec.match_flags = EFX_FILTER_MATCH_ETHER_TYPE; in efx_ethtool_set_class_rule()
1201 spec.ether_type = htons(ETH_P_IP); in efx_ethtool_set_class_rule()
1205 spec.match_flags |= EFX_FILTER_MATCH_LOC_HOST; in efx_ethtool_set_class_rule()
1206 spec.loc_host[0] = uip_entry->ip4dst; in efx_ethtool_set_class_rule()
1211 spec.match_flags |= EFX_FILTER_MATCH_REM_HOST; in efx_ethtool_set_class_rule()
1212 spec.rem_host[0] = uip_entry->ip4src; in efx_ethtool_set_class_rule()
1217 spec.match_flags |= EFX_FILTER_MATCH_IP_PROTO; in efx_ethtool_set_class_rule()
1218 spec.ip_proto = uip_entry->proto; in efx_ethtool_set_class_rule()
1225 spec.match_flags = EFX_FILTER_MATCH_ETHER_TYPE; in efx_ethtool_set_class_rule()
1226 spec.ether_type = htons(ETH_P_IPV6); in efx_ethtool_set_class_rule()
1230 spec.match_flags |= EFX_FILTER_MATCH_LOC_HOST; in efx_ethtool_set_class_rule()
1231 memcpy(spec.loc_host, uip6_entry->ip6dst, sizeof(spec.loc_host)); in efx_ethtool_set_class_rule()
1236 spec.match_flags |= EFX_FILTER_MATCH_REM_HOST; in efx_ethtool_set_class_rule()
1237 memcpy(spec.rem_host, uip6_entry->ip6src, sizeof(spec.rem_host)); in efx_ethtool_set_class_rule()
1242 spec.match_flags |= EFX_FILTER_MATCH_IP_PROTO; in efx_ethtool_set_class_rule()
1243 spec.ip_proto = uip6_entry->l4_proto; in efx_ethtool_set_class_rule()
1251 spec.match_flags |= EFX_FILTER_MATCH_LOC_MAC_IG; in efx_ethtool_set_class_rule()
1253 spec.match_flags |= EFX_FILTER_MATCH_LOC_MAC; in efx_ethtool_set_class_rule()
1256 ether_addr_copy(spec.loc_mac, mac_entry->h_dest); in efx_ethtool_set_class_rule()
1261 spec.match_flags |= EFX_FILTER_MATCH_REM_MAC; in efx_ethtool_set_class_rule()
1262 ether_addr_copy(spec.rem_mac, mac_entry->h_source); in efx_ethtool_set_class_rule()
1267 spec.match_flags |= EFX_FILTER_MATCH_ETHER_TYPE; in efx_ethtool_set_class_rule()
1268 spec.ether_type = mac_entry->h_proto; in efx_ethtool_set_class_rule()
1279 spec.match_flags |= EFX_FILTER_MATCH_OUTER_VID; in efx_ethtool_set_class_rule()
1280 spec.outer_vid = rule->h_ext.vlan_tci; in efx_ethtool_set_class_rule()
1283 rc = efx_filter_insert_filter(efx, &spec, true); in efx_ethtool_set_class_rule()