aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBodong Wang <bodong@mellanox.com>2016-08-21 19:48:01 +0300
committerDoug Ledford <dledford@redhat.com>2016-08-25 10:42:40 -0400
commit3a338f6a11c93bc85e99b06cef3e0a5fadbde1e0 (patch)
treebc1c737e346463649cd78911c2b09b83a2e7202a
parent4e03cc1693c38291b87b53a4f7b3a8a998a2dac4 (diff)
downloadlibibverbs-3a338f6a11c93bc85e99b06cef3e0a5fadbde1e0.tar.gz
Update man pages for TSO support
Update relevant man pages for TSO: - Add max_tso_header as part of ibv_create_qp_ex man page. - Add IBV_WR_TSO opcode and update send operation support table for RAW_PACKET QP as part of ibv_post_send man page. - Add TSO capabilities as part of ibv_query_device_ex man page. In addition, fixed a typo as part of updating ibv_post_send related to ibv_odp_caps. Signed-off-by: Bodong Wang <bodong@mellanox.com> Reviewed-by: Yishai Hadas <yishaih@mellanox.com> Signed-off-by: Doug Ledford <dledford@redhat.com>
-rw-r--r--man/ibv_create_qp_ex.31
-rw-r--r--man/ibv_post_send.336
-rw-r--r--man/ibv_query_device_ex.322
3 files changed, 39 insertions, 20 deletions
diff --git a/man/ibv_create_qp_ex.3 b/man/ibv_create_qp_ex.3
index f772a57..a2a67a4 100644
--- a/man/ibv_create_qp_ex.3
+++ b/man/ibv_create_qp_ex.3
@@ -34,6 +34,7 @@ uint32_t comp_mask; /* Identifies valid fields */
struct ibv_pd *pd; /* PD to be associated with the QP */
struct ibv_xrcd *xrcd; /* XRC domain to be associated with the target QP */
enum ibv_qp_create_flags create_flags; /* Creation flags for this QP */
+uint16_t max_tso_header; /* Maximum TSO header size */
.in -8
};
.sp
diff --git a/man/ibv_post_send.3 b/man/ibv_post_send.3
index f918afb..c45eb01 100644
--- a/man/ibv_post_send.3
+++ b/man/ibv_post_send.3
@@ -69,6 +69,8 @@ uint32_t remote_srqn; /* Number of the remote SRQ */
} xrc;
.in -8
} qp_type;
+union {
+.in +8
struct {
.in +8
struct ibv_mw *mw; /* Memory window (MW) of type 2 to bind */
@@ -76,6 +78,15 @@ uint32_t rkey; /* The desired new rkey of the MW */
struct ibv_mw_bind_info bind_info; /* MW additional bind information */
.in -8
} bind_mw;
+struct {
+.in +8
+void *hdr; /* Pointer address of inline header */
+uint16_t hdr_sz; /* Inline header size */
+uint16_t mss; /* Maximum segment size for each TSO fragment */
+.in -8
+} tso;
+.in -8
+};
.in -8
};
.fi
@@ -104,18 +115,19 @@ uint32_t lkey; /* Key of the local Memory Regio
Each QP Transport Service Type supports a specific set of opcodes, as shown in the following table:
.PP
.nf
-OPCODE | IBV_QPT_UD | IBV_QPT_UC | IBV_QPT_RC | IBV_QPT_XRC_SEND
-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-+\-\-\-\-\-\-\-\-\-\-\-\-+\-\-\-\-\-\-\-\-\-\-\-\-+\-\-\-\-\-\-\-\-\-\-\-
-IBV_WR_SEND | X | X | X | X
-IBV_WR_SEND_WITH_IMM | X | X | X | X
-IBV_WR_RDMA_WRITE | | X | X | X
-IBV_WR_RDMA_WRITE_WITH_IMM | | X | X | X
-IBV_WR_RDMA_READ | | | X | X
-IBV_WR_ATOMIC_CMP_AND_SWP | | | X | X
-IBV_WR_ATOMIC_FETCH_AND_ADD | | | X | X
-IBV_WR_LOCAL_INV | | X | X | X
-IBV_WR_BIND_MW | | X | X | X
-IBV_WR_SEND_WITH_INV | | X | X | X
+OPCODE | IBV_QPT_UD | IBV_QPT_UC | IBV_QPT_RC | IBV_QPT_XRC_SEND | IBV_QPT_RAW_PACKET
+\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-+\-\-\-\-\-\-\-\-\-\-\-\-+\-\-\-\-\-\-\-\-\-\-\-\-+\-\-\-\-\-\-\-\-\-\-\-\-+\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-+\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-
+IBV_WR_SEND | X | X | X | X | X
+IBV_WR_SEND_WITH_IMM | X | X | X | X |
+IBV_WR_RDMA_WRITE | | X | X | X |
+IBV_WR_RDMA_WRITE_WITH_IMM | | X | X | X |
+IBV_WR_RDMA_READ | | | X | X |
+IBV_WR_ATOMIC_CMP_AND_SWP | | | X | X |
+IBV_WR_ATOMIC_FETCH_AND_ADD | | | X | X |
+IBV_WR_LOCAL_INV | | X | X | X |
+IBV_WR_BIND_MW | | X | X | X |
+IBV_WR_SEND_WITH_INV | | X | X | X |
+IBV_WR_TSO | X | | | | X
.fi
.PP
The attribute send_flags describes the properties of the \s-1WR\s0. It is either 0 or the bitwise \s-1OR\s0 of one or more of the following flags:
diff --git a/man/ibv_query_device_ex.3 b/man/ibv_query_device_ex.3
index 5097be0..d06b40f 100644
--- a/man/ibv_query_device_ex.3
+++ b/man/ibv_query_device_ex.3
@@ -26,17 +26,18 @@ uint32_t comp_mask; /* Compatibility mask that de
struct ibv_odp_caps odp_caps; /* On-Demand Paging capabilities */
uint64_t completion_timestamp_mask; /* Completion timestamp mask (0 = unsupported) */
uint64_t hca_core_clock; /* The frequency (in kHZ) of the HCA (0 = unsupported) */
-uint64_t device_cap_flags_ex; /* Extended device capability flags */
+uint64_t device_cap_flags_ex; /* Extended device capability flags */
+struct ibv_tso_caps tso_caps; /* TCP segmentation offload capabilities */
.in -8
};
-struct ibv_exp_odp_caps {
- uint64_t general_odp_caps; /* Mask with enum ibv_odp_general_cap_bits */
- struct {
- uint32_t rc_odp_caps; /* Mask with enum ibv_odp_tranport_cap_bits to know which operations are supported. */
- uint32_t uc_odp_caps; /* Mask with enum ibv_odp_tranport_cap_bits to know which operations are supported. */
- uint32_t ud_odp_caps; /* Mask with enum ibv_odp_tranport_cap_bits to know which operations are supported. */
- } per_transport_caps;
+struct ibv_odp_caps {
+ uint64_t general_odp_caps; /* Mask with enum ibv_odp_general_cap_bits */
+ struct {
+ uint32_t rc_odp_caps; /* Mask with enum ibv_odp_tranport_cap_bits to know which operations are supported. */
+ uint32_t uc_odp_caps; /* Mask with enum ibv_odp_tranport_cap_bits to know which operations are supported. */
+ uint32_t ud_odp_caps; /* Mask with enum ibv_odp_tranport_cap_bits to know which operations are supported. */
+ } per_transport_caps;
};
enum ibv_odp_general_cap_bits {
@@ -51,6 +52,11 @@ enum ibv_odp_transport_cap_bits {
IBV_ODP_SUPPORT_ATOMIC = 1 << 4, /* RDMA-Atomic operations support on-demand paging */
};
+struct ibv_tso_caps {
+ uint32_t max_tso; /* Maximum payload size in bytes supported for segmentation by TSO engine.*/
+ uint32_t supported_qpts; /* Bitmap showing which QP types are supported by TSO operation. */
+};
+
.fi
.SH "RETURN VALUE"
.B ibv_query_device_ex()