diff options
author | David Gwynne <dlg@cvs.openbsd.org> | 2020-07-22 00:29:01 +0000 |
---|---|---|
committer | David Gwynne <dlg@cvs.openbsd.org> | 2020-07-22 00:29:01 +0000 |
commit | 547bd856b3aefa801c25796cc7f187126a88b0b8 (patch) | |
tree | afc62461275b4b7f592863ce075b7d18d7c83b50 /sys/net/trunklacp.c | |
parent | 67af9a0b189ec9b044e91b9d0b898f7e736d20a7 (diff) |
add code to coordinate how bridges attach to ethernet interfaces.
this is the first step in refactoring how ethernet frames are demuxed
by virtual interfaces, and also in deprecating interface input list
handling.
we now have drivers for three types of virtual bridges, bridge(4),
switch(4), and tpmr(4), and it doesn't make sense for any of them
to be enabled on the same "port" interfaces at the same time.
currently you can add a port interface to multiple types of bridge,
but which one gets to steal the packets depends on the order in
which they were attached.
this creates an ether_brport structure that holds an input function
for the bridge, and optionally some per port state that the bridge
can use. arpcom has a single pointer to one of these structs that
will be used during normal ether_input processing to see if a packet
should be passed to a bridge, and will be used instead of an if
input handler. because it is a single pointer, it will make sure
only one bridge of any type is attached to a port at any one time.
this has been in snaps as part of a larger diff for over a week.
Diffstat (limited to 'sys/net/trunklacp.c')
0 files changed, 0 insertions, 0 deletions