netdev.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH 00/15] Introduce HabanaLabs network drivers
@ 2024-06-13  8:21 Omer Shpigelman
  2024-06-13  8:21 ` [PATCH 01/15] net: hbl_cn: add habanalabs Core Network driver Omer Shpigelman
                   ` (16 more replies)
  0 siblings, 17 replies; 108+ messages in thread
From: Omer Shpigelman @ 2024-06-13  8:21 UTC (permalink / raw)
  To: linux-kernel, linux-rdma, netdev, dri-devel
  Cc: ogabbay, oshpigelman, zyehudai

This patch set implements the HabanaLabs network drivers for Gaudi2 ASIC
which is designed for scaling of AI neural networks training.
The patch set includes the common code which is shared by all Gaudi ASICs
and the Gaudi2 ASIC specific code. Newer ASICs code will be followed.
All of these network drivers are modeled as an auxiliary devices to the
parent driver.

The newly added drivers are Core Network (CN), Ethernet and InfiniBand.
All of these drivers are based on the existing habanalabs driver which
serves as the compute driver and the entire platform.
The habanalabs driver probes the network drivers which configure the
relevant NIC HW of the device. In addition, it continuously communicates
with the CN driver for providing some services which are not NIC specific
e.g. PCI, MMU, FW communication etc.

See the drivers scheme at:
Documentation/networking/device_drivers/ethernet/intel/hbl.rst

The CN driver is both a parent and a son driver. It serves as the common
layer of many shared operations that are required by both EN and IB
drivers.

The Gaudi2 NIC HW is composed of 48 physical lanes, 56Gbps each. Each pair
of lanes represent a 100Gbps logical port.

The NIC HW was designed specifically for scaling AI training.
Hence it basically functions as a regular NIC device but it is tuned for
its dedicated purpose. As a result, the NIC HW supports Ethernet traffic
and RDMA over modified ROCEv2 protocol.
For example, with respect to the IB driver, the HW supports a single
context and a single PD. The reason for this is that the operational use
case of AI training for Gaudi2 consists of a single user
application/process.
Another example related to the IB driver is the lack of MR since a single
application/process can share the entire MMU with the compute device.
Moreover, the memory allocation of user data buffers which are used for
RDMA communication is done via the habanalabs compute driver uAPI.
With respect to the Ethernet driver, since the Ethernet flow is used
mainly for control, the HW is not performance tuned e.g. it assumes a
contiguous memory for the Rx buffers. Thus the EN driver needs to copy the
Rx packets from the Rx buffer into the skb memory.

The first 8 patches implement the CN driver.
The next 2 patches implement the EN driver.
The next 2 patches implement the IB driver.
The last 3 patches modify the compute driver to support the CN driver.

The patches are rebased on v6.10-rc3 tag:
https://github.com/torvalds/linux/releases/tag/v6.10-rc3

The patches are also available at:
https://github.com/HabanaAI/drivers.gpu.linux-nic.kernel/tree/hbl_next

The user-mode of the driver is being reviewed at:
https://github.com/linux-rdma/rdma-core/pull/1472

Any feedback, comment or question is welcome.

Thanks,
Omer

