1MLX5DV_QUERY_DEVICE(3)     Library Functions Manual     MLX5DV_QUERY_DEVICE(3)
2
3
4

NAME

6       mlx5dv_query_device - Query device capabilities specific to mlx5
7

SYNOPSIS

9       #include <infiniband/mlx5dv.h>
10
11       int mlx5dv_query_device(struct ibv_context *ctx_in,
12                               struct mlx5dv_context *attrs_out);
13

DESCRIPTION

15       mlx5dv_query_device()  Query  HW  device-specific  information which is
16       important for data-path, but isn't provided by ibv_query_device(3).
17
18       This function returns version, flags and compatibility mask.  The  ver‐
19       sion  represents  the  format  of the internal hardware structures that
20       mlx5dv.h represents. Additions of new fields to the existed  structures
21       are handled by comp_mask field.
22
23       struct mlx5dv_sw_parsing_caps {
24               uint32_t sw_parsing_offloads; /* Use enum mlx5dv_sw_parsing_offloads */
25               uint32_t supported_qpts;
26       };
27
28       struct mlx5dv_striding_rq_caps {
29               uint32_t min_single_stride_log_num_of_bytes; /* min log size of each stride */
30               uint32_t max_single_stride_log_num_of_bytes; /* max log size of each stride */
31               uint32_t min_single_wqe_log_num_of_strides; /* min log number of strides per WQE */
32               uint32_t max_single_wqe_log_num_of_strides; /* max log number of strides per WQE */
33               uint32_t supported_qpts;
34       };
35
36       struct mlx5dv_context {
37               uint8_t         version;
38               uint64_t        flags;
39               uint64_t        comp_mask; /* Use enum mlx5dv_context_comp_mask */
40               struct mlx5dv_cqe_comp_caps     cqe_comp_caps;
41               struct mlx5dv_sw_parsing_caps sw_parsing_caps;
42               uint32_t  tunnel_offloads_caps;
43       };
44
45       enum mlx5dv_context_flags {
46               /*
47                * This flag indicates if CQE version 0 or 1 is needed.
48                */
49                MLX5DV_CONTEXT_FLAGS_CQE_V1 = (1 << 0),
50                MLX5DV_CONTEXT_FLAGS_OBSOLETE    =  (1 << 1), /* Obsoleted, don't use */
51                MLX5DV_CONTEXT_FLAGS_MPW_ALLOWED  = (1 << 2), /* Multi packet WQE is allowed */
52                MLX5DV_CONTEXT_FLAGS_ENHANCED_MPW = (1 << 3), /* Enhanced multi packet WQE is supported or not */
53                MLX5DV_CONTEXT_FLAGS_CQE_128B_COMP = (1 << 4), /* Support CQE 128B compression */
54                MLX5DV_CONTEXT_FLAGS_CQE_128B_PAD = (1 << 5), /* Support CQE 128B padding */
55       };
56
57
58       enum mlx5dv_context_comp_mask {
59               MLX5DV_CONTEXT_MASK_CQE_COMPRESION      = 1 << 0,
60               MLX5DV_CONTEXT_MASK_SWP                 = 1 << 1,
61               MLX5DV_CONTEXT_MASK_STRIDING_RQ         = 1 << 2,
62               MLX5DV_CONTEXT_MASK_TUNNEL_OFFLOADS     = 1 << 3,
63               MLX5DV_CONTEXT_MASK_RESERVED            = 1 << 4,
64       };
65
66
67       enum enum mlx5dv_sw_parsing_offloads {
68               MLX5DV_SW_PARSING         = 1 << 0,
69               MLX5DV_SW_PARSING_CSUM    = 1 << 1,
70               MLX5DV_SW_PARSING_LSO     = 1 << 2,
71       };
72
73
74       enum mlx5dv_tunnel_offloads {
75               MLX5DV_RAW_PACKET_CAP_TUNNELED_OFFLOAD_VXLAN  = 1 << 0,
76               MLX5DV_RAW_PACKET_CAP_TUNNELED_OFFLOAD_GRE    = 1 << 1,
77               MLX5DV_RAW_PACKET_CAP_TUNNELED_OFFLOAD_GENEVE = 1 << 2,
78       };
79
80

RETURN VALUE

82       0  on  success  or  the  value of errno on failure (which indicates the
83       failure reason).
84

NOTES

86        * Compatibility mask (comp_mask) is in/out field.
87

SEE ALSO

89       mlx5dv(7), ibv_query_device(3)
90

AUTHORS

92       Leon Romanovsky <leonro@mellanox.com>
93
94
95
961.0.0                             2017-02-02            MLX5DV_QUERY_DEVICE(3)
Impressum