Commit 56fa9501 authored by Pablo Neira Ayuso's avatar Pablo Neira Ayuso

netfilter: nft_meta: add NFT_META_IFTYPE

Generalize NFT_META_IIFTYPE to NFT_META_IFTYPE which allows you to match
on the interface type of the skb->dev field. This field is used by the
netdev family to add an implicit dependency to skip non-ethernet packets
when matching on layer 3 and 4 TCP/IP header fields.

For backward compatibility, add the NFT_META_IIFTYPE alias to
NFT_META_IFTYPE.

Add __NFT_META_IIFTYPE, to be used by userspace in the future to match
specifically on the iiftype.
Signed-off-by: default avatarPablo Neira Ayuso <pablo@netfilter.org>
parent b7b1d02f
...@@ -896,7 +896,8 @@ enum nft_meta_keys { ...@@ -896,7 +896,8 @@ enum nft_meta_keys {
NFT_META_OIF, NFT_META_OIF,
NFT_META_IIFNAME, NFT_META_IIFNAME,
NFT_META_OIFNAME, NFT_META_OIFNAME,
NFT_META_IIFTYPE, NFT_META_IFTYPE,
#define NFT_META_IIFTYPE NFT_META_IFTYPE
NFT_META_OIFTYPE, NFT_META_OIFTYPE,
NFT_META_SKUID, NFT_META_SKUID,
NFT_META_SKGID, NFT_META_SKGID,
...@@ -923,6 +924,7 @@ enum nft_meta_keys { ...@@ -923,6 +924,7 @@ enum nft_meta_keys {
NFT_META_TIME_HOUR, NFT_META_TIME_HOUR,
NFT_META_SDIF, NFT_META_SDIF,
NFT_META_SDIFNAME, NFT_META_SDIFNAME,
__NFT_META_IIFTYPE,
}; };
/** /**
......
...@@ -244,7 +244,11 @@ static bool nft_meta_get_eval_ifname(enum nft_meta_keys key, u32 *dest, ...@@ -244,7 +244,11 @@ static bool nft_meta_get_eval_ifname(enum nft_meta_keys key, u32 *dest,
case NFT_META_OIF: case NFT_META_OIF:
nft_meta_store_ifindex(dest, nft_out(pkt)); nft_meta_store_ifindex(dest, nft_out(pkt));
break; break;
case NFT_META_IIFTYPE: case NFT_META_IFTYPE:
if (!nft_meta_store_iftype(dest, pkt->skb->dev))
return false;
break;
case __NFT_META_IIFTYPE:
if (!nft_meta_store_iftype(dest, nft_in(pkt))) if (!nft_meta_store_iftype(dest, nft_in(pkt)))
return false; return false;
break; break;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment