aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/src
diff options
context:
space:
mode:
authorJason A. Donenfeld <Jason@zx2c4.com>2016-11-06 12:43:30 +0100
committerJason A. Donenfeld <Jason@zx2c4.com>2016-11-06 12:43:30 +0100
commit092a118bf8f5e4c23532c62b3c4a8c3293e65ed7 (patch)
treea9655d8e1d9bd700bac72b8fe1aaea8cf56eef61 /src
parentdata: squelch compiler warning on PARALLEL=n (diff)
downloadwireguard-monolithic-historical-092a118bf8f5e4c23532c62b3c4a8c3293e65ed7.tar.xz
wireguard-monolithic-historical-092a118bf8f5e4c23532c62b3c4a8c3293e65ed7.zip
socket: release dst on routing loop
Diffstat (limited to 'src')
-rw-r--r--src/socket.c2
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;