1. 04 2月, 2017 8 次提交
  2. 25 1月, 2017 1 次提交
  3. 26 11月, 2016 4 次提交
    • N
      mlxsw: reg: Add QoS Policer Configuration Register · 76a4c7d3
      Nogah Frankel 提交于
      The QPCR register is used to create and control policers.
      A policer can discard or change the color of packets that are
      trapped by a specific trap.
      Signed-off-by: NNogah Frankel <nogahf@mellanox.com>
      Signed-off-by: NJiri Pirko <jiri@mellanox.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      76a4c7d3
    • N
      mlxsw: Create a different trap group list for each device · 117b0dad
      Nogah Frankel 提交于
      Trap groups can be used to control traps priority, both in terms of
      which trap "wins" if a packet matches two traps (priority) and in terms
      of packets from which trap group will be scheduled to the cpu first (tc).
      They can also be used to set rate limiters (policers) on them (will be
      added in the next patches).
      
      Currently, we support two trap groups. In Spectrum we want a better
      resolution, so every protocol / flow will have a different trap group,
      so we can control its parameters separately. Once the policers will be
      implemented, it will also allow us limit the rate of each protocol by
      itself.
      
      This patch change the trap group list to include:
      * the emad trap group, which is shared for all the devices.
      * Switchx2's trap groups, which are a copy of the current trap groups.
      * Spectrum's new trap groups, in order to match the above guidelines.
      (Switchib is using only the emad trap group, so it require no changes).
      
      This patch also includes new configuration for Spectrum's trap groups,
      with primary priority order within them.
      Signed-off-by: NNogah Frankel <nogahf@mellanox.com>
      Signed-off-by: NJiri Pirko <jiri@mellanox.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      117b0dad
    • N
      mlxsw: Change trap groups setting · 579c82e4
      Nogah Frankel 提交于
      Trap groups have many options which we currently set to default values.
      In the next patches we will use many of them with non-default values.
      
      Some of these options have no default value, so this patch sets them as
      params for the trap group set function. Others almost always use the same
      values, so the set function will use this default values. In the rare cases
      when they will need to be with other values, these values can be set
      directly (using the macros for fields in registers).
      
      Parameters without default value:
      TC - the traffic class for packets that hit this trap group.
          (old default is the max tc)
      priority - if one packet hits multiple trap groups, the group with the
      	   higher priority will "catch" it. (old default is 0)
      policer - limit rate policer (old default is disabled)
      
      Default parameters:
      swid - switch id, relevant for the emad trap only, ignored on Spectrum.
             (new default is 0)
      rdq - CPU receive descriptor queue (new default is identical to trap
            group id)
      Signed-off-by: NNogah Frankel <nogahf@mellanox.com>
      Signed-off-by: NJiri Pirko <jiri@mellanox.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      579c82e4
    • N
      mlxsw: Change trap set function · d570b7ee
      Nogah Frankel 提交于
      Change trap setting function so instead of determining the trap group by
      trap id, it gets it as a parameter (so later we can have different trap
      groups for Spectrum and Switchx2).
      Add "is_ctrl" parameter to the trap setting function. It control whether
      the trapped packets wait in a designated control buffer or in their
      default one. This parameter is ignored by Switchx2 and Switchib.
      Add these parameters to the traps array in Spectrum, Switchx2 and
      Switchib.
      Signed-off-by: NNogah Frankel <nogahf@mellanox.com>
      Signed-off-by: NJiri Pirko <jiri@mellanox.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      d570b7ee
  4. 22 11月, 2016 1 次提交
  5. 14 11月, 2016 1 次提交
  6. 31 10月, 2016 3 次提交
  7. 24 10月, 2016 2 次提交
  8. 20 9月, 2016 1 次提交
  9. 14 9月, 2016 2 次提交
  10. 25 8月, 2016 1 次提交
  11. 18 8月, 2016 2 次提交
  12. 25 7月, 2016 3 次提交
  13. 21 7月, 2016 1 次提交
  14. 16 7月, 2016 1 次提交
    • I
      mlxsw: spectrum: Prevent invalid ingress buffer mapping · 11719a58
      Ido Schimmel 提交于
      Packets entering the switch are mapped to a Switch Priority (SP)
      according to their PCP value (untagged frames are mapped to SP 0).
      
      The packets are classified to a priority group (PG) buffer in the port's
      headroom according to their SP.
      
      The switch maintains another mapping (SP to IEEE priority), which is
      used to generate PFC frames for lossless PGs. This mapping is
      initialized to IEEE = SP % 8.
      
      Therefore, when mapping SP 'x' to PG 'y' we create a situation in which
      an IEEE priority is mapped to two different PGs:
      
      IEEE 'x' ---> SP 'x' ---> PG 'y'
      IEEE 'x' ---> SP 'x + 8' ---> PG '0' (default)
      
      Which is invalid, as a flow can use only one PG buffer.
      
      Fix this by mapping both SP 'x' and 'x + 8' to the same PG buffer.
      
      Fixes: 8e8dfe9f ("mlxsw: spectrum: Add IEEE 802.1Qaz ETS support")
      Signed-off-by: NIdo Schimmel <idosch@mellanox.com>
      Signed-off-by: NJiri Pirko <jiri@mellanox.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      11719a58
  15. 06 7月, 2016 4 次提交
  16. 05 7月, 2016 4 次提交
  17. 03 7月, 2016 1 次提交