]> git.baikalelectronics.ru Git - kernel.git/commit
net/ipv4: Allow send to local broadcast from a socket bound to a VRF
authorDavid Ahern <dsahern@gmail.com>
Thu, 25 Jan 2018 03:37:38 +0000 (19:37 -0800)
committerDavid S. Miller <davem@davemloft.net>
Fri, 26 Jan 2018 02:51:31 +0000 (21:51 -0500)
commitbb25757c291ca9ab8809375a5b359b780a5a570c
treed99fa85b32350f876b977c55c2f11d39ee697f06
parent6bd0b195ed700186a7d6775b7aea220e898038cf
net/ipv4: Allow send to local broadcast from a socket bound to a VRF

Message sends to the local broadcast address (255.255.255.255) require
uc_index or sk_bound_dev_if to be set to an egress device. However,
responses or only received if the socket is bound to the device. This
is overly constraining for processes running in an L3 domain. This
patch allows a socket bound to the VRF device to send to the local
broadcast address by using IP_UNICAST_IF to set the egress interface
with packet receipt handled by the VRF binding.

Similar to IP_MULTICAST_IF, relax the constraint on setting
IP_UNICAST_IF if a socket is bound to an L3 master device. In this
case allow uc_index to be set to an enslaved if sk_bound_dev_if is
an L3 master device and is the master device for the ifindex.

In udp and raw sendmsg, allow uc_index to override the oif if
uc_index master device is oif (ie., the oif is an L3 master and the
index is an L3 slave).

Signed-off-by: David Ahern <dsahern@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/ipv4/ip_sockglue.c
net/ipv4/raw.c
net/ipv4/udp.c