/openbmc/linux/net/ipv4/ |
H A D | ip_tunnel_core.c | 132 md->u.tun_info.mode & IP_TUNNEL_INFO_TX) in iptunnel_metadata_reply() 135 src = &md->u.tun_info; in iptunnel_metadata_reply() 140 dst = &res->u.tun_info; in iptunnel_metadata_reply() 659 struct ip_tunnel_info *tun_info; in ip_tun_build_state() local 671 new_state = lwtunnel_state_alloc(sizeof(*tun_info) + opt_len); in ip_tun_build_state() 677 tun_info = lwt_tun_info(new_state); in ip_tun_build_state() 679 err = ip_tun_set_opts(tb[LWTUNNEL_IP_OPTS], tun_info, extack); in ip_tun_build_state() 686 err = dst_cache_init(&tun_info->dst_cache, GFP_KERNEL); in ip_tun_build_state() 694 tun_info->key.tun_id = nla_get_be64(tb[LWTUNNEL_IP_ID]); in ip_tun_build_state() 697 tun_info->key.u.ipv4.dst = nla_get_in_addr(tb[LWTUNNEL_IP_DST]); in ip_tun_build_state() [all …]
|
H A D | ip_tunnel.c | 589 struct ip_tunnel_info *tun_info; in ip_md_tunnel_xmit() local 598 tun_info = skb_tunnel_info(skb); in ip_md_tunnel_xmit() 599 if (unlikely(!tun_info || !(tun_info->mode & IP_TUNNEL_INFO_TX) || in ip_md_tunnel_xmit() 600 ip_tunnel_info_af(tun_info) != AF_INET)) in ip_md_tunnel_xmit() 602 key = &tun_info->key; in ip_md_tunnel_xmit() 618 tunnel_hlen = ip_encap_hlen(&tun_info->encap); in ip_md_tunnel_xmit() 620 if (ip_tunnel_encap(skb, &tun_info->encap, &proto, &fl4) < 0) in ip_md_tunnel_xmit() 623 use_cache = ip_tunnel_dst_cache_usable(skb, tun_info); in ip_md_tunnel_xmit() 625 rt = dst_cache_get_ip4(&tun_info->dst_cache, &fl4.saddr); in ip_md_tunnel_xmit() 633 dst_cache_set_ip4(&tun_info->dst_cache, &rt->dst, in ip_md_tunnel_xmit() [all …]
|
H A D | ip_gre.c | 334 md = ip_tunnel_info_opts(&tun_dst->u.tun_info); in erspan_rcv() 340 info = &tun_dst->u.tun_info; in erspan_rcv() 486 struct ip_tunnel_info *tun_info; in gre_fb_xmit() local 491 tun_info = skb_tunnel_info(skb); in gre_fb_xmit() 492 if (unlikely(!tun_info || !(tun_info->mode & IP_TUNNEL_INFO_TX) || in gre_fb_xmit() 493 ip_tunnel_info_af(tun_info) != AF_INET)) in gre_fb_xmit() 496 key = &tun_info->key; in gre_fb_xmit() 503 if (gre_handle_offloads(skb, !!(tun_info->key.tun_flags & TUNNEL_CSUM))) in gre_fb_xmit() 506 flags = tun_info->key.tun_flags & in gre_fb_xmit() 509 tunnel_id_to_key32(tun_info->key.tun_id), in gre_fb_xmit() [all …]
|
/openbmc/linux/include/net/ |
H A D | dst_metadata.h | 36 struct ip_tunnel_info tun_info; member 60 return &md_dst->u.tun_info; in skb_tunnel_info() 118 return memcmp(&a->u.tun_info, &b->u.tun_info, in skb_metadata_dst_cmp() 119 sizeof(a->u.tun_info) + in skb_metadata_dst_cmp() 120 a->u.tun_info.options_len); in skb_metadata_dst_cmp() 147 tun_dst->u.tun_info.options_len = 0; in tun_rx_dst() 148 tun_dst->u.tun_info.mode = 0; in tun_rx_dst() 161 md_size = md_dst->u.tun_info.options_len; in tun_dst_unclone() 166 memcpy(&new_md->u.tun_info, &md_dst->u.tun_info, in tun_dst_unclone() 170 if (new_md->u.tun_info.dst_cache.cache) { in tun_dst_unclone() [all …]
|
/openbmc/linux/net/psample/ |
H A D | psample.c | 217 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() 290 struct ip_tunnel_info *tun_info) in psample_ip_tun_to_nlattr() argument 299 err = __psample_ip_tun_to_nlattr(skb, tun_info); in psample_ip_tun_to_nlattr() 310 static int psample_tunnel_meta_len(struct ip_tunnel_info *tun_info) in psample_tunnel_meta_len() argument 312 unsigned short tun_proto = ip_tunnel_info_af(tun_info); in psample_tunnel_meta_len() [all …]
|
/openbmc/linux/drivers/net/ethernet/mellanox/mlx5/core/en/ |
H A D | tc_tun_geneve.c | 19 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 = !!(tun_info->key.tun_flags & TUNNEL_OAM); in mlx5e_gen_ip_tunnel_header_geneve() 110 geneveh->critical = !!(tun_info->key.tun_flags & TUNNEL_CRIT_OPT); in mlx5e_gen_ip_tunnel_header_geneve() 111 mlx5e_tunnel_id_to_vni(tun_info->key.tun_id, geneveh->vni); in mlx5e_gen_ip_tunnel_header_geneve() 114 if (tun_info->key.tun_flags & TUNNEL_GENEVE_OPT) { in mlx5e_gen_ip_tunnel_header_geneve() 117 ip_tunnel_info_opts_get(geneveh->options, tun_info); in mlx5e_gen_ip_tunnel_header_geneve()
|
H A D | tc_tun_encap.c | 476 kfree(e->tun_info); in mlx5e_encap_dealloc() 665 e_key.ip_tun_key = &e->tun_info->key; in mlx5e_encap_get() 693 struct ip_tunnel_info *mlx5e_dup_tun_info(const struct ip_tunnel_info *tun_info) in mlx5e_dup_tun_info() argument 695 size_t tun_size = sizeof(*tun_info) + tun_info->options_len; in mlx5e_dup_tun_info() 697 return kmemdup(tun_info, tun_size, GFP_KERNEL); in mlx5e_dup_tun_info() 832 const struct ip_tunnel_info *tun_info; in mlx5e_attach_encap() local 845 tun_info = parse_attr->tun_info[out_index]; in mlx5e_attach_encap() 847 family = ip_tunnel_info_af(tun_info); in mlx5e_attach_encap() 848 key.ip_tun_key = &tun_info->key; in mlx5e_attach_encap() 881 tun_info = mlx5e_dup_tun_info(tun_info); in mlx5e_attach_encap() [all …]
|
H A D | tc_tun_vxlan.c | 66 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 D | tc_tun_gre.c | 14 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 D | tc_tun_encap.h | 42 struct ip_tunnel_info *mlx5e_dup_tun_info(const struct ip_tunnel_info *tun_info);
|
/openbmc/linux/net/netfilter/ |
H A D | nft_tunnel.c | 29 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() 510 memcpy(&md->u.tun_info, &info, sizeof(info)); in nft_tunnel_obj_init() [all …]
|
H A D | nf_flow_table_offload.c | 33 struct ip_tunnel_info *tun_info) in nf_flow_rule_lwt_match() argument 39 if (!tun_info || !(tun_info->mode & IP_TUNNEL_INFO_TX)) in nf_flow_rule_lwt_match() 44 key->enc_key_id.keyid = tunnel_id_to_key32(tun_info->key.tun_id); in nf_flow_rule_lwt_match() 49 if (ip_tunnel_info_af(tun_info) == AF_INET) { in nf_flow_rule_lwt_match() 52 key->enc_ipv4.src = tun_info->key.u.ipv4.dst; in nf_flow_rule_lwt_match() 53 key->enc_ipv4.dst = tun_info->key.u.ipv4.src; in nf_flow_rule_lwt_match() 61 memcpy(&key->enc_ipv6.src, &tun_info->key.u.ipv6.dst, in nf_flow_rule_lwt_match() 63 memcpy(&key->enc_ipv6.dst, &tun_info->key.u.ipv6.src, in nf_flow_rule_lwt_match() 96 struct ip_tunnel_info *tun_info; in nf_flow_rule_match() local 108 tun_info = lwt_tun_info(other_dst->lwtstate); in nf_flow_rule_match() [all …]
|
/openbmc/linux/net/bridge/ |
H A D | br_vlan_tunnel.c | 78 metadata->u.tun_info.mode |= IP_TUNNEL_INFO_TX | IP_TUNNEL_INFO_BRIDGE; in __vlan_tunnel_info_add() 210 tunnel_dst->u.tun_info.mode |= IP_TUNNEL_INFO_TX | in br_handle_egress_vlan_tunnel() 212 tunnel_dst->u.tun_info.key.nhid = in br_handle_egress_vlan_tunnel()
|
/openbmc/linux/net/ipv6/ |
H A D | ip6_gre.c | 577 info = &tun_dst->u.tun_info; in ip6erspan_rcv() 736 struct ip_tunnel_info *tun_info; in skb_tunnel_info_txcheck() local 738 tun_info = skb_tunnel_info(skb); in skb_tunnel_info_txcheck() 739 if (unlikely(!tun_info || !(tun_info->mode & IP_TUNNEL_INFO_TX))) in skb_tunnel_info_txcheck() 742 return tun_info; in skb_tunnel_info_txcheck() 766 struct ip_tunnel_info *tun_info; in __gre6_xmit() local 770 tun_info = skb_tunnel_info_txcheck(skb); in __gre6_xmit() 771 if (IS_ERR(tun_info) || in __gre6_xmit() 772 unlikely(ip_tunnel_info_af(tun_info) != AF_INET6)) in __gre6_xmit() 775 key = &tun_info->key; in __gre6_xmit() [all …]
|
/openbmc/linux/net/openvswitch/ |
H A D | flow.c | 1001 int ovs_flow_key_extract(const struct ip_tunnel_info *tun_info, in ovs_flow_key_extract() argument 1012 if (tun_info) { in ovs_flow_key_extract() 1013 key->tun_proto = ip_tunnel_info_af(tun_info); in ovs_flow_key_extract() 1014 memcpy(&key->tun_key, &tun_info->key, sizeof(key->tun_key)); in ovs_flow_key_extract() 1016 if (tun_info->options_len) { in ovs_flow_key_extract() 1017 BUILD_BUG_ON((1 << (sizeof(tun_info->options_len) * in ovs_flow_key_extract() 1021 ip_tunnel_info_opts_get(TUN_METADATA_OPTS(key, tun_info->options_len), in ovs_flow_key_extract() 1022 tun_info); in ovs_flow_key_extract() 1023 key->tun_opts_len = tun_info->options_len; in ovs_flow_key_extract()
|
H A D | flow_netlink.c | 967 struct ip_tunnel_info *tun_info) in ovs_nla_put_tunnel_info() argument 969 return __ip_tun_to_nlattr(skb, &tun_info->key, in ovs_nla_put_tunnel_info() 970 ip_tunnel_info_opts(tun_info), in ovs_nla_put_tunnel_info() 971 tun_info->options_len, in ovs_nla_put_tunnel_info() 972 ip_tunnel_info_af(tun_info), tun_info->mode); in ovs_nla_put_tunnel_info() 2766 struct ip_tunnel_info *tun_info; in validate_and_copy_set_tun() local 2805 err = dst_cache_init(&tun_dst->u.tun_info.dst_cache, GFP_KERNEL); in validate_and_copy_set_tun() 2821 tun_info = &tun_dst->u.tun_info; in validate_and_copy_set_tun() 2822 tun_info->mode = IP_TUNNEL_INFO_TX; in validate_and_copy_set_tun() 2824 tun_info->mode |= IP_TUNNEL_INFO_IPV6; in validate_and_copy_set_tun() [all …]
|
H A D | vport.c | 495 const struct ip_tunnel_info *tun_info) in ovs_vport_receive() argument 509 tun_info = NULL; in ovs_vport_receive() 513 error = ovs_flow_key_extract(tun_info, skb, &key); in ovs_vport_receive()
|
H A D | flow_netlink.h | 50 struct ip_tunnel_info *tun_info);
|
/openbmc/linux/drivers/net/ethernet/mellanox/mlx5/core/en/tc/act/ |
H A D | mirred.c | 185 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 D | tun.c | 29 parse_state->tun_info = act->tunnel; in tc_act_parse_tun_encap()
|
H A D | act.h | 26 const struct ip_tunnel_info *tun_info; member
|
/openbmc/linux/drivers/net/ethernet/netronome/nfp/flower/ |
H A D | tunnel_conf.c | 55 } 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()
|
/openbmc/linux/net/sched/ |
H A D | act_tunnel_key.c | 480 ret = dst_cache_init(&metadata->u.tun_info.dst_cache, GFP_KERNEL); in tunnel_key_init() 487 &metadata->u.tun_info, in tunnel_key_init() 493 metadata->u.tun_info.mode |= IP_TUNNEL_INFO_TX; in tunnel_key_init() 740 ¶ms->tcft_enc_metadata->u.tun_info; in tunnel_key_dump() 747 ¶ms->tcft_enc_metadata->u.tun_info) || in tunnel_key_dump()
|
/openbmc/linux/include/net/tc_act/ |
H A D | tc_tunnel_key.h | 64 return ¶ms->tcft_enc_metadata->u.tun_info; in tcf_tunnel_info()
|
/openbmc/linux/net/core/ |
H A D | dst.c | 305 dst_cache_destroy(&md_dst->u.tun_info.dst_cache); in metadata_dst_free() 340 dst_cache_destroy(&one_md_dst->u.tun_info.dst_cache); in metadata_dst_free_percpu()
|