1. 10 6月, 2017 4 次提交
  2. 09 6月, 2017 31 次提交
  3. 08 6月, 2017 5 次提交
    • D
      Merge branch 'dsa-add-cross-chip-VLAN-support' · 6c8607eb
      David S. Miller 提交于
      Vivien Didelot says:
      
      ====================
      net: dsa: add cross-chip VLAN support
      
      The current code in DSA does not support cross-chip VLAN. This means
      that in a multi-chip environment such as this one (similar to ZII Rev B)
      
               [CPU].................... (mdio)
          (eth0) |   :       :          :
                _|_____    _______    _______
               [__sw0__]--[__sw1__]--[__sw2__]
                |  |  |    |  |  |    |  |  |
                v  v  v    v  v  v    v  v  v
                p1 p2 p3   p4 p5 p6   p7 p8 p9
      
      adding a VLAN to p9 won't be enough to reach the CPU, until at least one
      port of sw0 and sw1 join the VLAN as well and become aware of the VID.
      
      This patchset makes the DSA core program the VLAN on the CPU and DSA
      links itself, which brings seamlessly cross-chip VLAN support to DSA.
      
      With this series applied*, the hardware VLAN tables of a 3-switch setup
      look like this after adding a VLAN to only one port of the end switch:
      
          # cat /sys/class/net/br0/bridge/default_pvid
          42
          # cat /sys/kernel/debug/mv88e6xxx/sw{0,1,2}/vtu
          # ip link set up master br0 dev lan6
          # cat /sys/kernel/debug/mv88e6xxx/sw{0,1,2}/vtu
           VID  FID  SID  0  1  2  3  4  5  6
            42    1    0  x  x  x  x  x  =  =
           VID  FID  SID  0  1  2  3  4  5  6
            42    1    0  x  x  x  x  x  =  =
           VID  FID  SID  0  1  2  3  4  5  6  7  8  9
            42    1    0  u  x  x  x  x  x  x  x  x  =
      
      ('x' is excluded, 'u' is untagged, '=' is unmodified DSA and CPU ports.)
      
      Completely removing a VLAN entry (which is currently the responsibility
      of drivers anyway) is not supported yet since it requires some caching.
      
      (*) the output is shown from this out-of-tree debugfs patch:
      https://github.com/vivien/linux/commit/7b61a684b9d6b6a499135a587c7f62a1fddceb8b.patch
      
      Changes in v2:
        - canonical incrementation (port++ instead of ++port)
        - check CPU and DSA ports before purging a VLAN
        - add Reviewed-by tags
      ====================
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      6c8607eb
    • V
      net: dsa: mv88e6xxx: do not skip ports on VLAN del · adc3a9ce
      Vivien Didelot 提交于
      The mv88e6xxx driver currently tries to be smart and remove by itself a
      VLAN entry from the VTU when the driven switch sees no user ports as
      members of the VLAN.
      
      This is bad in a multi-chip switch fabric, since a chip in between
      others may have no bridge port members, but still needs to be aware of
      the VID in order to correctly pass frames in the data path.
      
      Now that the DSA core explicitly manages DSA and CPU ports, do not skip
      them when checking remaining VLAN members.
      Signed-off-by: NVivien Didelot <vivien.didelot@savoirfairelinux.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      adc3a9ce
    • V
      net: dsa: mv88e6xxx: exclude all ports in new VLAN · 553a768d
      Vivien Didelot 提交于
      Now that the DSA core adds the CPU and DSA ports itself to the new VLAN
      entry, there is no need to include them as members of this VLAN when
      initializing a new VTU entry.
      
      As of now, initialize a new VTU entry with all ports excluded.
      Reviewed-by: NFlorian Fainelli <f.fainelli@gmail.com>
      Signed-off-by: NVivien Didelot <vivien.didelot@savoirfairelinux.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      553a768d
    • V
      net: dsa: add CPU and DSA ports as VLAN members · b2f81d30
      Vivien Didelot 提交于
      In a multi-chip switch fabric, it is currently the responsibility of the
      driver to add the CPU or DSA (interconnecting chips together) ports as
      members of a new VLAN entry. This makes the drivers more complicated.
      
      We want the DSA drivers to be stupid and the DSA core being the one
      responsible for caring about the abstracted switch logic and topology.
      
      Make the DSA core program the CPU and DSA ports as part of the VLAN.
      
      This makes all chips of the data path to be aware of VIDs spanning the
      the whole fabric and thus, seamlessly add support for cross-chip VLAN.
      Reviewed-by: NFlorian Fainelli <f.fainelli@gmail.com>
      Signed-off-by: NVivien Didelot <vivien.didelot@savoirfairelinux.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      b2f81d30
    • V
      net: dsa: check VLAN capability of every switch · 1ca4aa9c
      Vivien Didelot 提交于
      Now that the VLAN object is propagated to every switch chip of the
      switch fabric, we can easily ensure that they all support the required
      VLAN operations before modifying an entry on a single switch.
      
      To achieve that, remove the condition skipping other target switches,
      and add a bitmap of VLAN members, eventually containing the target port,
      if we are programming the switch target.
      
      This will allow us to easily add other VLAN members, such as the DSA or
      CPU ports (to introduce cross-chip VLAN support) or the other port
      members if we want to reduce hardware accesses later.
      Reviewed-by: NFlorian Fainelli <f.fainelli@gmail.com>
      Signed-off-by: NVivien Didelot <vivien.didelot@savoirfairelinux.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      1ca4aa9c