Home
last modified time | relevance | path

Searched refs:tun_info (Results 1 – 25 of 37) sorted by relevance

12

/linux/net/ipv4/
H A Dip_tunnel_core.c150 md->u.tun_info.mode & IP_TUNNEL_INFO_TX) in iptunnel_metadata_reply()
153 src = &md->u.tun_info; in iptunnel_metadata_reply()
158 dst = &res->u.tun_info; in iptunnel_metadata_reply()
683 struct ip_tunnel_info *tun_info; in ip_tun_build_state() local
695 new_state = lwtunnel_state_alloc(sizeof(*tun_info) + opt_len); in ip_tun_build_state()
701 tun_info = lwt_tun_info(new_state); in ip_tun_build_state()
703 err = ip_tun_set_opts(tb[LWTUNNEL_IP_OPTS], tun_info, extack); in ip_tun_build_state()
710 err = dst_cache_init(&tun_info->dst_cache, GFP_KERNEL); in ip_tun_build_state()
718 tun_info->key.tun_id = nla_get_be64(tb[LWTUNNEL_IP_ID]); in ip_tun_build_state()
721 tun_info->key.u.ipv4.dst = nla_get_in_addr(tb[LWTUNNEL_IP_DST]); in ip_tun_build_state()
[all …]
H A Dip_tunnel.c576 struct ip_tunnel_info *tun_info; in ip_md_tunnel_xmit() local
585 tun_info = skb_tunnel_info(skb); in ip_md_tunnel_xmit()
586 if (unlikely(!tun_info || !(tun_info->mode & IP_TUNNEL_INFO_TX) || in ip_md_tunnel_xmit()
587 ip_tunnel_info_af(tun_info) != AF_INET)) in ip_md_tunnel_xmit()
589 key = &tun_info->key; in ip_md_tunnel_xmit()
605 tunnel_hlen = ip_encap_hlen(&tun_info->encap); in ip_md_tunnel_xmit()
607 if (ip_tunnel_encap(skb, &tun_info->encap, &proto, &fl4) < 0) in ip_md_tunnel_xmit()
610 use_cache = ip_tunnel_dst_cache_usable(skb, tun_info); in ip_md_tunnel_xmit()
612 rt = dst_cache_get_ip4(&tun_info->dst_cache, &fl4.saddr); in ip_md_tunnel_xmit()
620 dst_cache_set_ip4(&tun_info->dst_cache, &rt->dst, in ip_md_tunnel_xmit()
[all …]
H A Dip_gre.c334 info = &tun_dst->u.tun_info; in erspan_rcv()
345 md = ip_tunnel_info_opts(&tun_dst->u.tun_info); in erspan_rcv()
503 struct ip_tunnel_info *tun_info; in gre_fb_xmit() local
507 tun_info = skb_tunnel_info(skb); in gre_fb_xmit()
508 if (unlikely(!tun_info || !(tun_info->mode & IP_TUNNEL_INFO_TX) || in gre_fb_xmit()
509 ip_tunnel_info_af(tun_info) != AF_INET)) in gre_fb_xmit()
512 key = &tun_info->key; in gre_fb_xmit()
526 ip_tunnel_flags_and(flags, tun_info->key.tun_flags, flags); in gre_fb_xmit()
529 tunnel_id_to_key32(tun_info->key.tun_id), in gre_fb_xmit()
546 struct ip_tunnel_info *tun_info; in erspan_fb_xmit() local
[all …]
/linux/include/net/
H A Ddst_metadata.h37 struct ip_tunnel_info tun_info; member
61 return &md_dst->u.tun_info; in skb_tunnel_info()
119 return memcmp(&a->u.tun_info, &b->u.tun_info, in skb_metadata_dst_cmp()
120 sizeof(a->u.tun_info) + in skb_metadata_dst_cmp()
121 a->u.tun_info.options_len); in skb_metadata_dst_cmp()
148 tun_dst->u.tun_info.options_len = 0; in tun_rx_dst()
149 tun_dst->u.tun_info.mode = 0; in tun_rx_dst()
162 md_size = md_dst->u.tun_info.options_len; in tun_dst_unclone()
167 memcpy(&new_md->u.tun_info, &md_dst->u.tun_info, in tun_dst_unclone()
171 if (new_md->u.tun_info.dst_cache.cache) { in tun_dst_unclone()
[all …]
/linux/net/psample/
H A Dpsample.c217 struct ip_tunnel_info *tun_info) in __psample_ip_tun_to_nlattr() argument
219 unsigned short tun_proto = ip_tunnel_info_af(tun_info); in __psample_ip_tun_to_nlattr()
220 const void *tun_opts = ip_tunnel_info_opts(tun_info); in __psample_ip_tun_to_nlattr()
221 const struct ip_tunnel_key *tun_key = &tun_info->key; in __psample_ip_tun_to_nlattr()
222 int tun_opts_len = tun_info->options_len; in __psample_ip_tun_to_nlattr()
229 if (tun_info->mode & IP_TUNNEL_INFO_BRIDGE && in __psample_ip_tun_to_nlattr()
291 struct ip_tunnel_info *tun_info) in psample_ip_tun_to_nlattr() argument
300 err = __psample_ip_tun_to_nlattr(skb, tun_info); in psample_ip_tun_to_nlattr()
311 static int psample_tunnel_meta_len(struct ip_tunnel_info *tun_info) in psample_tunnel_meta_len() argument
313 unsigned short tun_proto = ip_tunnel_info_af(tun_info); in psample_tunnel_meta_len()
[all …]
/linux/drivers/net/ethernet/mellanox/mlx5/core/en/
H A Dtc_tun_geneve.c19 e->tun_info->options_len; in mlx5e_tc_tun_calc_hlen_geneve()
96 const struct ip_tunnel_info *tun_info = e->tun_info; in mlx5e_gen_ip_tunnel_header_geneve() local
104 udp->dest = tun_info->key.tp_dst; in mlx5e_gen_ip_tunnel_header_geneve()
108 geneveh->opt_len = tun_info->options_len / 4; in mlx5e_gen_ip_tunnel_header_geneve()
109 geneveh->oam = test_bit(IP_TUNNEL_OAM_BIT, tun_info->key.tun_flags); in mlx5e_gen_ip_tunnel_header_geneve()
111 tun_info->key.tun_flags); in mlx5e_gen_ip_tunnel_header_geneve()
112 mlx5e_tunnel_id_to_vni(tun_info->key.tun_id, geneveh->vni); in mlx5e_gen_ip_tunnel_header_geneve()
115 if (test_bit(IP_TUNNEL_GENEVE_OPT_BIT, tun_info->key.tun_flags)) { in mlx5e_gen_ip_tunnel_header_geneve()
118 ip_tunnel_info_opts_get(geneveh->options, tun_info); in mlx5e_gen_ip_tunnel_header_geneve()
H A Dtc_tun_encap.c475 kfree(e->tun_info); in mlx5e_encap_dealloc()
664 e_key.ip_tun_key = &e->tun_info->key; in mlx5e_encap_get()
692 struct ip_tunnel_info *mlx5e_dup_tun_info(const struct ip_tunnel_info *tun_info) in mlx5e_dup_tun_info() argument
694 size_t tun_size = sizeof(*tun_info) + tun_info->options_len; in mlx5e_dup_tun_info()
696 return kmemdup(tun_info, tun_size, GFP_KERNEL); in mlx5e_dup_tun_info()
829 const struct ip_tunnel_info *tun_info; in mlx5e_attach_encap() local
842 tun_info = parse_attr->tun_info[out_index]; in mlx5e_attach_encap()
844 family = ip_tunnel_info_af(tun_info); in mlx5e_attach_encap()
845 key.ip_tun_key = &tun_info->key; in mlx5e_attach_encap()
878 tun_info = mlx5e_dup_tun_info(tun_info); in mlx5e_attach_encap()
[all …]
H A Dtc_tun_vxlan.c66 int dst_port = be16_to_cpu(e->tun_info->key.tp_dst); in mlx5e_tc_tun_init_encap_attr_vxlan()
87 const struct ip_tunnel_key *tun_key = &e->tun_info->key; in mlx5e_gen_ip_tunnel_header_vxlan()
94 e->tun_info->options_len != sizeof(*md)) in mlx5e_gen_ip_tunnel_header_vxlan()
103 md = ip_tunnel_info_opts(e->tun_info); in mlx5e_gen_ip_tunnel_header_vxlan()
H A Dtc_tun_gre.c14 return gre_calc_hlen(e->tun_info->key.tun_flags); in mlx5e_tc_tun_calc_hlen_gretap()
31 const struct ip_tunnel_key *tun_key = &e->tun_info->key; in mlx5e_gen_ip_tunnel_header_gretap()
H A Dtc_tun_encap.h42 struct ip_tunnel_info *mlx5e_dup_tun_info(const struct ip_tunnel_info *tun_info);
H A Dtc_tun_mplsoudp.c32 const struct ip_tunnel_key *tun_key = &r->tun_info->key; in generate_ip_tun_hdr()
H A Dtc_priv.h36 const struct ip_tunnel_info *tun_info[MLX5_MAX_FLOW_FWD_VPORTS]; member
/linux/net/netfilter/
H A Dnft_tunnel.c29 struct ip_tunnel_info *tun_info; in nft_tunnel_get_eval() local
31 tun_info = skb_tunnel_info(pkt->skb); in nft_tunnel_get_eval()
35 if (!tun_info) { in nft_tunnel_get_eval()
41 !(tun_info->mode & IP_TUNNEL_INFO_TX)) || in nft_tunnel_get_eval()
43 (tun_info->mode & IP_TUNNEL_INFO_TX))) in nft_tunnel_get_eval()
49 if (!tun_info) { in nft_tunnel_get_eval()
55 !(tun_info->mode & IP_TUNNEL_INFO_TX)) || in nft_tunnel_get_eval()
57 (tun_info->mode & IP_TUNNEL_INFO_TX))) in nft_tunnel_get_eval()
58 *dest = ntohl(tunnel_id_to_key32(tun_info->key.tun_id)); in nft_tunnel_get_eval()
514 memcpy(&md->u.tun_info, in nft_tunnel_obj_init()
[all...]
H A Dnf_flow_table_offload.c34 struct ip_tunnel_info *tun_info) in nf_flow_rule_lwt_match() argument
40 if (!tun_info || !(tun_info->mode & IP_TUNNEL_INFO_TX)) in nf_flow_rule_lwt_match()
45 key->enc_key_id.keyid = tunnel_id_to_key32(tun_info->key.tun_id); in nf_flow_rule_lwt_match()
50 if (ip_tunnel_info_af(tun_info) == AF_INET) { in nf_flow_rule_lwt_match()
53 key->enc_ipv4.src = tun_info->key.u.ipv4.dst; in nf_flow_rule_lwt_match()
54 key->enc_ipv4.dst = tun_info->key.u.ipv4.src; in nf_flow_rule_lwt_match()
62 memcpy(&key->enc_ipv6.src, &tun_info->key.u.ipv6.dst, in nf_flow_rule_lwt_match()
64 memcpy(&key->enc_ipv6.dst, &tun_info->key.u.ipv6.src, in nf_flow_rule_lwt_match()
97 struct ip_tunnel_info *tun_info; in nf_flow_rule_match() local
109 tun_info = lwt_tun_info(other_dst->lwtstate); in nf_flow_rule_match()
[all …]
/linux/net/core/
H A Ddst.c174 dst_cache_reset_now(&md_dst->u.tun_info.dst_cache); in dst_release()
298 md_dst = kmalloc_flex(*md_dst, u.tun_info.options, optslen, flags); in metadata_dst_alloc()
312 dst_cache_destroy(&md_dst->u.tun_info.dst_cache); in metadata_dst_free()
326 md_dst = __alloc_percpu_gfp(struct_size(md_dst, u.tun_info.options, in metadata_dst_alloc_percpu()
348 dst_cache_destroy(&one_md_dst->u.tun_info.dst_cache); in metadata_dst_free_percpu()
/linux/net/bridge/
H A Dbr_vlan_tunnel.c79 metadata->u.tun_info.mode |= IP_TUNNEL_INFO_TX | IP_TUNNEL_INFO_BRIDGE; in __vlan_tunnel_info_add()
216 tunnel_dst->u.tun_info.mode |= IP_TUNNEL_INFO_TX | in br_handle_egress_vlan_tunnel()
218 tunnel_dst->u.tun_info.key.nhid = in br_handle_egress_vlan_tunnel()
/linux/net/ipv6/
H A Dip6_gre.c539 info = &tun_dst->u.tun_info; in ip6erspan_rcv()
708 struct ip_tunnel_info *tun_info; in skb_tunnel_info_txcheck() local
710 tun_info = skb_tunnel_info(skb); in skb_tunnel_info_txcheck()
711 if (unlikely(!tun_info || !(tun_info->mode & IP_TUNNEL_INFO_TX))) in skb_tunnel_info_txcheck()
714 return tun_info; in skb_tunnel_info_txcheck()
738 struct ip_tunnel_info *tun_info; in __gre6_xmit() local
742 tun_info = skb_tunnel_info_txcheck(skb); in __gre6_xmit()
743 if (IS_ERR(tun_info) || in __gre6_xmit()
744 unlikely(ip_tunnel_info_af(tun_info) != AF_INET6)) in __gre6_xmit()
747 key = &tun_info->key; in __gre6_xmit()
[all …]
/linux/tools/testing/selftests/drivers/net/hw/
H A Dtso.py96 def build_tunnel(cfg, outer_ipver, tun_info):
105 tun_type = tun_info[0]
106 tun_arg = tun_info[1]
95 build_tunnel(cfg, outer_ipver, tun_info) global() argument
/linux/drivers/net/ethernet/mellanox/mlx5/core/en/tc/act/
H A Dmirred.c185 parse_attr->tun_info[esw_attr->out_count] = in parse_mirred_encap()
186 mlx5e_dup_tun_info(parse_state->tun_info); in parse_mirred_encap()
188 if (!parse_attr->tun_info[esw_attr->out_count]) in parse_mirred_encap()
H A Dtun.c29 parse_state->tun_info = act->tunnel; in tc_act_parse_tun_encap()
H A Dact.h26 const struct ip_tunnel_info *tun_info; member
/linux/net/openvswitch/
H A Dflow_netlink.c980 struct ip_tunnel_info *tun_info) in ovs_nla_put_tunnel_info() argument
982 return __ip_tun_to_nlattr(skb, &tun_info->key, in ovs_nla_put_tunnel_info()
983 ip_tunnel_info_opts(tun_info), in ovs_nla_put_tunnel_info()
984 tun_info->options_len, in ovs_nla_put_tunnel_info()
985 ip_tunnel_info_af(tun_info), tun_info->mode); in ovs_nla_put_tunnel_info()
2731 struct ip_tunnel_info *tun_info; in validate_and_copy_set_tun() local
2769 err = dst_cache_init(&tun_dst->u.tun_info.dst_cache, GFP_KERNEL); in validate_and_copy_set_tun()
2785 tun_info = &tun_dst->u.tun_info; in validate_and_copy_set_tun()
2786 tun_info->mode = IP_TUNNEL_INFO_TX; in validate_and_copy_set_tun()
2788 tun_info->mode |= IP_TUNNEL_INFO_IPV6; in validate_and_copy_set_tun()
[all …]
H A Dvport.c495 const struct ip_tunnel_info *tun_info) in ovs_vport_receive() argument
511 tun_info = NULL; in ovs_vport_receive()
515 error = ovs_flow_key_extract(tun_info, skb, &key); in ovs_vport_receive()
H A Dflow_netlink.h50 struct ip_tunnel_info *tun_info);
/linux/drivers/net/ethernet/netronome/nfp/flower/
H A Dtunnel_conf.c55 } tun_info[]; member
76 } tun_info[]; member
225 if (pay_len != struct_size(payload, tun_info, count)) { in nfp_tunnel_keep_alive()
232 ipv4_addr = payload->tun_info[i].ipv4; in nfp_tunnel_keep_alive()
233 port = be32_to_cpu(payload->tun_info[i].egress_port); in nfp_tunnel_keep_alive()
267 if (pay_len != struct_size(payload, tun_info, count)) { in nfp_tunnel_keep_alive_v6()
274 ipv6_add = &payload->tun_info[i].ipv6; in nfp_tunnel_keep_alive_v6()
275 port = be32_to_cpu(payload->tun_info[i].egress_port); in nfp_tunnel_keep_alive_v6()

12