Broadcom bge and 802.1Q vlan tags

Sam Leffler sam at errno.com
Tue Oct 12 08:54:05 PDT 2004


Gleb Smirnoff wrote:
> On Tue, Oct 12, 2004 at 10:36:27AM +0200, Roub?cek Zdenek (T-Systems PragoNet) wrote:
> R>  I have run into a problem with my Broadcom NIC (Dell LATITUDE D600). I am not able to detect 802.1Q tags on incoming interface with ethereal or tcpdump. All incoming packets seems like they are not coming through trunk but as native ETH frames, ie. the vlan tag is missing, probably removed before being passed to tcpdump?
> R> 
> R> No I have not tested NIC's behaviour on 4.X, but I is working with linux (2.6.something kernel probably?)
> R> 
> R> Any ideas what to modify or set so I can detect vlan_tag would be very apreciated.
> 
> As Ruslan already mentioned, it is impossible to turn off hardware VLAN
> stripping in bge driver.
> 
> A patch to stop tagged frames to come on trunk interface is like this:
> 
> @@ -701,13 +657,16 @@
>          * see if the device performed the decapsulation and
>          * provided us with the tag.
>          */
> -       if (ifp->if_nvlans &&
> -           m_tag_locate(m, MTAG_VLAN, MTAG_VLAN_TAG, NULL) != NULL) {
> +       if (m_tag_locate(m, MTAG_VLAN, MTAG_VLAN_TAG, NULL) != NULL) {
>                 /*
>                  * vlan_input() will either recursively call ether_input()
>                  * or drop the packet.
>                  */
> -               KASSERT(vlan_input_p != NULL,("ether_input: VLAN not loaded!"));
> +               if (vlan_input_p == NULL) {
> +                       /* vlan(4) is not loaded, discard frame */
> +                       m_freem(m);
> +                       return;
> +               }
>                 (*vlan_input_p)(ifp, m);
>                 return;
>         }
> 

This pessimizes normal traffic.  We should look for a solution in the 
driver(s) to avoid sending packets up with tags when no vlans are 
configured.

	Sam



More information about the freebsd-current mailing list