Lines Matching refs:spec
795 struct ef4_filter_spec spec;
799 rule->location, &spec);
803 if (spec.dmaq_id == EF4_FILTER_RX_DMAQ_ID_DROP)
806 rule->ring_cookie = spec.dmaq_id;
808 if ((spec.match_flags & EF4_FILTER_MATCH_ETHER_TYPE) &&
809 spec.ether_type == htons(ETH_P_IP) &&
810 (spec.match_flags & EF4_FILTER_MATCH_IP_PROTO) &&
811 (spec.ip_proto == IPPROTO_TCP || spec.ip_proto == IPPROTO_UDP) &&
812 !(spec.match_flags &
817 rule->flow_type = ((spec.ip_proto == IPPROTO_TCP) ?
819 if (spec.match_flags & EF4_FILTER_MATCH_LOC_HOST) {
820 ip_entry->ip4dst = spec.loc_host[0];
823 if (spec.match_flags & EF4_FILTER_MATCH_REM_HOST) {
824 ip_entry->ip4src = spec.rem_host[0];
827 if (spec.match_flags & EF4_FILTER_MATCH_LOC_PORT) {
828 ip_entry->pdst = spec.loc_port;
831 if (spec.match_flags & EF4_FILTER_MATCH_REM_PORT) {
832 ip_entry->psrc = spec.rem_port;
835 } else if ((spec.match_flags & EF4_FILTER_MATCH_ETHER_TYPE) &&
836 spec.ether_type == htons(ETH_P_IPV6) &&
837 (spec.match_flags & EF4_FILTER_MATCH_IP_PROTO) &&
838 (spec.ip_proto == IPPROTO_TCP || spec.ip_proto == IPPROTO_UDP) &&
839 !(spec.match_flags &
844 rule->flow_type = ((spec.ip_proto == IPPROTO_TCP) ?
846 if (spec.match_flags & EF4_FILTER_MATCH_LOC_HOST) {
847 memcpy(ip6_entry->ip6dst, spec.loc_host,
851 if (spec.match_flags & EF4_FILTER_MATCH_REM_HOST) {
852 memcpy(ip6_entry->ip6src, spec.rem_host,
856 if (spec.match_flags & EF4_FILTER_MATCH_LOC_PORT) {
857 ip6_entry->pdst = spec.loc_port;
860 if (spec.match_flags & EF4_FILTER_MATCH_REM_PORT) {
861 ip6_entry->psrc = spec.rem_port;
864 } else if (!(spec.match_flags &
869 if (spec.match_flags &
871 ether_addr_copy(mac_entry->h_dest, spec.loc_mac);
872 if (spec.match_flags & EF4_FILTER_MATCH_LOC_MAC)
878 if (spec.match_flags & EF4_FILTER_MATCH_REM_MAC) {
879 ether_addr_copy(mac_entry->h_source, spec.rem_mac);
882 if (spec.match_flags & EF4_FILTER_MATCH_ETHER_TYPE) {
883 mac_entry->h_proto = spec.ether_type;
886 } else if (spec.match_flags & EF4_FILTER_MATCH_ETHER_TYPE &&
887 spec.ether_type == htons(ETH_P_IP) &&
888 !(spec.match_flags &
894 if (spec.match_flags & EF4_FILTER_MATCH_IP_PROTO) {
896 uip_entry->proto = spec.ip_proto;
898 if (spec.match_flags & EF4_FILTER_MATCH_LOC_HOST) {
899 uip_entry->ip4dst = spec.loc_host[0];
902 if (spec.match_flags & EF4_FILTER_MATCH_REM_HOST) {
903 uip_entry->ip4src = spec.rem_host[0];
906 } else if (spec.match_flags & EF4_FILTER_MATCH_ETHER_TYPE &&
907 spec.ether_type == htons(ETH_P_IPV6) &&
908 !(spec.match_flags &
913 if (spec.match_flags & EF4_FILTER_MATCH_IP_PROTO) {
915 uip6_entry->l4_proto = spec.ip_proto;
917 if (spec.match_flags & EF4_FILTER_MATCH_LOC_HOST) {
918 memcpy(uip6_entry->ip6dst, spec.loc_host,
922 if (spec.match_flags & EF4_FILTER_MATCH_REM_HOST) {
923 memcpy(uip6_entry->ip6src, spec.rem_host,
933 if (spec.match_flags & EF4_FILTER_MATCH_OUTER_VID) {
935 rule->h_ext.vlan_tci = spec.outer_vid;
1031 struct ef4_filter_spec spec;
1049 ef4_filter_init_rx(&spec, EF4_FILTER_PRI_MANUAL,
1057 spec.match_flags = (EF4_FILTER_MATCH_ETHER_TYPE |
1059 spec.ether_type = htons(ETH_P_IP);
1060 spec.ip_proto = ((rule->flow_type & ~FLOW_EXT) == TCP_V4_FLOW ?
1065 spec.match_flags |= EF4_FILTER_MATCH_LOC_HOST;
1066 spec.loc_host[0] = ip_entry->ip4dst;
1071 spec.match_flags |= EF4_FILTER_MATCH_REM_HOST;
1072 spec.rem_host[0] = ip_entry->ip4src;
1077 spec.match_flags |= EF4_FILTER_MATCH_LOC_PORT;
1078 spec.loc_port = ip_entry->pdst;
1083 spec.match_flags |= EF4_FILTER_MATCH_REM_PORT;
1084 spec.rem_port = ip_entry->psrc;
1092 spec.match_flags = (EF4_FILTER_MATCH_ETHER_TYPE |
1094 spec.ether_type = htons(ETH_P_IPV6);
1095 spec.ip_proto = ((rule->flow_type & ~FLOW_EXT) == TCP_V6_FLOW ?
1100 spec.match_flags |= EF4_FILTER_MATCH_LOC_HOST;
1101 memcpy(spec.loc_host, ip6_entry->ip6dst, sizeof(spec.loc_host));
1106 spec.match_flags |= EF4_FILTER_MATCH_REM_HOST;
1107 memcpy(spec.rem_host, ip6_entry->ip6src, sizeof(spec.rem_host));
1112 spec.match_flags |= EF4_FILTER_MATCH_LOC_PORT;
1113 spec.loc_port = ip6_entry->pdst;
1118 spec.match_flags |= EF4_FILTER_MATCH_REM_PORT;
1119 spec.rem_port = ip6_entry->psrc;
1129 spec.match_flags = EF4_FILTER_MATCH_ETHER_TYPE;
1130 spec.ether_type = htons(ETH_P_IP);
1134 spec.match_flags |= EF4_FILTER_MATCH_LOC_HOST;
1135 spec.loc_host[0] = uip_entry->ip4dst;
1140 spec.match_flags |= EF4_FILTER_MATCH_REM_HOST;
1141 spec.rem_host[0] = uip_entry->ip4src;
1146 spec.match_flags |= EF4_FILTER_MATCH_IP_PROTO;
1147 spec.ip_proto = uip_entry->proto;
1154 spec.match_flags = EF4_FILTER_MATCH_ETHER_TYPE;
1155 spec.ether_type = htons(ETH_P_IPV6);
1159 spec.match_flags |= EF4_FILTER_MATCH_LOC_HOST;
1160 memcpy(spec.loc_host, uip6_entry->ip6dst, sizeof(spec.loc_host));
1165 spec.match_flags |= EF4_FILTER_MATCH_REM_HOST;
1166 memcpy(spec.rem_host, uip6_entry->ip6src, sizeof(spec.rem_host));
1171 spec.match_flags |= EF4_FILTER_MATCH_IP_PROTO;
1172 spec.ip_proto = uip6_entry->l4_proto;
1180 spec.match_flags |= EF4_FILTER_MATCH_LOC_MAC_IG;
1182 spec.match_flags |= EF4_FILTER_MATCH_LOC_MAC;
1185 ether_addr_copy(spec.loc_mac, mac_entry->h_dest);
1190 spec.match_flags |= EF4_FILTER_MATCH_REM_MAC;
1191 ether_addr_copy(spec.rem_mac, mac_entry->h_source);
1196 spec.match_flags |= EF4_FILTER_MATCH_ETHER_TYPE;
1197 spec.ether_type = mac_entry->h_proto;
1208 spec.match_flags |= EF4_FILTER_MATCH_OUTER_VID;
1209 spec.outer_vid = rule->h_ext.vlan_tci;
1212 rc = ef4_filter_insert_filter(efx, &spec, true);