}, {
MFF_IP_DSCP, "nw_tos", NULL,
MF_FIELD_SIZES(u8),
- MFM_NONE, FWW_NW_DSCP,
+ MFM_NONE, 0,
MFS_DECIMAL,
MFP_IP_ANY,
true,
}, {
MFF_IP_ECN, "nw_ecn", NULL,
1, 2,
- MFM_NONE, FWW_NW_ECN,
+ MFM_NONE, 0,
MFS_DECIMAL,
MFP_IP_ANY,
true,
case MFF_IN_PORT:
case MFF_ETH_TYPE:
case MFF_IP_PROTO:
- case MFF_IP_DSCP:
- case MFF_IP_ECN:
case MFF_IP_TTL:
case MFF_ARP_OP:
assert(mf->fww_bit != 0);
case MFF_IPV6_LABEL:
return !wc->ipv6_label_mask;
+ case MFF_IP_DSCP:
+ return !(wc->nw_tos_mask & IP_DSCP_MASK);
+ case MFF_IP_ECN:
+ return !(wc->nw_tos_mask & IP_ECN_MASK);
+
case MFF_ND_TARGET:
return ipv6_mask_is_any(&wc->nd_target_mask);
case MFF_IN_PORT:
case MFF_ETH_TYPE:
case MFF_IP_PROTO:
- case MFF_IP_DSCP:
- case MFF_IP_ECN:
case MFF_IP_TTL:
case MFF_ARP_OP:
assert(mf->fww_bit != 0);
mask->be32 = wc->ipv6_label_mask;
break;
+ case MFF_IP_DSCP:
+ mask->u8 = wc->nw_tos_mask & IP_DSCP_MASK;
+ break;
+ case MFF_IP_ECN:
+ mask->u8 = wc->nw_tos_mask & IP_ECN_MASK;
+ break;
+
case MFF_ND_TARGET:
mask->ipv6 = wc->nd_target_mask;
break;
break;
case MFF_IP_DSCP:
- rule->wc.wildcards |= FWW_NW_DSCP;
+ rule->wc.nw_tos_mask &= ~IP_DSCP_MASK;
rule->flow.nw_tos &= ~IP_DSCP_MASK;
break;
case MFF_IP_ECN:
- rule->wc.wildcards |= FWW_NW_ECN;
+ rule->wc.nw_tos_mask &= ~IP_ECN_MASK;
rule->flow.nw_tos &= ~IP_ECN_MASK;
break;