Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 51e398e8 authored by Wei Wang's avatar Wei Wang Committed by David S. Miller
Browse files

ipv6: don't release rt->rt6i_pcpu memory during rt6_release()



After rwlock is replaced with rcu and spinlock, route lookup can happen
simultanously with route deletion.
This patch removes the call to free_percpu(rt->rt6i_pcpu) from
rt6_release() to avoid the race condition between rt6_release() and
rt6_get_pcpu_route(). And as free_percpu(rt->rt6i_pcpu) is already
called in ip6_dst_destroy() after the rcu grace period, it is safe to do
this change.

Signed-off-by: default avatarWei Wang <weiwan@google.com>
Signed-off-by: default avatarMartin KaFai Lau <kafai@fb.com>
Signed-off-by: default avatarEric Dumazet <edumazet@google.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent a94b9367
Loading
Loading
Loading
Loading
+0 −3
Original line number Original line Diff line number Diff line
@@ -190,9 +190,6 @@ void rt6_free_pcpu(struct rt6_info *non_pcpu_rt)
			*ppcpu_rt = NULL;
			*ppcpu_rt = NULL;
		}
		}
	}
	}

	free_percpu(non_pcpu_rt->rt6i_pcpu);
	non_pcpu_rt->rt6i_pcpu = NULL;
}
}
EXPORT_SYMBOL_GPL(rt6_free_pcpu);
EXPORT_SYMBOL_GPL(rt6_free_pcpu);