Omer Shpigelman (15):
  net: hbl_cn: add habanalabs Core Network driver
  net: hbl_cn: memory manager component
  net: hbl_cn: physical layer support
  net: hbl_cn: QP state machine
  net: hbl_cn: memory trace events
  net: hbl_cn: debugfs support
  net: hbl_cn: gaudi2: ASIC register header files
  net: hbl_cn: gaudi2: ASIC specific support
  net: hbl_en: add habanalabs Ethernet driver
  net: hbl_en: gaudi2: ASIC specific support
  RDMA/hbl: add habanalabs RDMA driver
  RDMA/hbl: direct verbs support
  accel/habanalabs: network scaling support
  accel/habanalabs/gaudi2: CN registers header files
  accel/habanalabs/gaudi2: network scaling support

 .../ABI/testing/debugfs-driver-habanalabs_cn  |   195 +
 .../device_drivers/ethernet/index.rst         |     1 +
 .../device_drivers/ethernet/intel/hbl.rst     |    82 +
 MAINTAINERS                                   |    33 +
 drivers/accel/habanalabs/Kconfig              |     1 +
 drivers/accel/habanalabs/Makefile             |     3 +
 drivers/accel/habanalabs/cn/Makefile          |     2 +
 drivers/accel/habanalabs/cn/cn.c              |   815 +
 drivers/accel/habanalabs/cn/cn.h              |   133 +
 .../habanalabs/common/command_submission.c    |     2 +-
 drivers/accel/habanalabs/common/device.c      |    23 +
 drivers/accel/habanalabs/common/firmware_if.c |    20 +
 drivers/accel/habanalabs/common/habanalabs.h  |    43 +-
 .../accel/habanalabs/common/habanalabs_drv.c  |    37 +-
 .../habanalabs/common/habanalabs_ioctl.c      |     2 +
 drivers/accel/habanalabs/common/memory.c      |   123 +
 drivers/accel/habanalabs/gaudi/gaudi.c        |    14 +-
 drivers/accel/habanalabs/gaudi2/Makefile      |     2 +-
 drivers/accel/habanalabs/gaudi2/gaudi2.c      |   440 +-
 drivers/accel/habanalabs/gaudi2/gaudi2P.h     |    41 +-
 drivers/accel/habanalabs/gaudi2/gaudi2_cn.c   |   424 +
 drivers/accel/habanalabs/gaudi2/gaudi2_cn.h   |    42 +
 .../habanalabs/gaudi2/gaudi2_coresight.c      |   145 +-
 .../accel/habanalabs/gaudi2/gaudi2_security.c |    16 +-
 drivers/accel/habanalabs/goya/goya.c          |     6 +
 .../include/gaudi2/asic_reg/gaudi2_regs.h     |    10 +-
 .../include/gaudi2/asic_reg/nic0_phy_regs.h   |    59 +
 .../nic0_qm0_axuser_nonsecured_regs.h         |    61 +
 .../include/gaudi2/asic_reg/nic0_qpc1_regs.h  |   905 +
 .../include/gaudi2/asic_reg/nic0_rxe0_regs.h  |   725 +
 .../include/gaudi2/asic_reg/nic0_rxe1_regs.h  |   725 +
 .../include/gaudi2/asic_reg/nic0_txe0_regs.h  |   529 +
 .../include/gaudi2/asic_reg/nic0_txs0_regs.h  |   289 +
 .../include/hw_ip/nic/nic_general.h           |    15 +
 drivers/infiniband/Kconfig                    |     1 +
 drivers/infiniband/hw/Makefile                |     1 +
 drivers/infiniband/hw/hbl/Kconfig             |    18 +
 drivers/infiniband/hw/hbl/Makefile            |    12 +
 drivers/infiniband/hw/hbl/hbl.h               |   326 +
 drivers/infiniband/hw/hbl/hbl_encap.c         |   216 +
 drivers/infiniband/hw/hbl/hbl_main.c          |   493 +
 drivers/infiniband/hw/hbl/hbl_query_port.c    |    96 +
 drivers/infiniband/hw/hbl/hbl_set_port_ex.c   |    96 +
 drivers/infiniband/hw/hbl/hbl_usr_fifo.c      |   252 +
 drivers/infiniband/hw/hbl/hbl_verbs.c         |  2686 +
 drivers/net/ethernet/intel/Kconfig            |    38 +
 drivers/net/ethernet/intel/Makefile           |     2 +
 drivers/net/ethernet/intel/hbl_cn/Makefile    |    14 +
 .../net/ethernet/intel/hbl_cn/common/Makefile |     3 +
 .../net/ethernet/intel/hbl_cn/common/hbl_cn.c |  5984 ++
 .../net/ethernet/intel/hbl_cn/common/hbl_cn.h |  1666 +
 .../intel/hbl_cn/common/hbl_cn_debugfs.c      |  1457 +
 .../ethernet/intel/hbl_cn/common/hbl_cn_drv.c |   240 +
 .../intel/hbl_cn/common/hbl_cn_memory.c       |   368 +
 .../ethernet/intel/hbl_cn/common/hbl_cn_phy.c |   234 +
 .../ethernet/intel/hbl_cn/common/hbl_cn_qp.c  |   491 +
 .../net/ethernet/intel/hbl_cn/gaudi2/Makefile |     3 +
 .../asic_reg/arc_farm_kdma_ctx_axuser_masks.h |   135 +
 .../asic_reg/dcore0_sync_mngr_objs_regs.h     | 43543 +++++++++++++++
 .../asic_reg/gaudi2_blocks_linux_driver.h     | 45068 ++++++++++++++++
 .../hbl_cn/gaudi2/asic_reg/gaudi2_regs.h      |    77 +
 .../asic_reg/nic0_mac_ch0_mac_128_masks.h     |   339 +
 .../asic_reg/nic0_mac_ch0_mac_128_regs.h      |   101 +
 .../asic_reg/nic0_mac_ch0_mac_pcs_masks.h     |   713 +
 .../asic_reg/nic0_mac_ch0_mac_pcs_regs.h      |   271 +
 .../asic_reg/nic0_mac_ch1_mac_pcs_regs.h      |   271 +
 .../asic_reg/nic0_mac_ch2_mac_pcs_regs.h      |   271 +
 .../asic_reg/nic0_mac_ch3_mac_pcs_regs.h      |   271 +
 .../nic0_mac_glob_stat_control_reg_masks.h    |    67 +
 .../nic0_mac_glob_stat_control_reg_regs.h     |    37 +
 .../asic_reg/nic0_mac_glob_stat_rx0_regs.h    |    93 +
 .../asic_reg/nic0_mac_glob_stat_rx2_regs.h    |    93 +
 .../asic_reg/nic0_mac_glob_stat_tx0_regs.h    |    75 +
 .../asic_reg/nic0_mac_glob_stat_tx2_regs.h    |    75 +
 .../gaudi2/asic_reg/nic0_mac_rs_fec_regs.h    |   157 +
 .../hbl_cn/gaudi2/asic_reg/nic0_phy_masks.h   |    77 +
 .../hbl_cn/gaudi2/asic_reg/nic0_phy_regs.h    |    59 +
 .../nic0_qm0_axuser_nonsecured_regs.h         |    61 +
 .../asic_reg/nic0_qpc0_axuser_cong_que_regs.h |    61 +
 .../asic_reg/nic0_qpc0_axuser_db_fifo_regs.h  |    61 +
 .../asic_reg/nic0_qpc0_axuser_err_fifo_regs.h |    61 +
 .../nic0_qpc0_axuser_ev_que_lbw_intr_regs.h   |    61 +
 .../asic_reg/nic0_qpc0_axuser_qpc_req_regs.h  |    61 +
 .../asic_reg/nic0_qpc0_axuser_qpc_resp_regs.h |    61 +
 .../asic_reg/nic0_qpc0_axuser_rxwqe_regs.h    |    61 +
 .../nic0_qpc0_axuser_txwqe_lbw_qman_bp_regs.h |    61 +
 .../nic0_qpc0_dbfifo0_ci_upd_addr_regs.h      |    27 +
 .../nic0_qpc0_dbfifosecur_ci_upd_addr_regs.h  |    27 +
 .../hbl_cn/gaudi2/asic_reg/nic0_qpc0_masks.h  |   963 +
 .../hbl_cn/gaudi2/asic_reg/nic0_qpc0_regs.h   |   905 +
 .../hbl_cn/gaudi2/asic_reg/nic0_qpc1_regs.h   |   905 +
 .../gaudi2/asic_reg/nic0_rxb_core_masks.h     |   459 +
 .../gaudi2/asic_reg/nic0_rxb_core_regs.h      |   665 +
 .../nic0_rxe0_axuser_axuser_cq0_regs.h        |    61 +
 .../nic0_rxe0_axuser_axuser_cq1_regs.h        |    61 +
 .../hbl_cn/gaudi2/asic_reg/nic0_rxe0_masks.h  |   705 +
 .../hbl_cn/gaudi2/asic_reg/nic0_rxe0_regs.h   |   725 +
 .../asic_reg/nic0_rxe0_wqe_aruser_regs.h      |    61 +
 .../hbl_cn/gaudi2/asic_reg/nic0_rxe1_regs.h   |   725 +
 .../gaudi2/asic_reg/nic0_serdes0_masks.h      |  7163 +++
 .../gaudi2/asic_reg/nic0_serdes0_regs.h       |  1679 +
 .../gaudi2/asic_reg/nic0_serdes1_regs.h       |  1679 +
 .../asic_reg/nic0_tmr_axuser_tmr_fifo_regs.h  |    61 +
 .../nic0_tmr_axuser_tmr_free_list_regs.h      |    61 +
 .../asic_reg/nic0_tmr_axuser_tmr_fsm_regs.h   |    61 +
 .../hbl_cn/gaudi2/asic_reg/nic0_tmr_masks.h   |   361 +
 .../hbl_cn/gaudi2/asic_reg/nic0_tmr_regs.h    |   183 +
 .../hbl_cn/gaudi2/asic_reg/nic0_txb_regs.h    |   167 +
 .../hbl_cn/gaudi2/asic_reg/nic0_txe0_masks.h  |   759 +
 .../hbl_cn/gaudi2/asic_reg/nic0_txe0_regs.h   |   529 +
 .../hbl_cn/gaudi2/asic_reg/nic0_txs0_masks.h  |   555 +
 .../hbl_cn/gaudi2/asic_reg/nic0_txs0_regs.h   |   289 +
 .../nic0_umr0_0_completion_queue_ci_1_regs.h  |    27 +
 .../nic0_umr0_0_unsecure_doorbell0_regs.h     |    31 +
 .../nic0_umr0_0_unsecure_doorbell1_regs.h     |    31 +
 .../gaudi2/asic_reg/prt0_mac_core_masks.h     |   137 +
 .../gaudi2/asic_reg/prt0_mac_core_regs.h      |    67 +
 .../ethernet/intel/hbl_cn/gaudi2/gaudi2_cn.c  |  5689 ++
 .../ethernet/intel/hbl_cn/gaudi2/gaudi2_cn.h  |   427 +
 .../intel/hbl_cn/gaudi2/gaudi2_cn_debugfs.c   |   319 +
 .../intel/hbl_cn/gaudi2/gaudi2_cn_eq.c        |   732 +
 .../intel/hbl_cn/gaudi2/gaudi2_cn_phy.c       |  2743 +
 drivers/net/ethernet/intel/hbl_en/Makefile    |    12 +
 .../net/ethernet/intel/hbl_en/common/Makefile |     3 +
 .../net/ethernet/intel/hbl_en/common/hbl_en.c |  1170 +
 .../net/ethernet/intel/hbl_en/common/hbl_en.h |   208 +
 .../intel/hbl_en/common/hbl_en_dcbnl.c        |   101 +
 .../ethernet/intel/hbl_en/common/hbl_en_drv.c |   211 +
 .../intel/hbl_en/common/hbl_en_ethtool.c      |   452 +
 .../net/ethernet/intel/hbl_en/gaudi2/Makefile |     2 +
 .../ethernet/intel/hbl_en/gaudi2/gaudi2_en.c  |   728 +
 .../ethernet/intel/hbl_en/gaudi2/gaudi2_en.h  |    53 +
 .../intel/hbl_en/gaudi2/gaudi2_en_dcbnl.c     |    32 +
 include/linux/habanalabs/cpucp_if.h           |   125 +-
 include/linux/habanalabs/hl_boot_if.h         |     9 +-
 include/linux/net/intel/cn.h                  |   474 +
 include/linux/net/intel/cn_aux.h              |   298 +
 include/linux/net/intel/cni.h                 |   636 +
 include/linux/net/intel/gaudi2.h              |   432 +
 include/linux/net/intel/gaudi2_aux.h          |    94 +
 include/trace/events/habanalabs_cn.h          |   116 +
 include/uapi/drm/habanalabs_accel.h           |    10 +-
 include/uapi/rdma/hbl-abi.h                   |   204 +
 include/uapi/rdma/hbl_user_ioctl_cmds.h       |    66 +
 include/uapi/rdma/hbl_user_ioctl_verbs.h      |   106 +
 include/uapi/rdma/ib_user_ioctl_verbs.h       |     1 +
 146 files changed, 148514 insertions(+), 70 deletions(-)
 create mode 100644 Documentation/ABI/testing/debugfs-driver-habanalabs_cn
 create mode 100644 Documentation/networking/device_drivers/ethernet/intel/hbl.rst
 create mode 100644 drivers/accel/habanalabs/cn/Makefile
 create mode 100644 drivers/accel/habanalabs/cn/cn.c
 create mode 100644 drivers/accel/habanalabs/cn/cn.h
 create mode 100644 drivers/accel/habanalabs/gaudi2/gaudi2_cn.c
 create mode 100644 drivers/accel/habanalabs/gaudi2/gaudi2_cn.h
 create mode 100644 drivers/accel/habanalabs/include/gaudi2/asic_reg/nic0_phy_regs.h
 create mode 100644 drivers/accel/habanalabs/include/gaudi2/asic_reg/nic0_qm0_axuser_nonsecured_regs.h
 create mode 100644 drivers/accel/habanalabs/include/gaudi2/asic_reg/nic0_qpc1_regs.h
 create mode 100644 drivers/accel/habanalabs/include/gaudi2/asic_reg/nic0_rxe0_regs.h
 create mode 100644 drivers/accel/habanalabs/include/gaudi2/asic_reg/nic0_rxe1_regs.h
 create mode 100644 drivers/accel/habanalabs/include/gaudi2/asic_reg/nic0_txe0_regs.h
 create mode 100644 drivers/accel/habanalabs/include/gaudi2/asic_reg/nic0_txs0_regs.h
 create mode 100644 drivers/accel/habanalabs/include/hw_ip/nic/nic_general.h
 create mode 100644 drivers/infiniband/hw/hbl/Kconfig
 create mode 100644 drivers/infiniband/hw/hbl/Makefile
 create mode 100644 drivers/infiniband/hw/hbl/hbl.h
 create mode 100644 drivers/infiniband/hw/hbl/hbl_encap.c
 create mode 100644 drivers/infiniband/hw/hbl/hbl_main.c
 create mode 100644 drivers/infiniband/hw/hbl/hbl_query_port.c
 create mode 100644 drivers/infiniband/hw/hbl/hbl_set_port_ex.c
 create mode 100644 drivers/infiniband/hw/hbl/hbl_usr_fifo.c
 create mode 100644 drivers/infiniband/hw/hbl/hbl_verbs.c
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/Makefile
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/common/Makefile
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/common/hbl_cn.c
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/common/hbl_cn.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/common/hbl_cn_debugfs.c
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/common/hbl_cn_drv.c
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/common/hbl_cn_memory.c
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/common/hbl_cn_phy.c
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/common/hbl_cn_qp.c
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/Makefile
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/arc_farm_kdma_ctx_axuser_masks.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/dcore0_sync_mngr_objs_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/gaudi2_blocks_linux_driver.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/gaudi2_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_mac_ch0_mac_128_masks.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_mac_ch0_mac_128_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_mac_ch0_mac_pcs_masks.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_mac_ch0_mac_pcs_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_mac_ch1_mac_pcs_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_mac_ch2_mac_pcs_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_mac_ch3_mac_pcs_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_mac_glob_stat_control_reg_masks.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_mac_glob_stat_control_reg_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_mac_glob_stat_rx0_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_mac_glob_stat_rx2_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_mac_glob_stat_tx0_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_mac_glob_stat_tx2_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_mac_rs_fec_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_phy_masks.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_phy_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_qm0_axuser_nonsecured_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_qpc0_axuser_cong_que_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_qpc0_axuser_db_fifo_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_qpc0_axuser_err_fifo_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_qpc0_axuser_ev_que_lbw_intr_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_qpc0_axuser_qpc_req_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_qpc0_axuser_qpc_resp_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_qpc0_axuser_rxwqe_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_qpc0_axuser_txwqe_lbw_qman_bp_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_qpc0_dbfifo0_ci_upd_addr_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_qpc0_dbfifosecur_ci_upd_addr_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_qpc0_masks.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_qpc0_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_qpc1_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_rxb_core_masks.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_rxb_core_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_rxe0_axuser_axuser_cq0_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_rxe0_axuser_axuser_cq1_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_rxe0_masks.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_rxe0_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_rxe0_wqe_aruser_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_rxe1_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_serdes0_masks.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_serdes0_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_serdes1_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_tmr_axuser_tmr_fifo_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_tmr_axuser_tmr_free_list_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_tmr_axuser_tmr_fsm_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_tmr_masks.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_tmr_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_txb_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_txe0_masks.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_txe0_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_txs0_masks.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_txs0_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_umr0_0_completion_queue_ci_1_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_umr0_0_unsecure_doorbell0_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/nic0_umr0_0_unsecure_doorbell1_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/prt0_mac_core_masks.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/asic_reg/prt0_mac_core_regs.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/gaudi2_cn.c
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/gaudi2_cn.h
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/gaudi2_cn_debugfs.c
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/gaudi2_cn_eq.c
 create mode 100644 drivers/net/ethernet/intel/hbl_cn/gaudi2/gaudi2_cn_phy.c
 create mode 100644 drivers/net/ethernet/intel/hbl_en/Makefile
 create mode 100644 drivers/net/ethernet/intel/hbl_en/common/Makefile
 create mode 100644 drivers/net/ethernet/intel/hbl_en/common/hbl_en.c
 create mode 100644 drivers/net/ethernet/intel/hbl_en/common/hbl_en.h
 create mode 100644 drivers/net/ethernet/intel/hbl_en/common/hbl_en_dcbnl.c
 create mode 100644 drivers/net/ethernet/intel/hbl_en/common/hbl_en_drv.c
 create mode 100644 drivers/net/ethernet/intel/hbl_en/common/hbl_en_ethtool.c
 create mode 100644 drivers/net/ethernet/intel/hbl_en/gaudi2/Makefile
 create mode 100644 drivers/net/ethernet/intel/hbl_en/gaudi2/gaudi2_en.c
 create mode 100644 drivers/net/ethernet/intel/hbl_en/gaudi2/gaudi2_en.h
 create mode 100644 drivers/net/ethernet/intel/hbl_en/gaudi2/gaudi2_en_dcbnl.c
 create mode 100644 include/linux/net/intel/cn.h
 create mode 100644 include/linux/net/intel/cn_aux.h
 create mode 100644 include/linux/net/intel/cni.h
 create mode 100644 include/linux/net/intel/gaudi2.h
 create mode 100644 include/linux/net/intel/gaudi2_aux.h
 create mode 100644 include/trace/events/habanalabs_cn.h
 create mode 100644 include/uapi/rdma/hbl-abi.h
 create mode 100644 include/uapi/rdma/hbl_user_ioctl_cmds.h
 create mode 100644 include/uapi/rdma/hbl_user_ioctl_verbs.h

