|
@@ -1026,6 +1026,7 @@ struct dst_entry *ip6_dst_lookup_flow(struct sock *sk, struct flowi *fl,
|
|
if (final_dst)
|
|
if (final_dst)
|
|
ipv6_addr_copy(&fl->fl6_dst, final_dst);
|
|
ipv6_addr_copy(&fl->fl6_dst, final_dst);
|
|
if (want_blackhole) {
|
|
if (want_blackhole) {
|
|
|
|
+ fl->flags |= FLOWI_FLAG_CAN_SLEEP;
|
|
err = __xfrm_lookup(sock_net(sk), &dst, fl, sk, XFRM_LOOKUP_WAIT);
|
|
err = __xfrm_lookup(sock_net(sk), &dst, fl, sk, XFRM_LOOKUP_WAIT);
|
|
if (err == -EREMOTE)
|
|
if (err == -EREMOTE)
|
|
err = ip6_dst_blackhole(sk, &dst, fl);
|
|
err = ip6_dst_blackhole(sk, &dst, fl);
|
|
@@ -1070,6 +1071,7 @@ struct dst_entry *ip6_sk_dst_lookup_flow(struct sock *sk, struct flowi *fl,
|
|
if (final_dst)
|
|
if (final_dst)
|
|
ipv6_addr_copy(&fl->fl6_dst, final_dst);
|
|
ipv6_addr_copy(&fl->fl6_dst, final_dst);
|
|
if (want_blackhole) {
|
|
if (want_blackhole) {
|
|
|
|
+ fl->flags |= FLOWI_FLAG_CAN_SLEEP;
|
|
err = __xfrm_lookup(sock_net(sk), &dst, fl, sk, XFRM_LOOKUP_WAIT);
|
|
err = __xfrm_lookup(sock_net(sk), &dst, fl, sk, XFRM_LOOKUP_WAIT);
|
|
if (err == -EREMOTE)
|
|
if (err == -EREMOTE)
|
|
err = ip6_dst_blackhole(sk, &dst, fl);
|
|
err = ip6_dst_blackhole(sk, &dst, fl);
|