]> git.openfabrics.org - ~shefty/libibverbs.git/commit
libibverbs: Add support for XRC QPs
authorSean Hefty <sean.hefty@intel.com>
Mon, 17 Sep 2012 23:00:12 +0000 (16:00 -0700)
committerSean Hefty <sean.hefty@intel.com>
Mon, 17 Sep 2012 23:15:44 +0000 (16:15 -0700)
commit71de751ac24904a7170258c7ce63c739d28c7a05
treee7dc06c6bd70e08034618b89c2ed6a0f89a5c51d
parent2881e8cd99b0a71921b86fb1235b822a270b06b9
libibverbs: Add support for XRC QPs

XRC queue pairs: xrc defines two new types of QPs.  The
initiator, or send-side, xrc qp behaves similar to a send-
only RC qp.  xrc send qp's are managed through the existing
QP functions.  The send_wr structure is extended in a back-
wards compatible way to support posting sends on a send xrc
qp, which require specifying the remote xrc srq.

The target, or receive-side, xrc qp behaves differently
than other implemented qp's.  A recv xrc qp can be created,
modified, and destroyed like other qp's through the existing
calls.  The qp_init_attr structure is extended for xrc qp's.

Because xrc recv qp's are bound to an xrcd, rather than a pd,
it is intended to be used among multiple processes.  Any process
with access to an xrcd may allocate and connect an xrc recv qp.
The actual xrc recv qp is allocated and managed by the kernel.
If the owning process explicit destroys the xrc recv qp, it is
destroyed.  However, if the xrc recv qp is left open when the
user process exits or closes its device, then the lifetime of
the xrc recv qp is bound with the lifetime of the xrcd.

Signed-off-by: Sean Hefty <sean.hefty@intel.com>
include/infiniband/driver.h
include/infiniband/kern-abi.h
include/infiniband/verbs.h
src/cmd.c
src/libibverbs.map
src/verbs.c