Message ID | 1583982231-20060-1-git-send-email-martinvarghesenokia@gmail.com |
---|---|
State | Accepted |
Delegated to: | David Miller |
Headers | show |
Series | [net-next,v2] bareudp: Fixed bareudp receive handling | expand |
From: Martin Varghese <martinvarghesenokia@gmail.com> Date: Thu, 12 Mar 2020 08:33:51 +0530 > From: Martin Varghese <martin.varghese@nokia.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 > > CC: Taehee Yoo <ap420073@gmail.com> > Fixes: 2baecda37f4e ("bareudp: remove unnecessary udp_encap_enable() in bareudp_socket_create()") > Signed-off-by: Martin Varghese <martin.varghese@nokia.com> > --- > Changes in v2: > - Add Comments in the code. Applied, thanks Martin.
diff --git a/drivers/net/bareudp.c b/drivers/net/bareudp.c index 71a2f48..cc0703c 100644 --- a/drivers/net/bareudp.c +++ b/drivers/net/bareudp.c @@ -250,6 +250,12 @@ 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); + /* As the setup_udp_tunnel_sock does not call udp_encap_enable if the + * socket type is v6 an explicit call to udp_encap_enable is needed. + */ + if (sock->sk->sk_family == AF_INET6) + udp_encap_enable(); + rcu_assign_pointer(bareudp->sock, sock); return 0; }