[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <1583859760-18364-1-git-send-email-martinvarghesenokia@gmail.com>
Date: Tue, 10 Mar 2020 22:32:40 +0530
From: Martin Varghese <martinvarghesenokia@...il.com>
To: netdev@...r.kernel.org, davem@...emloft.net,
martin.varghese@...ia.com
Subject: [PATCH net-next] bareudp: Fixed bareudp receive handling
From: Martin Varghese <martin.varghese@...ia.com>
Reverted commit "2baecda bareudp: remove unnecessary udp_encap_enable() in
bareudp_socket_create()"
An explicit call to udp_encap_enable is needed as the setup_udp_tunnel_sock
does not call udp_encap_enable if the if the socket is of type v6.
Bareudp device uses v6 socket to receive v4 & v6 traffic
Signed-off-by: Martin Varghese <martin.varghese@...ia.com>
Fixes: 2baecda37f4e ("bareudp: remove unnecessary udp_encap_enable() in bareudp_socket_create()")
---
drivers/net/bareudp.c | 3 +++
1 file changed, 3 insertions(+)
diff --git a/drivers/net/bareudp.c b/drivers/net/bareudp.c
index 71a2f48..c9d0d68 100644
--- a/drivers/net/bareudp.c
+++ b/drivers/net/bareudp.c
@@ -250,6 +250,9 @@ static int bareudp_socket_create(struct bareudp_dev *bareudp, __be16 port)
tunnel_cfg.encap_destroy = NULL;
setup_udp_tunnel_sock(bareudp->net, sock, &tunnel_cfg);
+ if (sock->sk->sk_family == AF_INET6)
+ udp_encap_enable();
+
rcu_assign_pointer(bareudp->sock, sock);
return 0;
}
--
1.8.3.1
Powered by blists - more mailing lists