diff options
author | Jason A. Donenfeld <Jason@zx2c4.com> | 2016-11-06 12:43:30 +0100 |
---|---|---|
committer | Jason A. Donenfeld <Jason@zx2c4.com> | 2016-11-06 12:43:30 +0100 |
commit | 092a118bf8f5e4c23532c62b3c4a8c3293e65ed7 (patch) | |
tree | a9655d8e1d9bd700bac72b8fe1aaea8cf56eef61 | |
parent | data: squelch compiler warning on PARALLEL=n (diff) | |
download | wireguard-monolithic-historical-092a118bf8f5e4c23532c62b3c4a8c3293e65ed7.tar.xz wireguard-monolithic-historical-092a118bf8f5e4c23532c62b3c4a8c3293e65ed7.zip |
socket: release dst on routing loop
-rw-r--r-- | src/socket.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/src/socket.c b/src/socket.c index 4f8c4e8..069d45d 100644 --- a/src/socket.c +++ b/src/socket.c @@ -47,6 +47,7 @@ static inline int send4(struct wireguard_device *wg, struct sk_buff *skb, struct net_dbg_ratelimited("No route to %pISpfsc, error %d\n", addr, ret); goto err; } else if (unlikely(rt->dst.dev == skb->dev)) { + dst_release(&rt->dst); ret = -ELOOP; net_dbg_ratelimited("Avoiding routing loop to %pISpfsc\n", addr); goto err; @@ -105,6 +106,7 @@ static inline int send6(struct wireguard_device *wg, struct sk_buff *skb, struct net_dbg_ratelimited("No route to %pISpfsc, error %d\n", addr, ret); goto err; } else if (unlikely(dst->dev == skb->dev)) { + dst_release(dst); ret = -ELOOP; net_dbg_ratelimited("Avoiding routing loop to %pISpfsc\n", addr); goto err; |