[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <m11vt9fbgj.fsf@fess.ebiederm.org>
Date: Sat, 07 Mar 2009 10:13:16 -0800
From: ebiederm@...ssion.com (Eric W. Biederman)
To: Ben Greear <greearb@...delatech.com>
Cc: Mark Smith
<nanog@...5b20a518b8f6864949bd940457dc124746ddc.nosense.org>,
Patrick McHardy <kaber@...sh.net>,
David Miller <davem@...emloft.net>, netdev@...r.kernel.org,
shemminger@...ux-foundation.org
Subject: Re: MACVLANs really best solution? How about a bridge with multiple bridge virtual interfaces? (was Re: [PATCH] macvlan: Support creating macvlans from macvlans)
Ben Greear <greearb@...delatech.com> writes:
> Mark Smith wrote:
>> Hi,
>>
>> Ben said,
>>
>>> I wouldn't deny sending with wrong source mac..ethernet interfaces can do
>>> this,
>>> and mac-vlan should look as much like ethernet is possible.
>>>
>>
>> I agree, however there's further things that mac-vlans aren't
>> currently doing as virtual ethernet interfaces that real ones do.
>> Unicast ethernet traffic sent out one mac-vlan interface with a
>> destination address of another mac-vlan interface on the same host
>> isn't delivered. mac-vlan interfaces, even though they're conceptually
>> located on the same ethernet segment, are currently isolated from each
>> other for unicast traffic.
>>
> At least for my use, having them all blindly TX is fine. For thousands
> of interfaces, if you did this right and also delivered all broadcast packets
> locally
> (ie, ARP), you will cause a lot of overhead, and unless you are running a
> patched
> kernel (or namespaces perhaps), you can't really communicate with yourself over
> the
> network anyway using IP.
>
> For the behaviour you want, try adding pairs of VETH interfaces and add one end
> of the veth's to the bridge. Add a physical port to the bridge for egress.
> Since this
> can be done, I don't really see any reason to change mac-vlan significantly...
>
> If the veth/bridge thing doesn't work, then let us know, as I think that would
> be
> a bug. I use a similar-to-veth virtual-device pair in this way and it works
> fine.
There is one scenario in which macvlans totally beat bridging veth
devices. macvlans support the full set of stateless hardware
offloads that the hardware supports. Whereas veth device support none
of them.
I don't think changing macvlans makes a lot of sense. Beyond the
pain of making it work, there are the semantic differences of local
broadcast working.
Doing something so that bridges have roughly the same performance
as macvlans would be very nice. I think it requires advertising
most if not all stateless hardware offloads, and then implementing
them in software on the endpoints that don't support them.
I did get as far as implementing a first draft at looping packets back
locally and behaviour difference for broadcasts and multicast
differences made macvlans a bad fit. For clean code something like
the bridge code where you don't use the original interface directly
for sending and receiving traffic seems required.
Eric
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists