Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
ipv6: release rt6->rt6i_idev properly during ifdown
When a dst is created by addrconf_dst_alloc() for a host route or an anycast route, dst->dev points to loopback dev while rt6->rt6i_idev points to a real device. When the real device goes down, the current cleanup code only checks for dst->dev and assumes rt6->rt6i_idev->dev is the same. This causes the refcount leak on the real device in the above situation. This patch makes sure to always release the refcount taken on rt6->rt6i_idev during dst_dev_put(). Fixes: 587fea7 ("ipv6: mark DST_NOGC and remove the operation of dst_free()") Reported-by: John Stultz <[email protected]> Tested-by: John Stultz <[email protected]> Tested-by: Martin KaFai Lau <[email protected]> Signed-off-by: Wei Wang <[email protected]> Signed-off-by: Martin KaFai Lau <[email protected]> Acked-by: David Ahern <[email protected]> Signed-off-by: David S. Miller <[email protected]>
- Loading branch information