On Mon, 2016-03-21 at 11:50 -0400, David Miller wrote: > From: Paolo Abeni <pab...@redhat.com> > Date: Mon, 21 Mar 2016 16:42:11 +0100 > > > Currently, ingress ipv4 broadcast datagrams are dropped if the > > ingress interface lacks an ipv4 address. This is caused by > > multiple issues: > > > > - in udp_v4_early_demux() ip_check_mc_rcu is invoked even on > > bcast packets > > > > - ip_route_input_slow() always try to validate the source > > > > This patch tries to address both issues, invoking ip_check_mc_rcu() > > only for mcast packets and calling fib_validate_source() only > > if the in_device has an address, at least. > > > > Fixes: 6e5403093261 ("ipv4/udp: Verify multicast group is ours in > > upd_v4_early_demux()") > > Signed-off-by: Paolo Abeni <pab...@redhat.com> > > I'm extremely weary to change the routing lookup code wrt. broadcast, > multicast, > etc. policies, ever. The checks in there have multiple decades of precedence > and therefore are extremely dangerous to modify. > > The UDP change in question didn't touch the generic routing code, therfore you > must fix this bug without modifying it either.
ok, I'll try to find something less intrusive. I'm not sure if it will be possible. Just a little addendum: the current issue is not caused only by the commit 6e5403093261, but also by some less trivial/older change into the routing lookup code I was unable to track exactly. Cheers, Paolo