Lines Matching refs:fl6

197 			       struct flowi6 *fl6)  in icmpv6_xrlim_allow()  argument
211 dst = ip6_route_output(net, sk, fl6); in icmpv6_xrlim_allow()
226 peer = inet_getpeer_v6(net->ipv6.peers, &fl6->daddr, 1); in icmpv6_xrlim_allow()
253 void icmpv6_push_pending_frames(struct sock *sk, struct flowi6 *fl6, in icmpv6_push_pending_frames() argument
270 icmp6h->icmp6_cksum = csum_ipv6_magic(&fl6->saddr, in icmpv6_push_pending_frames()
271 &fl6->daddr, in icmpv6_push_pending_frames()
272 len, fl6->flowi6_proto, in icmpv6_push_pending_frames()
283 icmp6h->icmp6_cksum = csum_ipv6_magic(&fl6->saddr, in icmpv6_push_pending_frames()
284 &fl6->daddr, in icmpv6_push_pending_frames()
285 len, fl6->flowi6_proto, in icmpv6_push_pending_frames()
338 struct flowi6 *fl6) in icmpv6_route_lookup() argument
344 err = ip6_dst_lookup(net, sk, &dst, fl6); in icmpv6_route_lookup()
352 if (ipv6_anycast_destination(dst, &fl6->daddr)) { in icmpv6_route_lookup()
361 dst = xfrm_lookup(net, dst, flowi6_to_flowi(fl6), sk, 0); in icmpv6_route_lookup()
432 struct flowi6 fl6; in icmp6_send() local
513 memset(&fl6, 0, sizeof(fl6)); in icmp6_send()
514 fl6.flowi6_proto = IPPROTO_ICMPV6; in icmp6_send()
515 fl6.daddr = hdr->saddr; in icmp6_send()
519 fl6.saddr = *saddr; in icmp6_send()
520 fl6.flowi6_mark = mark; in icmp6_send()
521 fl6.flowi6_oif = iif; in icmp6_send()
522 fl6.fl6_icmp_type = type; in icmp6_send()
523 fl6.fl6_icmp_code = code; in icmp6_send()
524 fl6.flowi6_uid = sock_net_uid(net, NULL); in icmp6_send()
525 fl6.mp_hash = rt6_multipath_hash(net, &fl6, skb, NULL); in icmp6_send()
526 security_skb_classify_flow(skb, flowi6_to_flowi(&fl6)); in icmp6_send()
535 if (!icmpv6_xrlim_allow(sk, type, &fl6)) in icmp6_send()
543 if (!fl6.flowi6_oif && ipv6_addr_is_multicast(&fl6.daddr)) in icmp6_send()
544 fl6.flowi6_oif = np->mcast_oif; in icmp6_send()
545 else if (!fl6.flowi6_oif) in icmp6_send()
546 fl6.flowi6_oif = np->ucast_oif; in icmp6_send()
549 fl6.flowlabel = ip6_make_flowinfo(ipc6.tclass, fl6.flowlabel); in icmp6_send()
551 dst = icmpv6_route_lookup(net, skb, sk, &fl6); in icmp6_send()
555 ipc6.hlimit = ip6_sk_dst_hoplimit(np, &fl6, dst); in icmp6_send()
575 &ipc6, &fl6, (struct rt6_info *)dst, in icmp6_send()
580 icmpv6_push_pending_frames(sk, &fl6, &tmp_hdr, in icmp6_send()
675 struct flowi6 fl6; in icmpv6_echo_reply() local
691 memset(&fl6, 0, sizeof(fl6)); in icmpv6_echo_reply()
692 fl6.flowi6_proto = IPPROTO_ICMPV6; in icmpv6_echo_reply()
693 fl6.daddr = ipv6_hdr(skb)->saddr; in icmpv6_echo_reply()
695 fl6.saddr = *saddr; in icmpv6_echo_reply()
696 fl6.flowi6_oif = icmp6_iif(skb); in icmpv6_echo_reply()
697 fl6.fl6_icmp_type = ICMPV6_ECHO_REPLY; in icmpv6_echo_reply()
698 fl6.flowi6_mark = mark; in icmpv6_echo_reply()
699 fl6.flowi6_uid = sock_net_uid(net, NULL); in icmpv6_echo_reply()
700 security_skb_classify_flow(skb, flowi6_to_flowi(&fl6)); in icmpv6_echo_reply()
709 if (!fl6.flowi6_oif && ipv6_addr_is_multicast(&fl6.daddr)) in icmpv6_echo_reply()
710 fl6.flowi6_oif = np->mcast_oif; in icmpv6_echo_reply()
711 else if (!fl6.flowi6_oif) in icmpv6_echo_reply()
712 fl6.flowi6_oif = np->ucast_oif; in icmpv6_echo_reply()
714 if (ip6_dst_lookup(net, sk, &dst, &fl6)) in icmpv6_echo_reply()
716 dst = xfrm_lookup(net, dst, flowi6_to_flowi(&fl6), sk, 0); in icmpv6_echo_reply()
727 ipc6.hlimit = ip6_sk_dst_hoplimit(np, &fl6, dst); in icmpv6_echo_reply()
732 sizeof(struct icmp6hdr), &ipc6, &fl6, in icmpv6_echo_reply()
737 icmpv6_push_pending_frames(sk, &fl6, &tmp_hdr, in icmpv6_echo_reply()
934 void icmpv6_flow_init(struct sock *sk, struct flowi6 *fl6, in icmpv6_flow_init() argument
940 memset(fl6, 0, sizeof(*fl6)); in icmpv6_flow_init()
941 fl6->saddr = *saddr; in icmpv6_flow_init()
942 fl6->daddr = *daddr; in icmpv6_flow_init()
943 fl6->flowi6_proto = IPPROTO_ICMPV6; in icmpv6_flow_init()
944 fl6->fl6_icmp_type = type; in icmpv6_flow_init()
945 fl6->fl6_icmp_code = 0; in icmpv6_flow_init()
946 fl6->flowi6_oif = oif; in icmpv6_flow_init()
947 security_sk_classify_flow(sk, flowi6_to_flowi(fl6)); in icmpv6_flow_init()