mlx5dv_reg_dmabuf_mr - Man Page

Register a dma-buf based memory region (MR)

Synopsis

#include <infiniband/mlx5dv.h>

struct ibv_mr *mlx5dv_reg_dmabuf_mr(struct ibv_pd *pd, uint64_t offset,
                                    size_t length, uint64_t iova, int fd,
                                    int access, int mlx5_access)

Description

Register a dma-buf based memory region (MR), it follows the functionality of ibv_reg_dmabuf_mr() with the ability to supply specific mlx5 access flags.

Arguments

pd

The associated protection domain.

offset

The offset of the dma-buf where the MR starts.

length
The length of the MR.
iova

Specifies the virtual base address of the MR when accessed through a lkey or rkey. It must have the same page offset as offset and be aligned with the system page size.

fd

The file descriptor that the dma-buf is identified by.

access

The desired memory protection attributes; it is either 0 or the bitwise OR of one or more of enum ibv_access_flags.

mlx5_access

A specific device access flags, it is either 0 or the below.

MLX5DV_REG_DMABUF_ACCESS_DATA_DIRECT if set, this MR will be accessed through the Data Direct engine bonded with that RDMA device.

Return Value

Upon success returns a pointer to the registered MR, or NULL if the request fails, in that case the value of errno indicates the failure reason.

See Also

ibv_reg_dmabuf_mr(3), mlx5dv_get_data_direct_sysfs_path(3)

Author

Yishai Hadas yishaih@nvidia.com\c

Referenced By

mlx5dv_get_data_direct_sysfs_path(3).