rdma_user_cm.h 6.5 KB
Newer Older
1
/* SPDX-License-Identifier: ((GPL-2.0 WITH Linux-syscall-note) OR BSD-2-Clause) */
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37
/*
 * Copyright (c) 2005-2006 Intel Corporation.  All rights reserved.
 *
 * 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.
 */

#ifndef RDMA_USER_CM_H
#define RDMA_USER_CM_H

#include <linux/types.h>
38
#include <linux/socket.h>
39 40 41 42
#include <linux/in6.h>
#include <rdma/ib_user_verbs.h>
#include <rdma/ib_user_sa.h>

43
#define RDMA_USER_CM_ABI_VERSION	4
44 45 46 47 48 49

#define RDMA_MAX_PRIVATE_DATA		256

enum {
	RDMA_USER_CM_CMD_CREATE_ID,
	RDMA_USER_CM_CMD_DESTROY_ID,
50 51
	RDMA_USER_CM_CMD_BIND_IP,
	RDMA_USER_CM_CMD_RESOLVE_IP,
52 53 54 55 56 57 58 59 60 61 62
	RDMA_USER_CM_CMD_RESOLVE_ROUTE,
	RDMA_USER_CM_CMD_QUERY_ROUTE,
	RDMA_USER_CM_CMD_CONNECT,
	RDMA_USER_CM_CMD_LISTEN,
	RDMA_USER_CM_CMD_ACCEPT,
	RDMA_USER_CM_CMD_REJECT,
	RDMA_USER_CM_CMD_DISCONNECT,
	RDMA_USER_CM_CMD_INIT_QP_ATTR,
	RDMA_USER_CM_CMD_GET_EVENT,
	RDMA_USER_CM_CMD_GET_OPTION,
	RDMA_USER_CM_CMD_SET_OPTION,
63
	RDMA_USER_CM_CMD_NOTIFY,
64
	RDMA_USER_CM_CMD_JOIN_IP_MCAST,
65
	RDMA_USER_CM_CMD_LEAVE_MCAST,
66
	RDMA_USER_CM_CMD_MIGRATE_ID,
67
	RDMA_USER_CM_CMD_QUERY,
68
	RDMA_USER_CM_CMD_BIND,
69 70
	RDMA_USER_CM_CMD_RESOLVE_ADDR,
	RDMA_USER_CM_CMD_JOIN_MCAST
71 72 73 74 75 76 77 78 79 80 81 82
};

/*
 * command ABI structures.
 */
struct rdma_ucm_cmd_hdr {
	__u32 cmd;
	__u16 in;
	__u16 out;
};

struct rdma_ucm_create_id {
83 84
	__aligned_u64 uid;
	__aligned_u64 response;
85
	__u16 ps;
86 87
	__u8  qp_type;
	__u8  reserved[5];
88 89 90 91 92 93 94
};

struct rdma_ucm_create_id_resp {
	__u32 id;
};

struct rdma_ucm_destroy_id {
95
	__aligned_u64 response;
96 97 98 99 100 101 102 103
	__u32 id;
	__u32 reserved;
};

struct rdma_ucm_destroy_id_resp {
	__u32 events_reported;
};

104
struct rdma_ucm_bind_ip {
105
	__aligned_u64 response;
106 107 108 109
	struct sockaddr_in6 addr;
	__u32 id;
};

110 111 112 113
struct rdma_ucm_bind {
	__u32 id;
	__u16 addr_size;
	__u16 reserved;
114
	struct __kernel_sockaddr_storage addr;
115 116
};

117
struct rdma_ucm_resolve_ip {
118 119 120 121 122 123
	struct sockaddr_in6 src_addr;
	struct sockaddr_in6 dst_addr;
	__u32 id;
	__u32 timeout_ms;
};

124 125 126 127 128 129
struct rdma_ucm_resolve_addr {
	__u32 id;
	__u32 timeout_ms;
	__u16 src_size;
	__u16 dst_size;
	__u32 reserved;
130 131
	struct __kernel_sockaddr_storage src_addr;
	struct __kernel_sockaddr_storage dst_addr;
132 133
};

134 135 136 137 138
struct rdma_ucm_resolve_route {
	__u32 id;
	__u32 timeout_ms;
};

139
enum {
140
	RDMA_USER_CM_QUERY_ADDR,
141 142
	RDMA_USER_CM_QUERY_PATH,
	RDMA_USER_CM_QUERY_GID
143 144 145
};

struct rdma_ucm_query {
146
	__aligned_u64 response;
147
	__u32 id;
148
	__u32 option;
149 150 151
};

struct rdma_ucm_query_route_resp {
152
	__aligned_u64 node_guid;
153 154 155 156 157 158 159 160
	struct ib_user_path_rec ib_route[2];
	struct sockaddr_in6 src_addr;
	struct sockaddr_in6 dst_addr;
	__u32 num_paths;
	__u8 port_num;
	__u8 reserved[3];
};

