Lines Matching refs:spec
657 struct efx_filter_spec spec;
661 rule->location, &spec);
665 if (spec.dmaq_id == EFX_FILTER_RX_DMAQ_ID_DROP)
668 rule->ring_cookie = spec.dmaq_id;
670 if ((spec.match_flags & EFX_FILTER_MATCH_ETHER_TYPE) &&
671 spec.ether_type == htons(ETH_P_IP) &&
672 (spec.match_flags & EFX_FILTER_MATCH_IP_PROTO) &&
673 (spec.ip_proto == IPPROTO_TCP || spec.ip_proto == IPPROTO_UDP) &&
674 !(spec.match_flags &
679 rule->flow_type = ((spec.ip_proto == IPPROTO_TCP) ?
681 if (spec.match_flags & EFX_FILTER_MATCH_LOC_HOST) {
682 ip_entry->ip4dst = spec.loc_host[0];
685 if (spec.match_flags & EFX_FILTER_MATCH_REM_HOST) {
686 ip_entry->ip4src = spec.rem_host[0];
689 if (spec.match_flags & EFX_FILTER_MATCH_LOC_PORT) {
690 ip_entry->pdst = spec.loc_port;
693 if (spec.match_flags & EFX_FILTER_MATCH_REM_PORT) {
694 ip_entry->psrc = spec.rem_port;
697 } else if ((spec.match_flags & EFX_FILTER_MATCH_ETHER_TYPE) &&
698 spec.ether_type == htons(ETH_P_IPV6) &&
699 (spec.match_flags & EFX_FILTER_MATCH_IP_PROTO) &&
700 (spec.ip_proto == IPPROTO_TCP || spec.ip_proto == IPPROTO_UDP) &&
701 !(spec.match_flags &
706 rule->flow_type = ((spec.ip_proto == IPPROTO_TCP) ?
708 if (spec.match_flags & EFX_FILTER_MATCH_LOC_HOST) {
709 memcpy(ip6_entry->ip6dst, spec.loc_host,
713 if (spec.match_flags & EFX_FILTER_MATCH_REM_HOST) {
714 memcpy(ip6_entry->ip6src, spec.rem_host,
718 if (spec.match_flags & EFX_FILTER_MATCH_LOC_PORT) {
719 ip6_entry->pdst = spec.loc_port;
722 if (spec.match_flags & EFX_FILTER_MATCH_REM_PORT) {
723 ip6_entry->psrc = spec.rem_port;
726 } else if (!(spec.match_flags &
731 if (spec.match_flags &
733 ether_addr_copy(mac_entry->h_dest, spec.loc_mac);
734 if (spec.match_flags & EFX_FILTER_MATCH_LOC_MAC)
740 if (spec.match_flags & EFX_FILTER_MATCH_REM_MAC) {
741 ether_addr_copy(mac_entry->h_source, spec.rem_mac);
744 if (spec.match_flags & EFX_FILTER_MATCH_ETHER_TYPE) {
745 mac_entry->h_proto = spec.ether_type;
748 } else if (spec.match_flags & EFX_FILTER_MATCH_ETHER_TYPE &&
749 spec.ether_type == htons(ETH_P_IP) &&
750 !(spec.match_flags &
756 if (spec.match_flags & EFX_FILTER_MATCH_IP_PROTO) {
758 uip_entry->proto = spec.ip_proto;
760 if (spec.match_flags & EFX_FILTER_MATCH_LOC_HOST) {
761 uip_entry->ip4dst = spec.loc_host[0];
764 if (spec.match_flags & EFX_FILTER_MATCH_REM_HOST) {
765 uip_entry->ip4src = spec.rem_host[0];
768 } else if (spec.match_flags & EFX_FILTER_MATCH_ETHER_TYPE &&
769 spec.ether_type == htons(ETH_P_IPV6) &&
770 !(spec.match_flags &
775 if (spec.match_flags & EFX_FILTER_MATCH_IP_PROTO) {
777 uip6_entry->l4_proto = spec.ip_proto;
779 if (spec.match_flags & EFX_FILTER_MATCH_LOC_HOST) {
780 memcpy(uip6_entry->ip6dst, spec.loc_host,
784 if (spec.match_flags & EFX_FILTER_MATCH_REM_HOST) {
785 memcpy(uip6_entry->ip6src, spec.rem_host,
795 if (spec.match_flags & EFX_FILTER_MATCH_OUTER_VID) {
797 rule->h_ext.vlan_tci = spec.outer_vid;
801 if (spec.flags & EFX_FILTER_FLAG_RX_RSS) {
803 *rss_context = spec.rss_context;
931 struct efx_filter_spec spec;
954 efx_filter_init_rx(&spec, EFX_FILTER_PRI_MANUAL, flags,
959 spec.rss_context = rss_context;
964 spec.match_flags = (EFX_FILTER_MATCH_ETHER_TYPE |
966 spec.ether_type = htons(ETH_P_IP);
967 spec.ip_proto = flow_type == TCP_V4_FLOW ? IPPROTO_TCP
972 spec.match_flags |= EFX_FILTER_MATCH_LOC_HOST;
973 spec.loc_host[0] = ip_entry->ip4dst;
978 spec.match_flags |= EFX_FILTER_MATCH_REM_HOST;
979 spec.rem_host[0] = ip_entry->ip4src;
984 spec.match_flags |= EFX_FILTER_MATCH_LOC_PORT;
985 spec.loc_port = ip_entry->pdst;
990 spec.match_flags |= EFX_FILTER_MATCH_REM_PORT;
991 spec.rem_port = ip_entry->psrc;
999 spec.match_flags = (EFX_FILTER_MATCH_ETHER_TYPE |
1001 spec.ether_type = htons(ETH_P_IPV6);
1002 spec.ip_proto = flow_type == TCP_V6_FLOW ? IPPROTO_TCP
1007 spec.match_flags |= EFX_FILTER_MATCH_LOC_HOST;
1008 memcpy(spec.loc_host, ip6_entry->ip6dst, sizeof(spec.loc_host));
1013 spec.match_flags |= EFX_FILTER_MATCH_REM_HOST;
1014 memcpy(spec.rem_host, ip6_entry->ip6src, sizeof(spec.rem_host));
1019 spec.match_flags |= EFX_FILTER_MATCH_LOC_PORT;
1020 spec.loc_port = ip6_entry->pdst;
1025 spec.match_flags |= EFX_FILTER_MATCH_REM_PORT;
1026 spec.rem_port = ip6_entry->psrc;
1036 spec.match_flags = EFX_FILTER_MATCH_ETHER_TYPE;
1037 spec.ether_type = htons(ETH_P_IP);
1041 spec.match_flags |= EFX_FILTER_MATCH_LOC_HOST;
1042 spec.loc_host[0] = uip_entry->ip4dst;
1047 spec.match_flags |= EFX_FILTER_MATCH_REM_HOST;
1048 spec.rem_host[0] = uip_entry->ip4src;
1053 spec.match_flags |= EFX_FILTER_MATCH_IP_PROTO;
1054 spec.ip_proto = uip_entry->proto;
1061 spec.match_flags = EFX_FILTER_MATCH_ETHER_TYPE;
1062 spec.ether_type = htons(ETH_P_IPV6);
1066 spec.match_flags |= EFX_FILTER_MATCH_LOC_HOST;
1067 memcpy(spec.loc_host, uip6_entry->ip6dst, sizeof(spec.loc_host));
1072 spec.match_flags |= EFX_FILTER_MATCH_REM_HOST;
1073 memcpy(spec.rem_host, uip6_entry->ip6src, sizeof(spec.rem_host));
1078 spec.match_flags |= EFX_FILTER_MATCH_IP_PROTO;
1079 spec.ip_proto = uip6_entry->l4_proto;
1087 spec.match_flags |= EFX_FILTER_MATCH_LOC_MAC_IG;
1089 spec.match_flags |= EFX_FILTER_MATCH_LOC_MAC;
1092 ether_addr_copy(spec.loc_mac, mac_entry->h_dest);
1097 spec.match_flags |= EFX_FILTER_MATCH_REM_MAC;
1098 ether_addr_copy(spec.rem_mac, mac_entry->h_source);
1103 spec.match_flags |= EFX_FILTER_MATCH_ETHER_TYPE;
1104 spec.ether_type = mac_entry->h_proto;
1115 spec.match_flags |= EFX_FILTER_MATCH_OUTER_VID;
1116 spec.outer_vid = rule->h_ext.vlan_tci;
1119 rc = efx_filter_insert_filter(efx, &spec, true);