NFT_OFFLOAD_MATCH(FLOW_DISSECTOR_KEY_ETH_ADDRS, eth_addrs,
                                  dst, ETH_ALEN, reg);
                break;
+       case offsetof(struct ethhdr, h_proto):
+               if (priv->len != sizeof(__be16))
+                       return -EOPNOTSUPP;
+
+               NFT_OFFLOAD_MATCH(FLOW_DISSECTOR_KEY_BASIC, basic,
+                                 n_proto, sizeof(__be16), reg);
+               nft_offload_set_dependency(ctx, NFT_OFFLOAD_DEP_NETWORK);
+               break;
+       case offsetof(struct vlan_ethhdr, h_vlan_TCI):
+               if (priv->len != sizeof(__be16))
+                       return -EOPNOTSUPP;
+
+               NFT_OFFLOAD_MATCH(FLOW_DISSECTOR_KEY_VLAN, vlan,
+                                 vlan_tci, sizeof(__be16), reg);
+               break;
+       case offsetof(struct vlan_ethhdr, h_vlan_encapsulated_proto):
+               if (priv->len != sizeof(__be16))
+                       return -EOPNOTSUPP;
+
+               NFT_OFFLOAD_MATCH(FLOW_DISSECTOR_KEY_VLAN, vlan,
+                                 vlan_tpid, sizeof(__be16), reg);
+               break;
        default:
                return -EOPNOTSUPP;
        }