2006-06-17 20:37:29 -07:00
/*
* Copyright ( c ) 2005 Voltaire Inc . All rights reserved .
* Copyright ( c ) 2005 Intel Corporation . All rights reserved .
*
2008-07-14 23:48:43 -07:00
* This software is available to you under a choice of one of two
* licenses . You may choose to be licensed under the terms of the GNU
* General Public License ( GPL ) Version 2 , available from the file
* COPYING in the main directory of this source tree , or the
* OpenIB . org BSD license below :
*
* Redistribution and use in source and binary forms , with or
* without modification , are permitted provided that the following
* conditions are met :
*
* - Redistributions of source code must retain the above
* copyright notice , this list of conditions and the following
* disclaimer .
*
* - Redistributions in binary form must reproduce the above
* copyright notice , this list of conditions and the following
* disclaimer in the documentation and / or other materials
* provided with the distribution .
*
* THE SOFTWARE IS PROVIDED " AS IS " , WITHOUT WARRANTY OF ANY KIND ,
* EXPRESS OR IMPLIED , INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
* MERCHANTABILITY , FITNESS FOR A PARTICULAR PURPOSE AND
* NONINFRINGEMENT . IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
* BE LIABLE FOR ANY CLAIM , DAMAGES OR OTHER LIABILITY , WHETHER IN AN
* ACTION OF CONTRACT , TORT OR OTHERWISE , ARISING FROM , OUT OF OR IN
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE .
2006-06-17 20:37:29 -07:00
*/
# if !defined(RDMA_CM_H)
# define RDMA_CM_H
# include <linux/socket.h>
# include <linux/in6.h>
# include <rdma/ib_addr.h>
# include <rdma/ib_sa.h>
/*
* Upon receiving a device removal event , users must destroy the associated
* RDMA identifier and release all resources allocated with the device .
*/
enum rdma_cm_event_type {
RDMA_CM_EVENT_ADDR_RESOLVED ,
RDMA_CM_EVENT_ADDR_ERROR ,
RDMA_CM_EVENT_ROUTE_RESOLVED ,
RDMA_CM_EVENT_ROUTE_ERROR ,
RDMA_CM_EVENT_CONNECT_REQUEST ,
RDMA_CM_EVENT_CONNECT_RESPONSE ,
RDMA_CM_EVENT_CONNECT_ERROR ,
RDMA_CM_EVENT_UNREACHABLE ,
RDMA_CM_EVENT_REJECTED ,
RDMA_CM_EVENT_ESTABLISHED ,
RDMA_CM_EVENT_DISCONNECTED ,
RDMA_CM_EVENT_DEVICE_REMOVAL ,
2007-02-15 17:00:18 -08:00
RDMA_CM_EVENT_MULTICAST_JOIN ,
2008-07-22 14:14:22 -07:00
RDMA_CM_EVENT_MULTICAST_ERROR ,
2008-07-22 14:14:23 -07:00
RDMA_CM_EVENT_ADDR_CHANGE ,
RDMA_CM_EVENT_TIMEWAIT_EXIT
2006-06-17 20:37:29 -07:00
} ;
enum rdma_port_space {
2008-07-14 23:48:44 -07:00
RDMA_PS_SDP = 0x0001 ,
RDMA_PS_IPOIB = 0x0002 ,
2011-05-28 21:56:39 -07:00
RDMA_PS_IB = 0x013F ,
2008-07-14 23:48:44 -07:00
RDMA_PS_TCP = 0x0106 ,
RDMA_PS_UDP = 0x0111 ,
2006-06-17 20:37:29 -07:00
} ;
2013-05-29 10:09:11 -07:00
# define RDMA_IB_IP_PS_MASK 0xFFFFFFFFFFFF0000ULL
# define RDMA_IB_IP_PS_TCP 0x0000000001060000ULL
# define RDMA_IB_IP_PS_UDP 0x0000000001110000ULL
# define RDMA_IB_IP_PS_IB 0x00000000013F0000ULL
2006-06-17 20:37:29 -07:00
struct rdma_addr {
2008-08-04 11:02:14 -07:00
struct sockaddr_storage src_addr ;
struct sockaddr_storage dst_addr ;
2006-06-17 20:37:29 -07:00
struct rdma_dev_addr dev_addr ;
} ;
struct rdma_route {
struct rdma_addr addr ;
struct ib_sa_path_rec * path_rec ;
int num_paths ;
} ;
2006-11-30 16:33:14 -08:00
struct rdma_conn_param {
const void * private_data ;
u8 private_data_len ;
u8 responder_resources ;
u8 initiator_depth ;
u8 flow_control ;
u8 retry_count ; /* ignored when accepting */
u8 rnr_retry_count ;
/* Fields below ignored if a QP is created on the rdma_cm_id. */
u8 srq ;
u32 qp_num ;
} ;
2006-11-30 16:44:16 -08:00
struct rdma_ud_param {
const void * private_data ;
u8 private_data_len ;
struct ib_ah_attr ah_attr ;
u32 qp_num ;
u32 qkey ;
} ;
2006-06-17 20:37:29 -07:00
struct rdma_cm_event {
enum rdma_cm_event_type event ;
int status ;
2006-11-30 16:33:14 -08:00
union {
struct rdma_conn_param conn ;
2006-11-30 16:44:16 -08:00
struct rdma_ud_param ud ;
2006-11-30 16:33:14 -08:00
} param ;
2006-06-17 20:37:29 -07:00
} ;
2011-05-20 11:46:11 -07:00
enum rdma_cm_state {
RDMA_CM_IDLE ,
RDMA_CM_ADDR_QUERY ,
RDMA_CM_ADDR_RESOLVED ,
RDMA_CM_ROUTE_QUERY ,
RDMA_CM_ROUTE_RESOLVED ,
RDMA_CM_CONNECT ,
RDMA_CM_DISCONNECT ,
RDMA_CM_ADDR_BOUND ,
RDMA_CM_LISTEN ,
RDMA_CM_DEVICE_REMOVAL ,
RDMA_CM_DESTROYING
} ;
2006-06-17 20:37:29 -07:00
struct rdma_cm_id ;
/**
* rdma_cm_event_handler - Callback used to report user events .
*
* Notes : Users may not call rdma_destroy_id from this callback to destroy
* the passed in id , or a corresponding listen id . Returning a
* non - zero value from the callback will destroy the passed in id .
*/
typedef int ( * rdma_cm_event_handler ) ( struct rdma_cm_id * id ,
struct rdma_cm_event * event ) ;
struct rdma_cm_id {
struct ib_device * device ;
void * context ;
struct ib_qp * qp ;
rdma_cm_event_handler event_handler ;
struct rdma_route route ;
enum rdma_port_space ps ;
2010-04-01 17:08:41 +00:00
enum ib_qp_type qp_type ;
2006-06-17 20:37:29 -07:00
u8 port_num ;
} ;
/**
* rdma_create_id - Create an RDMA identifier .
*
* @ event_handler : User callback invoked to report events associated with the
* returned rdma_id .
* @ context : User specified context associated with the id .
* @ ps : RDMA port space .
2010-04-01 17:08:41 +00:00
* @ qp_type : type of queue pair associated with the id .
2006-06-17 20:37:29 -07:00
*/
struct rdma_cm_id * rdma_create_id ( rdma_cm_event_handler event_handler ,
2010-04-01 17:08:41 +00:00
void * context , enum rdma_port_space ps ,
enum ib_qp_type qp_type ) ;
2006-06-17 20:37:29 -07:00
2006-09-12 09:03:33 -07:00
/**
* rdma_destroy_id - Destroys an RDMA identifier .
*
* @ id : RDMA identifier .
*
* Note : calling this function has the effect of canceling in - flight
* asynchronous operations associated with the id .
*/
2006-06-17 20:37:29 -07:00
void rdma_destroy_id ( struct rdma_cm_id * id ) ;
/**
* rdma_bind_addr - Bind an RDMA identifier to a source address and
* associated RDMA device , if needed .
*
* @ id : RDMA identifier .
* @ addr : Local address information . Wildcard values are permitted .
*
* This associates a source address with the RDMA identifier before calling
* rdma_listen . If a specific local address is given , the RDMA identifier will
* be bound to a local RDMA device .
*/
int rdma_bind_addr ( struct rdma_cm_id * id , struct sockaddr * addr ) ;
/**
* rdma_resolve_addr - Resolve destination and optional source addresses
* from IP addresses to an RDMA address . If successful , the specified
* rdma_cm_id will be bound to a local device .
*
* @ id : RDMA identifier .
* @ src_addr : Source address information . This parameter may be NULL .
* @ dst_addr : Destination address information .
* @ timeout_ms : Time to wait for resolution to complete .
*/
int rdma_resolve_addr ( struct rdma_cm_id * id , struct sockaddr * src_addr ,
struct sockaddr * dst_addr , int timeout_ms ) ;
/**
* rdma_resolve_route - Resolve the RDMA address bound to the RDMA identifier
* into route information needed to establish a connection .
*
* This is called on the client side of a connection .
* Users must have first called rdma_resolve_addr to resolve a dst_addr
* into an RDMA address before calling this routine .
*/
int rdma_resolve_route ( struct rdma_cm_id * id , int timeout_ms ) ;
/**
* rdma_create_qp - Allocate a QP and associate it with the specified RDMA
* identifier .
*
* QPs allocated to an rdma_cm_id will automatically be transitioned by the CMA
* through their states .
*/
int rdma_create_qp ( struct rdma_cm_id * id , struct ib_pd * pd ,
struct ib_qp_init_attr * qp_init_attr ) ;
/**
* rdma_destroy_qp - Deallocate the QP associated with the specified RDMA
* identifier .
*
* Users must destroy any QP associated with an RDMA identifier before
* destroying the RDMA ID .
*/
void rdma_destroy_qp ( struct rdma_cm_id * id ) ;
/**
* rdma_init_qp_attr - Initializes the QP attributes for use in transitioning
* to a specified QP state .
* @ id : Communication identifier associated with the QP attributes to
* initialize .
* @ qp_attr : On input , specifies the desired QP state . On output , the
* mandatory and desired optional attributes will be set in order to
* modify the QP to the specified state .
* @ qp_attr_mask : The QP attribute mask that may be used to transition the
* QP to the specified state .
*
* Users must set the @ qp_attr - > qp_state to the desired QP state . This call
* will set all required attributes for the given transition , along with
* known optional attributes . Users may override the attributes returned from
* this call before calling ib_modify_qp .
*
* Users that wish to have their QP automatically transitioned through its
* states can associate a QP with the rdma_cm_id by calling rdma_create_qp ( ) .
*/
int rdma_init_qp_attr ( struct rdma_cm_id * id , struct ib_qp_attr * qp_attr ,
int * qp_attr_mask ) ;
/**
* rdma_connect - Initiate an active connection request .
2006-11-30 16:44:16 -08:00
* @ id : Connection identifier to connect .
* @ conn_param : Connection information used for connected QPs .
2006-06-17 20:37:29 -07:00
*
* Users must have resolved a route for the rdma_cm_id to connect with
* by having called rdma_resolve_route before calling this routine .
2006-11-30 16:44:16 -08:00
*
* This call will either connect to a remote QP or obtain remote QP
* information for unconnected rdma_cm_id ' s . The actual operation is
* based on the rdma_cm_id ' s port space .
2006-06-17 20:37:29 -07:00
*/
int rdma_connect ( struct rdma_cm_id * id , struct rdma_conn_param * conn_param ) ;
/**
* rdma_listen - This function is called by the passive side to
* listen for incoming connection requests .
*
* Users must have bound the rdma_cm_id to a local address by calling
* rdma_bind_addr before calling this routine .
*/
int rdma_listen ( struct rdma_cm_id * id , int backlog ) ;
/**
* rdma_accept - Called to accept a connection request or response .
* @ id : Connection identifier associated with the request .
* @ conn_param : Information needed to establish the connection . This must be
* provided if accepting a connection request . If accepting a connection
* response , this parameter must be NULL .
*
* Typically , this routine is only called by the listener to accept a connection
* request . It must also be called on the active side of a connection if the
* user is performing their own QP transitions .
2006-09-22 15:22:54 -07:00
*
* In the case of error , a reject message is sent to the remote side and the
* state of the qp associated with the id is modified to error , such that any
* previously posted receive buffers would be flushed .
2006-06-17 20:37:29 -07:00
*/
int rdma_accept ( struct rdma_cm_id * id , struct rdma_conn_param * conn_param ) ;
2006-11-30 16:37:15 -08:00
/**
* rdma_notify - Notifies the RDMA CM of an asynchronous event that has
* occurred on the connection .
* @ id : Connection identifier to transition to established .
* @ event : Asynchronous event .
*
* This routine should be invoked by users to notify the CM of relevant
* communication events . Events that should be reported to the CM and
* when to report them are :
*
* IB_EVENT_COMM_EST - Used when a message is received on a connected
* QP before an RTU has been received .
*/
int rdma_notify ( struct rdma_cm_id * id , enum ib_event_type event ) ;
2006-06-17 20:37:29 -07:00
/**
* rdma_reject - Called to reject a connection request or response .
*/
int rdma_reject ( struct rdma_cm_id * id , const void * private_data ,
u8 private_data_len ) ;
/**
* rdma_disconnect - This function disconnects the associated QP and
* transitions it into the error state .
*/
int rdma_disconnect ( struct rdma_cm_id * id ) ;
2007-02-15 17:00:18 -08:00
/**
* rdma_join_multicast - Join the multicast group specified by the given
* address .
* @ id : Communication identifier associated with the request .
* @ addr : Multicast address identifying the group to join .
* @ context : User - defined context associated with the join request , returned
* to the user through the private_data pointer in multicast events .
*/
int rdma_join_multicast ( struct rdma_cm_id * id , struct sockaddr * addr ,
void * context ) ;
2006-06-17 20:37:29 -07:00
2007-02-15 17:00:18 -08:00
/**
* rdma_leave_multicast - Leave the multicast group specified by the given
* address .
*/
void rdma_leave_multicast ( struct rdma_cm_id * id , struct sockaddr * addr ) ;
2007-08-08 15:51:06 -07:00
/**
* rdma_set_service_type - Set the type of service associated with a
* connection identifier .
* @ id : Communication identifier to associated with service type .
* @ tos : Type of service .
*
* The type of service is interpretted as a differentiated service
* field ( RFC 2474 ) . The service type should be specified before
* performing route resolution , as existing communication on the
* connection identifier may be unaffected . The type of service
* requested may not be supported by the network to all destinations .
*/
void rdma_set_service_type ( struct rdma_cm_id * id , int tos ) ;
2011-05-09 22:06:10 -07:00
/**
* rdma_set_reuseaddr - Allow the reuse of local addresses when binding
* the rdma_cm_id .
* @ id : Communication identifier to configure .
* @ reuse : Value indicating if the bound address is reusable .
*
* Reuse must be set before an address is bound to the id .
*/
int rdma_set_reuseaddr ( struct rdma_cm_id * id , int reuse ) ;
2012-06-14 20:31:39 +00:00
/**
* rdma_set_afonly - Specify that listens are restricted to the
* bound address family only .
* @ id : Communication identifer to configure .
* @ afonly : Value indicating if listens are restricted .
*
* Must be set before identifier is in the listening state .
*/
int rdma_set_afonly ( struct rdma_cm_id * id , int afonly ) ;
2007-02-15 17:00:18 -08:00
# endif /* RDMA_CM_H */