Page MenuHomeFreeBSD

bridge.4: Improve VLAN documentation
ClosedPublic

Authored by ivy on Jul 6 2025, 8:24 PM.
Tags
None
Referenced Files
Unknown Object (File)
Fri, Oct 24, 5:38 PM
Unknown Object (File)
Fri, Oct 24, 5:21 PM
Unknown Object (File)
Thu, Oct 23, 11:16 AM
Unknown Object (File)
Sat, Oct 18, 3:36 PM
Unknown Object (File)
Sat, Oct 18, 8:20 AM
Unknown Object (File)
Fri, Oct 17, 4:06 PM
Unknown Object (File)
Thu, Oct 16, 3:19 AM
Unknown Object (File)
Tue, Oct 14, 7:07 PM

Details

Summary

Consider this a draft; there are probably other things we want to
mention and perhaps the wording could be improved.

  • Document both "legacy" and "VLAN filtering" bridges, but steer users towards VLAN filtering bridges, because this configuration is better in 99% of cases.
  • Document the interaction between bridge(4) and vlan(4) which is confusing if you don't know what's going on. I haven't gone so far as to say configuring bridge(4) and vlan(4) on the same interface is unsupported, mainly because VLAN filtering bridges solve this problem anyway.
  • Provides some examples of VLAN filtering bridges, and examples of how to migrate from legacy bridges.

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 66956
Build 63839: arc lint + arc unit

Event Timeline

There are a very large number of changes, so older changes are hidden. Show Older Changes
ivy requested review of this revision.Jul 6 2025, 8:24 PM

This is awesome!

share/man/man4/bridge.4
295

Should we use filtered and unfiltered, or some other descriptive title? Using legacy as a name instead of an adjective gets a bit confusing, and doesn't age well if it's still around when a third idea comes out.

324

Should we use RFC style language to improve semantic density?

330

Does it make sense to put numbered examples in an EXAMPLES section?

363

Putting macros in titles is discouraged per mdoc(7)

share/man/man4/bridge.4
295

i'm open to other names for the "legacy" bridge configuration, but i'm not sure "unfiltered" really works: an "unfiltered bridge" is not a thing anyone knows about, so it's not very descriptive. "legacy" at least implies "this is the old way of doing it".

i would be open to something like "basic bridge" and "VLAN filtering bridge", except i don't really like "basic bridge", but perhaps there's another word we could use here?

324

