lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <20180708205127.16750-1-idosch@mellanox.com>
Date:   Sun,  8 Jul 2018 23:51:15 +0300
From:   Ido Schimmel <idosch@...lanox.com>
To:     netdev@...r.kernel.org
Cc:     davem@...emloft.net, jiri@...lanox.com, mlxsw@...lanox.com,
        Ido Schimmel <idosch@...lanox.com>
Subject: [PATCH net-next 00/12] mlxsw: More Spectrum-2 preparations

Hi,

This is the second and last set of preparations towards initial
Spectrum-2 support in mlxsw. It mainly re-arranges parts of the code
that need to work with both ASICs, but somewhat differ.

The first three patches allow different ASICs to register different set
of operations for KVD linear (KVDL) management. In Spectrum-2 there is
no linear memory and instead entries that reside there in Spectrum
(e.g., nexthops) are hashed and inserted to the hash-based KVD memory.

The fourth patch does a similar restructuring in the low-level multicast
router code. This is necessary because multicast routing is implemented
using regular circuit TCAM (C-TCAM) in Spectrum, whereas Spectrum-2 uses
an algorithmic TCAM (A-TCAM).

Next six patches prepare the ACL code for the introduction of A-TCAM in
follow-up patch sets.

Last two patches allow different ASICs to require different firmware
versions and add two resources that need to be queried from firmware by
Spectrum-2 specific code.

Jiri Pirko (12):
  mlxsw: spectrum_kvdl: Push out KVD linear management into ops
  mlxsw: spectrum_kvdl: Pass entry type to alloc/free
  mlxsw: spectrum_kvdl: Pass entry_count to free function
  mlxsw: spectrum_mr_tcam: Push Spectrum-specific operations into a
    separate file
  mlxsw: spectrum_acl: Split TCAM handling 3 ways
  mlxsw: spectrum_acl: Add tcam init/fini ops
  mlxsw: spectrum_acl: Convert mlxsw_afk_create args to ops
  mlxsw: spectrum_acl: Move block items encoding into Spectrum op
  mlxsw: reg: Add priority field for PTCEV2 register
  mlxsw: spectrum_acl: Implement priority setting for rules inserted to
    TCAM
  mlxsw: spectrum: Prepare for multiple FW versions for Spectrum and
    Spectrum-2
  mlxsw: resources: Add couple of Spectrum-2 KVD resources

 drivers/net/ethernet/mellanox/mlxsw/Makefile       |  15 +-
 .../ethernet/mellanox/mlxsw/core_acl_flex_keys.c   |  58 +--
 .../ethernet/mellanox/mlxsw/core_acl_flex_keys.h   |  13 +-
 drivers/net/ethernet/mellanox/mlxsw/reg.h          |  12 +-
 drivers/net/ethernet/mellanox/mlxsw/resources.h    |   4 +
 drivers/net/ethernet/mellanox/mlxsw/spectrum.c     |  53 ++-
 drivers/net/ethernet/mellanox/mlxsw/spectrum.h     | 174 ++++++--
 .../ethernet/mellanox/mlxsw/spectrum1_acl_tcam.c   | 245 +++++++++++
 .../net/ethernet/mellanox/mlxsw/spectrum1_kvdl.c   | 459 +++++++++++++++++++++
 .../ethernet/mellanox/mlxsw/spectrum1_mr_tcam.c    | 374 +++++++++++++++++
 drivers/net/ethernet/mellanox/mlxsw/spectrum_acl.c |  30 +-
 .../ethernet/mellanox/mlxsw/spectrum_acl_ctcam.c   | 215 ++++++++++
 .../mellanox/mlxsw/spectrum_acl_flex_actions.c     |  21 +-
 ...um_acl_flex_keys.h => spectrum_acl_flex_keys.c} |  61 ++-
 .../ethernet/mellanox/mlxsw/spectrum_acl_tcam.c    | 356 +++++-----------
 .../ethernet/mellanox/mlxsw/spectrum_acl_tcam.h    | 146 +++++++
 .../net/ethernet/mellanox/mlxsw/spectrum_kvdl.c    | 432 ++-----------------
 drivers/net/ethernet/mellanox/mlxsw/spectrum_mr.c  |   2 +-
 drivers/net/ethernet/mellanox/mlxsw/spectrum_mr.h  |  11 +-
 .../net/ethernet/mellanox/mlxsw/spectrum_mr_tcam.c | 322 ++-------------
 .../net/ethernet/mellanox/mlxsw/spectrum_router.c  |  20 +-
 21 files changed, 1924 insertions(+), 1099 deletions(-)
 create mode 100644 drivers/net/ethernet/mellanox/mlxsw/spectrum1_acl_tcam.c
 create mode 100644 drivers/net/ethernet/mellanox/mlxsw/spectrum1_kvdl.c
 create mode 100644 drivers/net/ethernet/mellanox/mlxsw/spectrum1_mr_tcam.c
 create mode 100644 drivers/net/ethernet/mellanox/mlxsw/spectrum_acl_ctcam.c
 rename drivers/net/ethernet/mellanox/mlxsw/{spectrum_acl_flex_keys.h => spectrum_acl_flex_keys.c} (74%)
 create mode 100644 drivers/net/ethernet/mellanox/mlxsw/spectrum_acl_tcam.h

-- 
2.14.4

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