Page MenuHomeFreeBSD

Add the ability to lookup the 3b PCP of a VLAN interface. Use it in toe_l2_resolve to fill up the complete vtag and not just the vid.
ClosedPublic

Authored by np on Aug 16 2018, 6:54 PM.
Tags
None
Referenced Files
F133577407: D16752.diff
Sun, Oct 26, 6:54 PM
F133497052: D16752.id.diff
Sun, Oct 26, 5:31 AM
F133483258: D16752.id46792.diff
Sun, Oct 26, 3:15 AM
Unknown Object (File)
Sat, Oct 25, 5:45 PM
Unknown Object (File)
Fri, Oct 24, 7:45 PM
Unknown Object (File)
Sun, Oct 19, 1:33 AM
Unknown Object (File)
Wed, Oct 15, 6:19 PM
Unknown Object (File)
Mon, Oct 13, 8:41 PM
Subscribers

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

This is modeled after VLAN_TAG (which is mislabeled and just returns the
vid instead of the entire tag). I'm ok with changing the behavior of
VLAN_TAG to return the full tag including pcp but I went with a separate
VLAN_PCP to avoid surprising existing users of VLAN_TAG.

I am fine with that, but I am not quite sure why do you want VLAN_PCP() at all. if_pcp can be directly accessed and used when it is != IFNET_PCP_NONE.

This revision is now accepted and ready to land.Aug 16 2018, 10:10 PM
mjoras added inline comments.
sys/net/if_vlan.c
768 ↗(On Diff #46792)

Do you want this to be safe across vlan interface removal? If so you need to have locked access here.

I decided to grab the PCP from the ifvlan (like VLAN_TAG does). I believe ifconfig ... vlanpcp <foo> updates this field.
ifconfig ... pcp <foo> updates the if_pcp field but I don't see any code that attempts to keep the ifvlan's pcp
and the ifnet's pcp in sync when the ifnet is a vlan ifnet.

np marked an inline comment as done.Aug 16 2018, 10:42 PM
np added inline comments.
sys/net/if_vlan.c
768 ↗(On Diff #46792)

I want this to be as similar as possible to the vlan_tag a few lines above :-)

This revision was automatically updated to reflect the committed changes.
np marked an inline comment as done.