-- 
2.34.1


^ permalink raw reply	[flat|nested] 108+ messages in thread

end of thread, other threads:[~2024-12-17 10:52 UTC | newest]

Thread overview: 108+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-06-13  8:21 [PATCH 00/15] Introduce HabanaLabs network drivers Omer Shpigelman
2024-06-13  8:21 ` [PATCH 01/15] net: hbl_cn: add habanalabs Core Network driver Omer Shpigelman
2024-06-13 13:01   ` Przemek Kitszel
2024-06-13 14:16     ` Przemek Kitszel
2024-06-17  8:08     ` Omer Shpigelman
2024-06-17 11:48       ` Leon Romanovsky
2024-06-18  7:28         ` Omer Shpigelman
2024-06-15  0:05   ` Stephen Hemminger
2024-06-17  8:14     ` Omer Shpigelman
2024-06-17 14:05   ` Markus Elfring
2024-06-17 15:02     ` Andrew Lunn
2024-06-18  7:51       ` Omer Shpigelman
2024-06-13  8:21 ` [PATCH 02/15] net: hbl_cn: memory manager component Omer Shpigelman
2024-06-13  8:21 ` [PATCH 03/15] net: hbl_cn: physical layer support Omer Shpigelman
2024-06-13  8:21 ` [PATCH 04/15] net: hbl_cn: QP state machine Omer Shpigelman
2024-06-17 13:18   ` Leon Romanovsky
2024-06-18  5:50     ` Omer Shpigelman
2024-06-18  7:08       ` Leon Romanovsky
2024-06-18  7:58         ` Omer Shpigelman
2024-06-18  9:00           ` Leon Romanovsky
2024-06-24  7:24             ` Omer Shpigelman
2024-06-13  8:21 ` [PATCH 05/15] net: hbl_cn: memory trace events Omer Shpigelman
2024-06-13  8:21 ` [PATCH 06/15] net: hbl_cn: debugfs support Omer Shpigelman
2024-06-19 18:35   ` Sunil Kovvuri Goutham
2024-06-21 10:17     ` Omer Shpigelman
2024-06-21 10:30       ` Sunil Kovvuri Goutham
2024-06-23  7:25         ` Omer Shpigelman
2024-06-21 15:33       ` Andrew Lunn
2024-06-23  6:57         ` Omer Shpigelman
2024-06-23 15:02           ` Andrew Lunn
2024-06-24  7:21             ` Omer Shpigelman
2024-06-24  9:22             ` Leon Romanovsky
2024-12-17 10:00             ` Avri Kehat
2024-12-17 10:52               ` Andrew Lunn
2024-06-13  8:22 ` [PATCH 07/15] net: hbl_cn: gaudi2: ASIC register header files Omer Shpigelman
2024-06-13  8:22 ` [PATCH 08/15] net: hbl_cn: gaudi2: ASIC specific support Omer Shpigelman
2024-06-13  8:22 ` [PATCH 09/15] net: hbl_en: add habanalabs Ethernet driver Omer Shpigelman
2024-06-13 21:49   ` Andrew Lunn
2024-06-18  6:58     ` Omer Shpigelman
2024-06-18 14:19       ` Andrew Lunn
2024-06-19  7:16         ` Omer Shpigelman
2024-06-19  8:01           ` Przemek Kitszel
2024-06-19 12:15             ` Omer Shpigelman
2024-06-19 15:21           ` Jakub Kicinski
2024-06-20  8:43             ` Omer Shpigelman
2024-06-20 13:51               ` Jakub Kicinski
2024-06-20 19:14                 ` Andrew Lunn
2024-06-23 14:48                   ` Omer Shpigelman
2024-06-19 16:13           ` Andrew Lunn
2024-06-23  6:22             ` Omer Shpigelman
2024-06-23 14:46               ` Andrew Lunn
2024-06-26 10:13                 ` Omer Shpigelman
2024-06-26 14:13                   ` Andrew Lunn
2024-06-30  7:11                     ` Omer Shpigelman
2024-06-14 22:48   ` Joe Damato
2024-06-16  1:04     ` Andrew Lunn
2024-06-18 19:37     ` Omer Shpigelman
2024-06-18 21:19       ` Stephen Hemminger
2024-06-19 12:13         ` Omer Shpigelman
2024-06-15  0:10   ` Stephen Hemminger
2024-06-19 12:07     ` Omer Shpigelman
2024-06-15  0:16   ` Stephen Hemminger
2024-06-18 19:39     ` Omer Shpigelman
2024-06-19 15:40       ` Andrew Lunn
2024-06-20  8:36         ` Omer Shpigelman
2024-06-15 10:55   ` Zhu Yanjun
2024-06-18 11:16     ` Omer Shpigelman
2024-06-15 17:13   ` Zhu Yanjun
2024-06-16  1:08     ` Andrew Lunn
2024-06-13  8:22 ` [PATCH 10/15] net: hbl_en: gaudi2: ASIC specific support Omer Shpigelman
2024-06-13  8:22 ` [PATCH 11/15] RDMA/hbl: add habanalabs RDMA driver Omer Shpigelman
2024-06-13 19:18   ` Leon Romanovsky
2024-06-17 17:43     ` Omer Shpigelman
2024-06-17 19:04       ` Leon Romanovsky
2024-06-18 11:08         ` Omer Shpigelman
2024-06-18 12:58           ` Leon Romanovsky
2024-06-19  9:27             ` Omer Shpigelman
2024-06-19 10:52               ` Leon Romanovsky
2024-06-24  8:47                 ` Omer Shpigelman
2024-06-24  9:10                   ` Leon Romanovsky
2024-06-28 10:24                 ` Omer Shpigelman
2024-06-30 13:29                   ` Leon Romanovsky
2024-07-01 10:46                     ` Omer Shpigelman
2024-07-01 12:46                       ` Leon Romanovsky
2024-07-12 13:08                   ` Jason Gunthorpe
2024-07-14 10:18                     ` Omer Shpigelman
2024-07-16 13:40                       ` Jason Gunthorpe
2024-07-17  7:08                         ` Omer Shpigelman
2024-07-17  7:36                           ` Leon Romanovsky
2024-07-17 10:51                             ` Omer Shpigelman
2024-07-17 11:56                               ` Jason Gunthorpe
2024-07-17 12:33                               ` Leon Romanovsky
2024-07-18  6:54                                 ` Omer Shpigelman
2024-07-18  8:31                                   ` Leon Romanovsky
2024-06-18 16:01           ` Przemek Kitszel
2024-06-19  9:34             ` Omer Shpigelman
2024-06-17 14:17   ` Jason Gunthorpe
2024-06-19  9:39     ` Omer Shpigelman
2024-06-13  8:22 ` [PATCH 12/15] RDMA/hbl: direct verbs support Omer Shpigelman
2024-06-13  8:22 ` [PATCH 13/15] accel/habanalabs: network scaling support Omer Shpigelman
2024-06-19 18:41   ` Sunil Kovvuri Goutham
2024-06-21 10:21     ` Omer Shpigelman
2024-06-13  8:22 ` [PATCH 14/15] accel/habanalabs/gaudi2: CN registers header files Omer Shpigelman
2024-06-13  8:22 ` [PATCH 15/15] accel/habanalabs/gaudi2: network scaling support Omer Shpigelman
2024-06-17 12:34 ` [PATCH 00/15] Introduce HabanaLabs network drivers Alexander Lobakin
2024-06-19 11:40   ` Omer Shpigelman
2024-06-19 16:33 ` Jiri Pirko
2024-06-20  5:37   ` Omer Shpigelman

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).