Lines Matching refs:fl6
498 struct flowi6 fl6;
516 memset(&fl6, 0, sizeof(fl6));
518 fl6.flowi6_mark = READ_ONCE(sk->sk_mark);
519 fl6.flowi6_uid = sk->sk_uid;
532 fl6.flowlabel = lsa->l2tp_flowinfo & IPV6_FLOWINFO_MASK;
533 if (fl6.flowlabel & IPV6_FLOWLABEL_MASK) {
534 flowlabel = fl6_sock_lookup(sk, fl6.flowlabel);
550 fl6.flowi6_oif = lsa->l2tp_scope_id;
556 fl6.flowlabel = np->flow_label;
559 if (fl6.flowi6_oif == 0)
560 fl6.flowi6_oif = READ_ONCE(sk->sk_bound_dev_if);
568 err = ip6_datagram_send_ctl(sock_net(sk), sk, msg, &fl6, &ipc6);
573 if ((fl6.flowlabel & IPV6_FLOWLABEL_MASK) && !flowlabel) {
574 flowlabel = fl6_sock_lookup(sk, fl6.flowlabel);
591 fl6.flowi6_proto = sk->sk_protocol;
593 fl6.daddr = *daddr;
595 fl6.daddr.s6_addr[15] = 0x1; /* :: means loopback (BSD'ism) */
596 if (ipv6_addr_any(&fl6.saddr) && !ipv6_addr_any(&np->saddr))
597 fl6.saddr = np->saddr;
599 final_p = fl6_update_dst(&fl6, opt, &final);
601 if (!fl6.flowi6_oif && ipv6_addr_is_multicast(&fl6.daddr))
602 fl6.flowi6_oif = np->mcast_oif;
603 else if (!fl6.flowi6_oif)
604 fl6.flowi6_oif = np->ucast_oif;
606 security_sk_classify_flow(sk, flowi6_to_flowi_common(&fl6));
611 fl6.flowlabel = ip6_make_flowinfo(ipc6.tclass, fl6.flowlabel);
613 dst = ip6_dst_lookup_flow(sock_net(sk), sk, &fl6, final_p);
620 ipc6.hlimit = ip6_sk_dst_hoplimit(np, &fl6, dst);
633 &fl6, (struct rt6_info *)dst,
650 dst_confirm_neigh(dst, &fl6.daddr);