mlx5dv(7) — Linux manual page

NAME | DESCRIPTION | NOTES | SEE ALSO | AUTHORS | COLOPHON

MLX5DV(7)           Miscellaneous Information Manual           MLX5DV(7)

NAME         top

       mlx5dv - Direct verbs for mlx5 devices
       This is low level access to mlx5 devices to perform data path
       operations, without general branching performed by
       ibv_post_send(3).

DESCRIPTION         top

       The libibverbs API is an abstract one. It is agnostic to any
       underlying provider specific implementation. While this
       abstraction has the advantage of user applications portability it
       has a performance penalty. For some applications optimizing
       performance is more important than portability.

       The mlx5 direct verbs API is intended for such applications.  It
       exposes mlx5 specific low level data path
       (send/receive/completion) operations, allowing the application to
       bypass the libibverbs data path API.

       This interface consists from one hardware specific header file
       with relevant inline functions and conversion logic from ibverbs
       structures to mlx5 specific structures.

       The direct include of mlx5dv.h together with linkage to mlx5
       library will allow usage of this new interface.

       Once an application uses the direct flow the locking scheme is
       fully managed by itself. There is an expectation that no mixed
       flows in the data path for both direct/non-direct access will be
       by same application.

NOTES         top

       All Mellanox NIC devices starting from Connect-IB (Connect-IB,
       ConnectX-4, ConnectX-4Lx, ConnectX-5, ...) implement the mlx5
       API, thus using the mlx5 direct verbs does not limit the
       applications to a single NIC HW device thus keeping some level of
       portability.

SEE ALSO         top

       ibv_post_send(3), verbs(7), mlx5dv_is_supported(3)

AUTHORS         top

       Leon Romanovsky <leonro@mellanox.com>

COLOPHON         top

       This page is part of the rdma-core (RDMA Core Userspace Libraries
       and Daemons) project.  Information about the project can be found
       at ⟨https://github.com/linux-rdma/rdma-core⟩.  If you have a bug
       report for this manual page, send it to
       linux-rdma@vger.kernel.org.  This page was obtained from the
       project's upstream Git repository
       ⟨https://github.com/linux-rdma/rdma-core.git⟩ on 2024-06-14.  (At
       that time, the date of the most recent commit that was found in
       the repository was 2024-06-10.)  If you discover any rendering
       problems in this HTML version of the page, or you believe there
       is a better or more up-to-date source for the page, or you have
       corrections or improvements to the information in this COLOPHON
       (which is not part of the original manual page), send a mail to
       man-pages@man7.org

1.0.0                          2017-02-02                      MLX5DV(7)

Pages that refer to this page: mlx5dv_get_clock_info(3)mlx5dv_init_obj(3)mlx5dv_query_device(3)mlx5dv_ts_to_ns(3)