Lines Matching defs:spec
658 struct efx_filter_spec spec;
662 rule->location, &spec);
666 if (spec.dmaq_id == EFX_FILTER_RX_DMAQ_ID_DROP)
669 rule->ring_cookie = spec.dmaq_id;
671 if ((spec.match_flags & EFX_FILTER_MATCH_ETHER_TYPE) &&
672 spec.ether_type == htons(ETH_P_IP) &&
673 (spec.match_flags & EFX_FILTER_MATCH_IP_PROTO) &&
674 (spec.ip_proto == IPPROTO_TCP || spec.ip_proto == IPPROTO_UDP) &&
675 !(spec.match_flags &
680 rule->flow_type = ((spec.ip_proto == IPPROTO_TCP) ?
682 if (spec.match_flags & EFX_FILTER_MATCH_LOC_HOST) {
683 ip_entry->ip4dst = spec.loc_host[0];
686 if (spec.match_flags & EFX_FILTER_MATCH_REM_HOST) {
687 ip_entry->ip4src = spec.rem_host[0];
690 if (spec.match_flags & EFX_FILTER_MATCH_LOC_PORT) {
691 ip_entry->pdst = spec.loc_port;
694 if (spec.match_flags & EFX_FILTER_MATCH_REM_PORT) {
695 ip_entry->psrc = spec.rem_port;
698 } else if ((spec.match_flags & EFX_FILTER_MATCH_ETHER_TYPE) &&
699 spec.ether_type == htons(ETH_P_IPV6) &&
700 (spec.match_flags & EFX_FILTER_MATCH_IP_PROTO) &&
701 (spec.ip_proto == IPPROTO_TCP || spec.ip_proto == IPPROTO_UDP) &&
702 !(spec.match_flags &
707 rule->flow_type = ((spec.ip_proto == IPPROTO_TCP) ?
709 if (spec.match_flags & EFX_FILTER_MATCH_LOC_HOST) {
710 memcpy(ip6_entry->ip6dst, spec.loc_host,
714 if (spec.match_flags & EFX_FILTER_MATCH_REM_HOST) {
715 memcpy(ip6_entry->ip6src, spec.rem_host,
719 if (spec.match_flags & EFX_FILTER_MATCH_LOC_PORT) {
720 ip6_entry->pdst = spec.loc_port;
723 if (spec.match_flags & EFX_FILTER_MATCH_REM_PORT) {
724 ip6_entry->psrc = spec.rem_port;
727 } else if (!(spec.match_flags &
732 if (spec.match_flags &
734 ether_addr_copy(mac_entry->h_dest, spec.loc_mac);
735 if (spec.match_flags & EFX_FILTER_MATCH_LOC_MAC)
741 if (spec.match_flags & EFX_FILTER_MATCH_REM_MAC) {
742 ether_addr_copy(mac_entry->h_source, spec.rem_mac);
745 if (spec.match_flags & EFX_FILTER_MATCH_ETHER_TYPE) {
746 mac_entry->h_proto = spec.ether_type;
749 } else if (spec.match_flags & EFX_FILTER_MATCH_ETHER_TYPE &&
750 spec.ether_type == htons(ETH_P_IP) &&
751 !(spec.match_flags &
757 if (spec.match_flags & EFX_FILTER_MATCH_IP_PROTO) {
759 uip_entry->proto = spec.ip_proto;
761 if (spec.match_flags & EFX_FILTER_MATCH_LOC_HOST) {
762 uip_entry->ip4dst = spec.loc_host[0];
765 if (spec.match_flags & EFX_FILTER_MATCH_REM_HOST) {
766 uip_entry->ip4src = spec.rem_host[0];
769 } else if (spec.match_flags & EFX_FILTER_MATCH_ETHER_TYPE &&
770 spec.ether_type == htons(ETH_P_IPV6) &&
771 !(spec.match_flags &
776 if (spec.match_flags & EFX_FILTER_MATCH_IP_PROTO) {
778 uip6_entry->l4_proto = spec.ip_proto;
780 if (spec.match_flags & EFX_FILTER_MATCH_LOC_HOST) {
781 memcpy(uip6_entry->ip6dst, spec.loc_host,
785 if (spec.match_flags & EFX_FILTER_MATCH_REM_HOST) {
786 memcpy(uip6_entry->ip6src, spec.rem_host,
796 if (spec.match_flags & EFX_FILTER_MATCH_OUTER_VID) {
798 rule->h_ext.vlan_tci = spec.outer_vid;
802 if (spec.flags & EFX_FILTER_FLAG_RX_RSS) {
804 *rss_context = spec.rss_context;
932 struct efx_filter_spec spec;
955 efx_filter_init_rx(&spec, EFX_FILTER_PRI_MANUAL, flags,
960 spec.rss_context = rss_context;
965 spec.match_flags = (EFX_FILTER_MATCH_ETHER_TYPE |
967 spec.ether_type = htons(ETH_P_IP);
968 spec.ip_proto = flow_type == TCP_V4_FLOW ? IPPROTO_TCP
973 spec.match_flags |= EFX_FILTER_MATCH_LOC_HOST;
974 spec.loc_host[0] = ip_entry->ip4dst;
979 spec.match_flags |= EFX_FILTER_MATCH_REM_HOST;
980 spec.rem_host[0] = ip_entry->ip4src;
985 spec.match_flags |= EFX_FILTER_MATCH_LOC_PORT;
986 spec.loc_port = ip_entry->pdst;
991 spec.match_flags |= EFX_FILTER_MATCH_REM_PORT;
992 spec.rem_port = ip_entry->psrc;
1000 spec.match_flags = (EFX_FILTER_MATCH_ETHER_TYPE |
1002 spec.ether_type = htons(ETH_P_IPV6);
1003 spec.ip_proto = flow_type == TCP_V6_FLOW ? IPPROTO_TCP
1008 spec.match_flags |= EFX_FILTER_MATCH_LOC_HOST;
1009 memcpy(spec.loc_host, ip6_entry->ip6dst, sizeof(spec.loc_host));
1014 spec.match_flags |= EFX_FILTER_MATCH_REM_HOST;
1015 memcpy(spec.rem_host, ip6_entry->ip6src, sizeof(spec.rem_host));
1020 spec.match_flags |= EFX_FILTER_MATCH_LOC_PORT;
1021 spec.loc_port = ip6_entry->pdst;
1026 spec.match_flags |= EFX_FILTER_MATCH_REM_PORT;
1027 spec.rem_port = ip6_entry->psrc;
1037 spec.match_flags = EFX_FILTER_MATCH_ETHER_TYPE;
1038 spec.ether_type = htons(ETH_P_IP);
1042 spec.match_flags |= EFX_FILTER_MATCH_LOC_HOST;
1043 spec.loc_host[0] = uip_entry->ip4dst;
1048 spec.match_flags |= EFX_FILTER_MATCH_REM_HOST;
1049 spec.rem_host[0] = uip_entry->ip4src;
1054 spec.match_flags |= EFX_FILTER_MATCH_IP_PROTO;
1055 spec.ip_proto = uip_entry->proto;
1062 spec.match_flags = EFX_FILTER_MATCH_ETHER_TYPE;
1063 spec.ether_type = htons(ETH_P_IPV6);
1067 spec.match_flags |= EFX_FILTER_MATCH_LOC_HOST;
1068 memcpy(spec.loc_host, uip6_entry->ip6dst, sizeof(spec.loc_host));
1073 spec.match_flags |= EFX_FILTER_MATCH_REM_HOST;
1074 memcpy(spec.rem_host, uip6_entry->ip6src, sizeof(spec.rem_host));
1079 spec.match_flags |= EFX_FILTER_MATCH_IP_PROTO;
1080 spec.ip_proto = uip6_entry->l4_proto;
1088 spec.match_flags |= EFX_FILTER_MATCH_LOC_MAC_IG;
1090 spec.match_flags |= EFX_FILTER_MATCH_LOC_MAC;
1093 ether_addr_copy(spec.loc_mac, mac_entry->h_dest);
1098 spec.match_flags |= EFX_FILTER_MATCH_REM_MAC;
1099 ether_addr_copy(spec.rem_mac, mac_entry->h_source);
1104 spec.match_flags |= EFX_FILTER_MATCH_ETHER_TYPE;
1105 spec.ether_type = mac_entry->h_proto;
1116 spec.match_flags |= EFX_FILTER_MATCH_OUTER_VID;
1117 spec.outer_vid = rule->h_ext.vlan_tci;
1120 rc = efx_filter_insert_filter(efx, &spec, true);