1 /* SPDX-License-Identifier: GPL-2.0 OR Linux-OpenIB */ 2 /* Copyright (c) 2018 Mellanox Technologies. */ 3 4 #ifndef __MLX5_EN_TC_TUNNEL_H__ 5 #define __MLX5_EN_TC_TUNNEL_H__ 6 7 #include <linux/netdevice.h> 8 #include <linux/mlx5/fs.h> 9 #include <net/pkt_cls.h> 10 #include <linux/netlink.h> 11 #include "en.h" 12 #include "en_rep.h" 13 14 #ifdef CONFIG_MLX5_ESWITCH 15 16 enum { 17 MLX5E_TC_TUNNEL_TYPE_UNKNOWN, 18 MLX5E_TC_TUNNEL_TYPE_VXLAN, 19 MLX5E_TC_TUNNEL_TYPE_GENEVE, 20 MLX5E_TC_TUNNEL_TYPE_GRETAP, 21 MLX5E_TC_TUNNEL_TYPE_MPLSOUDP, 22 }; 23 24 struct mlx5e_encap_key { 25 const struct ip_tunnel_key *ip_tun_key; 26 struct mlx5e_tc_tunnel *tc_tunnel; 27 }; 28 29 struct mlx5e_tc_tunnel { 30 int tunnel_type; 31 enum mlx5_flow_match_level match_level; 32 33 bool (*can_offload)(struct mlx5e_priv *priv); 34 int (*calc_hlen)(struct mlx5e_encap_entry *e); 35 int (*init_encap_attr)(struct net_device *tunnel_dev, 36 struct mlx5e_priv *priv, 37 struct mlx5e_encap_entry *e, 38 struct netlink_ext_ack *extack); 39 int (*generate_ip_tun_hdr)(char buf[], 40 __u8 *ip_proto, 41 struct mlx5e_encap_entry *e); 42 int (*parse_udp_ports)(struct mlx5e_priv *priv, 43 struct mlx5_flow_spec *spec, 44 struct flow_cls_offload *f, 45 void *headers_c, 46 void *headers_v); 47 int (*parse_tunnel)(struct mlx5e_priv *priv, 48 struct mlx5_flow_spec *spec, 49 struct flow_cls_offload *f, 50 void *headers_c, 51 void *headers_v); 52 bool (*encap_info_equal)(struct mlx5e_encap_key *a, 53 struct mlx5e_encap_key *b); 54 }; 55 56 extern struct mlx5e_tc_tunnel vxlan_tunnel; 57 extern struct mlx5e_tc_tunnel geneve_tunnel; 58 extern struct mlx5e_tc_tunnel gre_tunnel; 59 extern struct mlx5e_tc_tunnel mplsoudp_tunnel; 60 61 struct mlx5e_tc_tunnel *mlx5e_get_tc_tun(struct net_device *tunnel_dev); 62 63 int mlx5e_tc_tun_init_encap_attr(struct net_device *tunnel_dev, 64 struct mlx5e_priv *priv, 65 struct mlx5e_encap_entry *e, 66 struct netlink_ext_ack *extack); 67 68 int mlx5e_tc_tun_create_header_ipv4(struct mlx5e_priv *priv, 69 struct net_device *mirred_dev, 70 struct mlx5e_encap_entry *e); 71 int mlx5e_tc_tun_update_header_ipv4(struct mlx5e_priv *priv, 72 struct net_device *mirred_dev, 73 struct mlx5e_encap_entry *e); 74 75 #if IS_ENABLED(CONFIG_INET) && IS_ENABLED(CONFIG_IPV6) 76 int mlx5e_tc_tun_create_header_ipv6(struct mlx5e_priv *priv, 77 struct net_device *mirred_dev, 78 struct mlx5e_encap_entry *e); 79 int mlx5e_tc_tun_update_header_ipv6(struct mlx5e_priv *priv, 80 struct net_device *mirred_dev, 81 struct mlx5e_encap_entry *e); 82 #else 83 static inline int 84 mlx5e_tc_tun_create_header_ipv6(struct mlx5e_priv *priv, 85 struct net_device *mirred_dev, 86 struct mlx5e_encap_entry *e) 87 { return -EOPNOTSUPP; } 88 static inline int 89 mlx5e_tc_tun_update_header_ipv6(struct mlx5e_priv *priv, 90 struct net_device *mirred_dev, 91 struct mlx5e_encap_entry *e) 92 { return -EOPNOTSUPP; } 93 #endif 94 int mlx5e_tc_tun_route_lookup(struct mlx5e_priv *priv, 95 struct mlx5_flow_spec *spec, 96 struct mlx5_flow_attr *attr); 97 98 bool mlx5e_tc_tun_device_to_offload(struct mlx5e_priv *priv, 99 struct net_device *netdev); 100 101 int mlx5e_tc_tun_parse(struct net_device *filter_dev, 102 struct mlx5e_priv *priv, 103 struct mlx5_flow_spec *spec, 104 struct flow_cls_offload *f, 105 u8 *match_level); 106 107 int mlx5e_tc_tun_parse_udp_ports(struct mlx5e_priv *priv, 108 struct mlx5_flow_spec *spec, 109 struct flow_cls_offload *f, 110 void *headers_c, 111 void *headers_v); 112 113 bool mlx5e_tc_tun_encap_info_equal_generic(struct mlx5e_encap_key *a, 114 struct mlx5e_encap_key *b); 115 116 #endif /* CONFIG_MLX5_ESWITCH */ 117 118 #endif //__MLX5_EN_TC_TUNNEL_H__ 119