1. 22 9月, 2018 33 次提交
  2. 21 9月, 2018 6 次提交
  3. 20 9月, 2018 1 次提交
    • D
      Merge branch 'mlxsw-Further-MC-awareness-configuration' · cab9572a
      David S. Miller 提交于
      Ido Schimmel says:
      
      ====================
      mlxsw: Further MC-awareness configuration
      
      Petr says:
      
      Due to an issue in Spectrum chips, when unicast traffic shares the same
      queue as BUM traffic, and there is congestion, the BUM traffic is
      admitted to the queue anyway, thus pushing out all UC traffic. In order
      to give unicast traffic precedence over BUM traffic, multicast-aware
      mode is now configured on all ports. Under MC-aware mode, egress TCs
      8..15 are used for BUM traffic, which has its own dedicated pool.
      
      This patch set improves the way that the MC pool and the higher-order
      TCs are integrated into the system.
      
      In patch #1, shaper at the higher TCs is configured to the same value
      that it has by default. It's better to have the corresponding artifact
      in the code explicitly.
      
      The 8 following patches gradually extend the devlink handling in mlxsw
      to support the extra TCs and the new MC pool.
      
      Patch #2 changes the way that pools are indexed in mlxsw. Instead of
      using (FW index, direction) tuple to identify the pool and the
      associated cache, mlxsw now uses devlink index. This change is necessary
      because the new pool 15 is not contiguously adjacent to the
      currently-used pools 0..3, and because it's only relevant on egress.
      Using devlink index relaxes the requirement for symmetry and adjacency
      imposed by using FW indexing.
      
      In patch #3, the assumption that number of ingress TCs matches that of
      egress TCs is relaxed to allow exposition of egress TCs 8..15.
      
      In patches #4, #5 and #6, support for infinite quotas is introduced.
      Infinite quotas are reported as taking all the memory in the system, but
      actually use a mechanism where the infinity is configured explicitly.
      
      In patches #7 and #8, support for configuring static pool sizes in
      introduced. Statically-sized pools have been supported for a while now,
      but during initialization, all pools have dynamic size. The patches
      allow there to be a mix of by-default static and dynamic pools.
      
      In patches #9 and #10, pool 15 resp. per-priority MC quotas are
      explicitly configured to be in sync with the current recommendation for
      handling BUM traffic in Spectrum chips.
      
      In the following 3 patches, an mlxsw-specific selftest is added to test
      the MC-awareness configuration.
      
      First in patches #11 and #12, lib.sh is extended with functions to
      collect ethtool stats, and to manage port MTU.
      
      Then in patch #13 the selftest itself is added.
      ====================
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      cab9572a