161
struct rdma_ucm_query_addr_resp {
162
	__aligned_u64 node_guid;
163 164 165 166 167
	__u8  port_num;
	__u8  reserved;
	__u16 pkey;
	__u16 src_size;
	__u16 dst_size;
168 169
	struct __kernel_sockaddr_storage src_addr;
	struct __kernel_sockaddr_storage dst_addr;
170 171
};

172 173 174 175 176 177
struct rdma_ucm_query_path_resp {
	__u32 num_paths;
	__u32 reserved;
	struct ib_path_rec_data path_data[0];
};

178 179
struct rdma_ucm_conn_param {
	__u32 qp_num;
S
Sean Hefty 已提交
180
	__u32 qkey;
181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212
	__u8  private_data[RDMA_MAX_PRIVATE_DATA];
	__u8  private_data_len;
	__u8  srq;
	__u8  responder_resources;
	__u8  initiator_depth;
	__u8  flow_control;
	__u8  retry_count;
	__u8  rnr_retry_count;
	__u8  valid;
};

struct rdma_ucm_ud_param {
	__u32 qp_num;
	__u32 qkey;
	struct ib_uverbs_ah_attr ah_attr;
	__u8  private_data[RDMA_MAX_PRIVATE_DATA];
	__u8  private_data_len;
	__u8  reserved[7];
};

struct rdma_ucm_connect {
	struct rdma_ucm_conn_param conn_param;
	__u32 id;
	__u32 reserved;
};

struct rdma_ucm_listen {
	__u32 id;
	__u32 backlog;
};

struct rdma_ucm_accept {
213
	__aligned_u64 uid;
214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230
	struct rdma_ucm_conn_param conn_param;
	__u32 id;
	__u32 reserved;
};

struct rdma_ucm_reject {
	__u32 id;
	__u8  private_data_len;
	__u8  reserved[3];
	__u8  private_data[RDMA_MAX_PRIVATE_DATA];
};

struct rdma_ucm_disconnect {
	__u32 id;
};

struct rdma_ucm_init_qp_attr {
231
	__aligned_u64 response;
232 233 234 235 236 237 238 239 240
	__u32 id;
	__u32 qp_state;
};

struct rdma_ucm_notify {
	__u32 id;
	__u32 event;
};

241
struct rdma_ucm_join_ip_mcast {
242 243
	__aligned_u64 response;		/* rdma_ucm_create_id_resp */
	__aligned_u64 uid;
244 245 246 247
	struct sockaddr_in6 addr;
	__u32 id;
};

248 249 250 251 252 253 254
/* Multicast join flags */
enum {
	RDMA_MC_JOIN_FLAG_FULLMEMBER,
	RDMA_MC_JOIN_FLAG_SENDONLY_FULLMEMBER,
	RDMA_MC_JOIN_FLAG_RESERVED,
};

255
struct rdma_ucm_join_mcast {
256 257
	__aligned_u64 response;		/* rdma_ucma_create_id_resp */
	__aligned_u64 uid;
258 259
	__u32 id;
	__u16 addr_size;
260
	__u16 join_flags;
261
	struct __kernel_sockaddr_storage addr;
262 263
};

264
struct rdma_ucm_get_event {
265
	__aligned_u64 response;
266 267 268
};

struct rdma_ucm_event_resp {
269
	__aligned_u64 uid;
270 271 272
	__u32 id;
	__u32 event;
	__u32 status;
273 274 275 276
	/*
	 * NOTE: This union is not aligned to 8 bytes so none of the union
	 * members may contain a u64 or anything with higher alignment than 4.
	 */
277 278 279 280
	union {
		struct rdma_ucm_conn_param conn;
		struct rdma_ucm_ud_param   ud;
	} param;
281
	__u32 reserved;
282 283
};

284 285
/* Option levels */
enum {
286 287
	RDMA_OPTION_ID		= 0,
	RDMA_OPTION_IB		= 1
288 289 290 291
};

/* Option details */
enum {
292 293
	RDMA_OPTION_ID_TOS	 = 0,
	RDMA_OPTION_ID_REUSEADDR = 1,
294
	RDMA_OPTION_ID_AFONLY	 = 2,
295
	RDMA_OPTION_IB_PATH	 = 1
296 297 298
};

struct rdma_ucm_set_option {
299
	__aligned_u64 optval;
300 301 302 303 304 305
	__u32 id;
	__u32 level;
	__u32 optname;
	__u32 optlen;
};

306
struct rdma_ucm_migrate_id {
307
	__aligned_u64 response;
308 309 310 311 312 313 314 315
	__u32 id;
	__u32 fd;
};

struct rdma_ucm_migrate_resp {
	__u32 events_reported;
};

316
#endif /* RDMA_USER_CM_H */