unless we use that language in other manual pages (which i don't think we do?) i don't think that is more clear.

330

i thought about this and i really prefer having examples inline here, rather than referring to the EXAMPLES section, because it makes it easier for the reader to understand what's going on. trying to explain the configuration without being able to show actual ifconfig commands is quite difficult and ends up being more verbose and less explanatory, at least in my experience. but i'm open to other ways of doing this if you have a better suggestion.

363

noted, but then what is the preferred formatting here?

share/man/man4/bridge.4
356

note to self: typo, "a separate STP instances"

fix some instances of ye olde Britishe Englische

be consistent about "frames" vs "packets" and "Ethernet address" vs "MAC address"

be more clear about how STP works when a vlan(4) is in a bridge.

Suggested by: adrian

Nothing jumps out to me regarding spelling and grammar. I'd like someone more familiar with the topic to review the content.

share/man/man4/bridge.4
391

Audience check: how well understood is the DMZ acronym as it relates to networks?

This revision is now accepted and ready to land.Jul 10 2025, 7:16 PM
share/man/man4/bridge.4
295

I do not have any alternative names to propose but I think almost anything is better than legacy almost all the time.

312

Consider using an appositive instead of nested parentheticals. I think appositives always read more clearly than parentheticals, and especially nested parentheticals.

336

Also consider using an appositive.

363

Titles shouldn't have cross-references. I'm not sure I understand this clearly, maybe not because of your writing but just because I'm not a network engineer, but maybe something like "Configuring VLAN-aware bridges" or
"Understanding bridge VLAN capture"?

391

Almost all of this is well over my head except DMZ. Afaik DMZ is the first thing they teach you about networking.

This revision now requires review to proceed.Jul 11 2025, 2:51 AM
share/man/man4/bridge.4
312

since we never use the acronym again i've just removed it, and we can also remove "sometimes called" since this term comes from 802.1Q, so it's always called that.

336

the wording here was redundant, so i've changed it to simply say what it meant.

363

this section is about a specific interaction between bridge(4) and vlan(4) in FreeBSD, not about VLANs in general, so i think that should be reflected in the title. i've changed it to use "if_bridge and if_vlan" to make that a bit more clear without using Xr.

391

i think anyone reading this will know what a DMZ is, but that's a detail that isn't actually relevant to the example, so i've reworded it to talk about "isolated networks" instead.

This is a massively good update! Thank you so much! I hope it can be landed soon.

share/man/man4/bridge.4
698

I believe this is supposed to defuntagged 100 to match the vlan ID below? I hope I understand correctly.

share/man/man4/bridge.4
698

correct, i will fix this prior to landing

emaste added inline comments.
share/man/man4/bridge.4
297

I don't like "previous" here without a reference first (previous to what?). Maybe "releases prior to 15.0" or maybe describe filtering first and legacy second?

309

Will it become the default in the future?

share/man/man4/bridge.4
297

i was thinking "previous to this release", but i suppose that won't be true when someone is reading this manual page in FreeBSD 20.0.

the reason i wrote it this way around is because (at least technically) the vlan filtering bridge is just the same bridge with some extra features, so it felt reasonable to describe the shared features first then describe the extra features. however maybe this isn't the best way to present it to users... if we want users to use the vlan filtering bridge, we could describe that first, then have a short section on the legacy bridge that describes what you can't do and what you might want to do instead (e.g., vlan(4) in a bridge).

309

hard to say. i would like to make "vlanfilter defuntagged 1" the default at some point, but this means people would have to configure IP addresses on bridge0.1 instead of bridge0 and i expect a large amount of push-back on that (as we saw with member_ifaddrs) so it may end up being easier to leave things as they are but recommend people use the new setup.

share/man/man4/bridge.4
297

Yeah, that's exactly what I was thinking of. We have lots of "new" and "ng" and such which stop being new but don't lose the name - things like newbus. Maybe it's fine here though because it does go on to explain where the new mode arrived.

share/man/man4/bridge.4
297

what gives me pause is that it feels strange to describe an optional feature, then describe the default behaviour in a footnote... if we had consensus that vlanfilter will become the default, that would be fine, but otherwise it feels backwards.

i can't land this anyway until some other changes have gone in (particularly D51600) so i'll have a think in the mean time and maybe do another pass of the manpage before landing it.

share/man/man4/bridge.4
297

We have lots of "new" and "ng" and such which stop being new but don't lose the name - things like newbus.

Yes this is very bad and renaming things after the fact is harder than finding a decent name for them. New/ng/legacy as names really makes me sad, because it is broken and we will never fix it.

Theyre broken to begin with, age unacceptably poorly, and are not descriptive at all. All the worst elements. Almost as bad as $other_os making difficult to remember fantasy names that have no reflection on anything.

share/man/man4/bridge.4
297

the difference is that "newbus" is no longer the new bus, it's just the bus, whereas the legacy bridge will always be the legacy bridge (at least until we remove it... but i have no plans for that). a better comparison would be if i'd named these "bridge" and "new bridge", but, anticipating, this problem, i did not :-)

Legacy has a different set of similar problems. It really tells people nothing, and ages poorly. What happens when there's a third one, and we still have to support the first one because of compat?

ivy retitled this revision from bridge.4: improve VLAN documentation to bridge.4: Improve VLAN documentation.Aug 6 2025, 3:59 PM

rewrite

update to the current bridge syntax.

with D51760, vlan support in general is less tied to vlan filtering, so we can
describe vlan support first then document filtering as a separate feature.

Minor suggestion.

share/man/man4/bridge.4
284

How about using active voice here:
"..., it is recommended to assign all traffice to a VLAN ..."

ziaee added a reviewer: crest_rlwinm.de.

+1 for active voice

This revision is now accepted and ready to land.Sep 4 2025, 11:50 PM

the voice was made more active, as some reviewers had suggested

This revision now requires review to proceed.Sep 10 2025, 6:44 PM
This revision was not accepted when it landed; it landed in state Needs Review.Mon, Oct 13, 10:44 AM
This revision was automatically updated to reflect the committed changes.