Home
last modified time | relevance | path

Searched refs:lwtstate (Results 1 – 21 of 21) sorted by relevance

/linux/include/net/
H A Dlwtunnel.h48 struct lwtunnel_state *lwtstate);
49 int (*get_encap_size)(struct lwtunnel_state *lwtstate);
80 static inline bool lwtunnel_output_redirect(struct lwtunnel_state *lwtstate) in lwtunnel_output_redirect() argument
82 if (lwtstate && (lwtstate->flags & LWTUNNEL_STATE_OUTPUT_REDIRECT)) in lwtunnel_output_redirect()
88 static inline bool lwtunnel_input_redirect(struct lwtunnel_state *lwtstate) in lwtunnel_input_redirect() argument
90 if (lwtstate && (lwtstate->flags & LWTUNNEL_STATE_INPUT_REDIRECT)) in lwtunnel_input_redirect()
96 static inline bool lwtunnel_xmit_redirect(struct lwtunnel_state *lwtstate) in lwtunnel_xmit_redirect() argument
98 if (lwtstate && (lwtstate->flags & LWTUNNEL_STATE_XMIT_REDIRECT)) in lwtunnel_xmit_redirect()
104 static inline unsigned int lwtunnel_headroom(struct lwtunnel_state *lwtstate, in lwtunnel_headroom() argument
107 if ((lwtunnel_xmit_redirect(lwtstate) || in lwtunnel_headroom()
[all …]
H A Ddst_metadata.h64 if (dst && dst->lwtstate && in skb_tunnel_info()
65 (dst->lwtstate->type == LWTUNNEL_ENCAP_IP || in skb_tunnel_info()
66 dst->lwtstate->type == LWTUNNEL_ENCAP_IP6)) in skb_tunnel_info()
67 return lwt_tun_info(dst->lwtstate); in skb_tunnel_info()
86 if (dst && dst->lwtstate && in skb_xfrm_md_info()
87 dst->lwtstate->type == LWTUNNEL_ENCAP_XFRM) in skb_xfrm_md_info()
88 return lwt_xfrm_info(dst->lwtstate); in skb_xfrm_md_info()
H A Dmpls_iptunnel.h20 static inline struct mpls_iptunnel_encap *mpls_lwtunnel_encap(struct lwtunnel_state *lwtstate) in mpls_lwtunnel_encap() argument
22 return (struct mpls_iptunnel_encap *)lwtstate->data; in mpls_lwtunnel_encap()
H A Dip_tunnels.h704 static inline struct ip_tunnel_info *lwt_tun_info(struct lwtunnel_state *lwtstate) in lwt_tun_info() argument
706 return (struct ip_tunnel_info *)lwtstate->data; in lwt_tun_info()
724 static inline struct ip_tunnel_info *lwt_tun_info(struct lwtunnel_state *lwtstate) in lwt_tun_info() argument
H A Dip.h502 res = mtu - lwtunnel_headroom(dst->lwtstate, mtu); in ip_dst_mtu_maybe_forward()
522 return mtu - lwtunnel_headroom(dst->lwtstate, mtu); in ip_skb_dst_mtu()
/linux/net/core/
H A Dlwtunnel.c229 int lwtunnel_fill_encap(struct sk_buff *skb, struct lwtunnel_state *lwtstate, in lwtunnel_fill_encap() argument
236 if (!lwtstate) in lwtunnel_fill_encap()
239 if (lwtstate->type == LWTUNNEL_ENCAP_NONE || in lwtunnel_fill_encap()
240 lwtstate->type > LWTUNNEL_ENCAP_MAX) in lwtunnel_fill_encap()
249 ops = rcu_dereference(lwtun_encaps[lwtstate->type]); in lwtunnel_fill_encap()
251 ret = ops->fill_encap(skb, lwtstate); in lwtunnel_fill_encap()
257 ret = nla_put_u16(skb, encap_type_attr, lwtstate->type); in lwtunnel_fill_encap()
270 int lwtunnel_get_encap_size(struct lwtunnel_state *lwtstate) in lwtunnel_get_encap_size() argument
275 if (!lwtstate) in lwtunnel_get_encap_size()
278 if (lwtstate->type == LWTUNNEL_ENCAP_NONE || in lwtunnel_get_encap_size()
[all …]
H A Ddst.c68 dst->lwtstate = NULL; in dst_init()
117 lwtstate_put(dst->lwtstate); in dst_destroy()
/linux/net/ipv6/ila/
H A Dila_lwt.c42 struct ila_lwt *ilwt = ila_lwt_lwtunnel(orig_dst->lwtstate); in ila_output()
51 ila_params_lwtunnel(orig_dst->lwtstate), in ila_output()
58 return orig_dst->lwtstate->orig_output(net, sk, skb); in ila_output()
92 if (ilwt->connected && orig_dst->lwtstate != dst->lwtstate) { in ila_output()
111 struct ila_lwt *ilwt = ila_lwt_lwtunnel(dst->lwtstate); in ila_input()
118 ila_params_lwtunnel(dst->lwtstate), in ila_input()
121 return dst->lwtstate->orig_input(skb); in ila_input()
270 struct lwtunnel_state *lwtstate) in ila_fill_encap_info() argument
272 struct ila_params *p = ila_params_lwtunnel(lwtstate); in ila_fill_encap_info()
273 struct ila_lwt *ilwt = ila_lwt_lwtunnel(lwtstate); in ila_fill_encap_info()
[all …]
/linux/net/ipv6/
H A Drpl_iptunnel.c199 tinfo = rpl_encap_lwtunnel(dst->lwtstate); in rpl_do_srh()
211 rlwt = rpl_lwt_lwtunnel(orig_dst->lwtstate); in rpl_output()
239 if (orig_dst->lwtstate != dst->lwtstate) { in rpl_output()
274 lwtst = orig_dst->lwtstate; in rpl_input()
293 if (!dst->error && lwtst != dst->lwtstate) { in rpl_input()
335 struct lwtunnel_state *lwtstate) in rpl_fill_encap_info() argument
337 struct rpl_iptunnel_encap *tuninfo = rpl_encap_lwtunnel(lwtstate); in rpl_fill_encap_info()
345 static int rpl_encap_nlsize(struct lwtunnel_state *lwtstate) in rpl_encap_nlsize() argument
347 struct rpl_iptunnel_encap *tuninfo = rpl_encap_lwtunnel(lwtstate); in rpl_encap_nlsize()
H A Dioam6_iptunnel.c349 ilwt = ioam6_lwt_state(orig_dst->lwtstate); in ioam6_output()
430 if (orig_dst->lwtstate == dst->lwtstate) in ioam6_output()
445 if (orig_dst->lwtstate != dst->lwtstate) { in ioam6_output()
452 return orig_dst->lwtstate->orig_output(net, sk, skb); in ioam6_output()
469 struct lwtunnel_state *lwtstate) in ioam6_fill_encap_info() argument
471 struct ioam6_lwt *ilwt = ioam6_lwt_state(lwtstate); in ioam6_fill_encap_info()
505 static int ioam6_encap_nlsize(struct lwtunnel_state *lwtstate) in ioam6_encap_nlsize() argument
507 struct ioam6_lwt *ilwt = ioam6_lwt_state(lwtstate); in ioam6_encap_nlsize()
H A Dseg6_iptunnel.c388 tinfo = seg6_encap_lwtunnel(dst->lwtstate); in seg6_do_srh()
486 lwtst = orig_dst->lwtstate; in seg6_input_core()
505 if (!dst->error && lwtst != dst->lwtstate) { in seg6_input_core()
564 slwt = seg6_lwt_lwtunnel(orig_dst->lwtstate); in seg6_output_core()
592 if (orig_dst->lwtstate != dst->lwtstate) { in seg6_output_core()
731 struct lwtunnel_state *lwtstate) in seg6_fill_encap_info() argument
733 struct seg6_iptunnel_encap *tuninfo = seg6_encap_lwtunnel(lwtstate); in seg6_fill_encap_info()
741 static int seg6_encap_nlsize(struct lwtunnel_state *lwtstate) in seg6_encap_nlsize() argument
743 struct seg6_iptunnel_encap *tuninfo = seg6_encap_lwtunnel(lwtstate); in seg6_encap_nlsize()
H A Dseg6_local.c912 slwt = seg6_local_lwtunnel(orig_dst->lwtstate); in input_action_end_dx6_finish()
965 slwt = seg6_local_lwtunnel(orig_dst->lwtstate); in input_action_end_dx4_finish()
1618 slwt = seg6_local_lwtunnel(orig_dst->lwtstate); in seg6_local_input_core()
H A Dip6_output.c114 if (lwtunnel_xmit_redirect(dst->lwtstate)) { in ip6_finish_output2()
H A Droute.c1154 rt->dst.lwtstate = lwtstate_get(res->nh->fib_nh_lws); in ip6_rt_init_dst()
5868 if (lwtunnel_fill_encap(skb, dst->lwtstate, RTA_ENCAP, RTA_ENCAP_TYPE) < 0) in rt6_fill_node()
/linux/net/mpls/
H A Dmpls_iptunnel.c59 !dst->lwtstate || skb_warn_if_lro(skb)) in mpls_xmit()
64 tun_encap_info = mpls_lwtunnel_encap(dst->lwtstate); in mpls_xmit()
227 struct lwtunnel_state *lwtstate) in mpls_fill_encap_info() argument
231 tun_encap_info = mpls_lwtunnel_encap(lwtstate); in mpls_fill_encap_info()
247 static int mpls_encap_nlsize(struct lwtunnel_state *lwtstate) in mpls_encap_nlsize() argument
252 tun_encap_info = mpls_lwtunnel_encap(lwtstate); in mpls_encap_nlsize()
/linux/net/ipv4/
H A Dip_tunnel_core.c751 static void ip_tun_destroy_state(struct lwtunnel_state *lwtstate) in ip_tun_destroy_state() argument
754 struct ip_tunnel_info *tun_info = lwt_tun_info(lwtstate); in ip_tun_destroy_state()
869 struct lwtunnel_state *lwtstate) in ip_tun_fill_encap_info() argument
871 struct ip_tunnel_info *tun_info = lwt_tun_info(lwtstate); in ip_tun_fill_encap_info()
926 static int ip_tun_encap_nlsize(struct lwtunnel_state *lwtstate) in ip_tun_encap_nlsize() argument
934 + ip_tun_opts_nlsize(lwt_tun_info(lwtstate)); in ip_tun_encap_nlsize()
1039 struct lwtunnel_state *lwtstate) in ip6_tun_fill_encap_info() argument
1041 struct ip_tunnel_info *tun_info = lwt_tun_info(lwtstate); in ip6_tun_fill_encap_info()
1057 static int ip6_tun_encap_nlsize(struct lwtunnel_state *lwtstate) in ip6_tun_encap_nlsize() argument
1065 + ip_tun_opts_nlsize(lwt_tun_info(lwtstate)); in ip6_tun_encap_nlsize()
H A Dfib_semantics.c625 struct lwtunnel_state *lwtstate; in fib_nh_common_init() local
628 nhc->nhc_family, cfg, &lwtstate, in fib_nh_common_init()
633 nhc->nhc_lwtstate = lwtstate_get(lwtstate); in fib_nh_common_init()
884 struct lwtunnel_state *lwtstate; in fib_encap_match() local
891 cfg, &lwtstate, extack); in fib_encap_match()
893 result = lwtunnel_cmp_encap(lwtstate, nh->fib_nh_lws); in fib_encap_match()
894 lwtstate_free(lwtstate); in fib_encap_match()
H A Droute.c1617 rt->dst.lwtstate = lwtstate_get(nhc->nhc_lwtstate); in rt_set_nexthop()
1700 new_rt->dst.lwtstate = lwtstate_get(rt->dst.lwtstate); in rt_dst_clone()
2450 rth->dst.lwtstate = lwtstate_get(nhc->nhc_lwtstate); in ip_route_input_slow()
2451 if (lwtunnel_input_redirect(rth->dst.lwtstate)) { in ip_route_input_slow()
2453 rth->dst.lwtstate->orig_input = rth->dst.input; in ip_route_input_slow()
2991 if (lwtunnel_fill_encap(skb, rt->dst.lwtstate, RTA_ENCAP, RTA_ENCAP_TYPE) < 0) in rt_fill_info()
H A Dip_output.c223 if (lwtunnel_xmit_redirect(dst->lwtstate)) { in ip_finish_output2()
/linux/net/netfilter/
H A Dnf_flow_table_offload.c108 if (other_dst && other_dst->lwtstate) { in nf_flow_rule_match()
109 tun_info = lwt_tun_info(other_dst->lwtstate); in nf_flow_rule_match()
591 if (dst && dst->lwtstate) { in flow_offload_encap_tunnel()
594 tun_info = lwt_tun_info(dst->lwtstate); in flow_offload_encap_tunnel()
616 if (dst && dst->lwtstate) { in flow_offload_decap_tunnel()
619 tun_info = lwt_tun_info(dst->lwtstate); in flow_offload_decap_tunnel()
/linux/net/xfrm/
H A Dxfrm_interface_core.c123 static int xfrmi_encap_nlsize(struct lwtunnel_state *lwtstate) in xfrmi_encap_nlsize() argument