{
        struct sja1105_l2_lookup_params_entry *l2_lookup_params =
                priv->static_config.tables[BLK_IDX_L2_LOOKUP_PARAMS].entries;
-       u64 poly_koopman = l2_lookup_params->poly;
+       u64 input, poly_koopman = l2_lookup_params->poly;
        /* Convert polynomial from Koopman to 'normal' notation */
        u8 poly = (u8)(1 + (poly_koopman << 1));
-       u64 vlanid = l2_lookup_params->shared_learn ? 0 : vid;
-       u64 input = (vlanid << 48) | ether_addr_to_u64(addr);
        u8 crc = 0; /* seed */
        int i;
 
+       input = ((u64)vid << 48) | ether_addr_to_u64(addr);
+
        /* Mask the eight bytes starting from MSB one at a time */
        for (i = 56; i >= 0; i -= 8) {
                u8 byte = (input & (0xffull << i)) >> i;
 
 {
        struct sja1105_private *priv = ds->priv;
 
-       /* dsa_8021q is in effect when the bridge's vlan_filtering isn't,
-        * so the switch still does some VLAN processing internally.
-        * But Shared VLAN Learning (SVL) is also active, and it will take
-        * care of autonomous forwarding between the unique pvid's of each
-        * port.  Here we just make sure that users can't add duplicate FDB
-        * entries when in this mode - the actual VID doesn't matter except
-        * for what gets printed in 'bridge fdb show'.  In the case of zero,
-        * no VID gets printed at all.
-        */
-       if (!priv->vlan_aware)
-               vid = 0;
-
        return priv->info->fdb_add_cmd(ds, port, addr, vid);
 }
 
 {
        struct sja1105_private *priv = ds->priv;
 
-       if (!priv->vlan_aware)
-               vid = 0;
-
        return priv->info->fdb_del_cmd(ds, port, addr, vid);
 }