svn commit: r304436 - in head: . sys/netinet
Slawa Olhovchenkov
slw at zxy.spb.ru
Sat Aug 20 20:41:16 UTC 2016
On Sat, Aug 20, 2016 at 09:34:06PM +0100, Bruce Simpson wrote:
> On 20/08/16 21:05, Bruce Simpson wrote:
> > Unless I am missing something crucial here? As far as I can tell,
> > arpresolve() unconditionally resolves L2 next-hop to the value of
> > ifp->if_broadcastaddr. And that is always set to 'etherbroadcastaddr' by
> > default for Ethernet ifnets: FF:FF:FF:FF:FF:FF.
> >
> > Would that not get past the M_BCAST check which replaced the call to
> > in_broadcast()?
>
> Based on my reading of the UDP-and-plumbing layer, it looks like we will
> only see FF:FF:FF:FF:FF:FF being used by the undirected IPv4 broadcast
> address, 255.255.255.255.
>
> But, in fact, this is probably a far more valid address to use for
> discovery services than the x.x.x.255-style IPv4 directed broadcast
> address, as, for Ethernet at least, it is guaranteed not to propagate
> beyond 1 union-of (on-link broadcast domain (layer 2, hop 1) & other
> ways that IPv4 subnet is bridged).
>
> So, Ryan -- your original reading of how in_broadcast() behaves is
> correct, modulo the all-ones bypassing it.
>
> (I believe dhclient and isc-dhcpd bypass it at BPF injection, though.)
What purpose to analyse L2 header?
Yes, curently FreeBSD don't support multiaccess media other then
ethernet (i.e. ATM, FrameRelay), but in case of mGRE L2 header will be
absent.
More information about the svn-src-head
mailing list