[PATCH] w1: Added add/remove slave callbacks.
[linux-2.6/verdex.git] / drivers / infiniband / core / mad.c
bloba4a4d9c1eef3ebb70603441d81f418898bb9cfa8
1 /*
2 * Copyright (c) 2004, 2005 Voltaire, Inc. All rights reserved.
3 * Copyright (c) 2005 Intel Corporation. All rights reserved.
4 * Copyright (c) 2005 Mellanox Technologies Ltd. All rights reserved.
6 * This software is available to you under a choice of one of two
7 * licenses. You may choose to be licensed under the terms of the GNU
8 * General Public License (GPL) Version 2, available from the file
9 * COPYING in the main directory of this source tree, or the
10 * OpenIB.org BSD license below:
12 * Redistribution and use in source and binary forms, with or
13 * without modification, are permitted provided that the following
14 * conditions are met:
16 * - Redistributions of source code must retain the above
17 * copyright notice, this list of conditions and the following
18 * disclaimer.
20 * - Redistributions in binary form must reproduce the above
21 * copyright notice, this list of conditions and the following
22 * disclaimer in the documentation and/or other materials
23 * provided with the distribution.
25 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
26 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
27 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
28 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
29 * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
30 * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
31 * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
32 * SOFTWARE.
34 * $Id: mad.c 2817 2005-07-07 11:29:26Z halr $
36 #include <linux/dma-mapping.h>
38 #include "mad_priv.h"
39 #include "mad_rmpp.h"
40 #include "smi.h"
41 #include "agent.h"
43 MODULE_LICENSE("Dual BSD/GPL");
44 MODULE_DESCRIPTION("kernel IB MAD API");
45 MODULE_AUTHOR("Hal Rosenstock");
46 MODULE_AUTHOR("Sean Hefty");
49 kmem_cache_t *ib_mad_cache;
51 static struct list_head ib_mad_port_list;
52 static u32 ib_mad_client_id = 0;
54 /* Port list lock */
55 static spinlock_t ib_mad_port_list_lock;
58 /* Forward declarations */
59 static int method_in_use(struct ib_mad_mgmt_method_table **method,
60 struct ib_mad_reg_req *mad_reg_req);
61 static void remove_mad_reg_req(struct ib_mad_agent_private *priv);
62 static struct ib_mad_agent_private *find_mad_agent(
63 struct ib_mad_port_private *port_priv,
64 struct ib_mad *mad);
65 static int ib_mad_post_receive_mads(struct ib_mad_qp_info *qp_info,
66 struct ib_mad_private *mad);
67 static void cancel_mads(struct ib_mad_agent_private *mad_agent_priv);
68 static void timeout_sends(void *data);
69 static void local_completions(void *data);
70 static int add_nonoui_reg_req(struct ib_mad_reg_req *mad_reg_req,
71 struct ib_mad_agent_private *agent_priv,
72 u8 mgmt_class);
73 static int add_oui_reg_req(struct ib_mad_reg_req *mad_reg_req,
74 struct ib_mad_agent_private *agent_priv);
77 * Returns a ib_mad_port_private structure or NULL for a device/port
78 * Assumes ib_mad_port_list_lock is being held
80 static inline struct ib_mad_port_private *
81 __ib_get_mad_port(struct ib_device *device, int port_num)
83 struct ib_mad_port_private *entry;
85 list_for_each_entry(entry, &ib_mad_port_list, port_list) {
86 if (entry->device == device && entry->port_num == port_num)
87 return entry;
89 return NULL;
93 * Wrapper function to return a ib_mad_port_private structure or NULL
94 * for a device/port
96 static inline struct ib_mad_port_private *
97 ib_get_mad_port(struct ib_device *device, int port_num)
99 struct ib_mad_port_private *entry;
100 unsigned long flags;
102 spin_lock_irqsave(&ib_mad_port_list_lock, flags);
103 entry = __ib_get_mad_port(device, port_num);
104 spin_unlock_irqrestore(&ib_mad_port_list_lock, flags);
106 return entry;
109 static inline u8 convert_mgmt_class(u8 mgmt_class)
111 /* Alias IB_MGMT_CLASS_SUBN_DIRECTED_ROUTE to 0 */
112 return mgmt_class == IB_MGMT_CLASS_SUBN_DIRECTED_ROUTE ?
113 0 : mgmt_class;
116 static int get_spl_qp_index(enum ib_qp_type qp_type)
118 switch (qp_type)
120 case IB_QPT_SMI:
121 return 0;
122 case IB_QPT_GSI:
123 return 1;
124 default:
125 return -1;
129 static int vendor_class_index(u8 mgmt_class)
131 return mgmt_class - IB_MGMT_CLASS_VENDOR_RANGE2_START;
134 static int is_vendor_class(u8 mgmt_class)
136 if ((mgmt_class < IB_MGMT_CLASS_VENDOR_RANGE2_START) ||
137 (mgmt_class > IB_MGMT_CLASS_VENDOR_RANGE2_END))
138 return 0;
139 return 1;
142 static int is_vendor_oui(char *oui)
144 if (oui[0] || oui[1] || oui[2])
145 return 1;
146 return 0;
149 static int is_vendor_method_in_use(
150 struct ib_mad_mgmt_vendor_class *vendor_class,
151 struct ib_mad_reg_req *mad_reg_req)
153 struct ib_mad_mgmt_method_table *method;
154 int i;
156 for (i = 0; i < MAX_MGMT_OUI; i++) {
157 if (!memcmp(vendor_class->oui[i], mad_reg_req->oui, 3)) {
158 method = vendor_class->method_table[i];
159 if (method) {
160 if (method_in_use(&method, mad_reg_req))
161 return 1;
162 else
163 break;
167 return 0;
171 * ib_register_mad_agent - Register to send/receive MADs
173 struct ib_mad_agent *ib_register_mad_agent(struct ib_device *device,
174 u8 port_num,
175 enum ib_qp_type qp_type,
176 struct ib_mad_reg_req *mad_reg_req,
177 u8 rmpp_version,
178 ib_mad_send_handler send_handler,
179 ib_mad_recv_handler recv_handler,
180 void *context)
182 struct ib_mad_port_private *port_priv;
183 struct ib_mad_agent *ret = ERR_PTR(-EINVAL);
184 struct ib_mad_agent_private *mad_agent_priv;
185 struct ib_mad_reg_req *reg_req = NULL;
186 struct ib_mad_mgmt_class_table *class;
187 struct ib_mad_mgmt_vendor_class_table *vendor;
188 struct ib_mad_mgmt_vendor_class *vendor_class;
189 struct ib_mad_mgmt_method_table *method;
190 int ret2, qpn;
191 unsigned long flags;
192 u8 mgmt_class, vclass;
194 /* Validate parameters */
195 qpn = get_spl_qp_index(qp_type);
196 if (qpn == -1)
197 goto error1;
199 if (rmpp_version && rmpp_version != IB_MGMT_RMPP_VERSION)
200 goto error1;
202 /* Validate MAD registration request if supplied */
203 if (mad_reg_req) {
204 if (mad_reg_req->mgmt_class_version >= MAX_MGMT_VERSION)
205 goto error1;
206 if (!recv_handler)
207 goto error1;
208 if (mad_reg_req->mgmt_class >= MAX_MGMT_CLASS) {
210 * IB_MGMT_CLASS_SUBN_DIRECTED_ROUTE is the only
211 * one in this range currently allowed
213 if (mad_reg_req->mgmt_class !=
214 IB_MGMT_CLASS_SUBN_DIRECTED_ROUTE)
215 goto error1;
216 } else if (mad_reg_req->mgmt_class == 0) {
218 * Class 0 is reserved in IBA and is used for
219 * aliasing of IB_MGMT_CLASS_SUBN_DIRECTED_ROUTE
221 goto error1;
222 } else if (is_vendor_class(mad_reg_req->mgmt_class)) {
224 * If class is in "new" vendor range,
225 * ensure supplied OUI is not zero
227 if (!is_vendor_oui(mad_reg_req->oui))
228 goto error1;
230 /* Make sure class supplied is consistent with QP type */
231 if (qp_type == IB_QPT_SMI) {
232 if ((mad_reg_req->mgmt_class !=
233 IB_MGMT_CLASS_SUBN_LID_ROUTED) &&
234 (mad_reg_req->mgmt_class !=
235 IB_MGMT_CLASS_SUBN_DIRECTED_ROUTE))
236 goto error1;
237 } else {
238 if ((mad_reg_req->mgmt_class ==
239 IB_MGMT_CLASS_SUBN_LID_ROUTED) ||
240 (mad_reg_req->mgmt_class ==
241 IB_MGMT_CLASS_SUBN_DIRECTED_ROUTE))
242 goto error1;
244 } else {
245 /* No registration request supplied */
246 if (!send_handler)
247 goto error1;
250 /* Validate device and port */
251 port_priv = ib_get_mad_port(device, port_num);
252 if (!port_priv) {
253 ret = ERR_PTR(-ENODEV);
254 goto error1;
257 /* Allocate structures */
258 mad_agent_priv = kmalloc(sizeof *mad_agent_priv, GFP_KERNEL);
259 if (!mad_agent_priv) {
260 ret = ERR_PTR(-ENOMEM);
261 goto error1;
263 memset(mad_agent_priv, 0, sizeof *mad_agent_priv);
265 mad_agent_priv->agent.mr = ib_get_dma_mr(port_priv->qp_info[qpn].qp->pd,
266 IB_ACCESS_LOCAL_WRITE);
267 if (IS_ERR(mad_agent_priv->agent.mr)) {
268 ret = ERR_PTR(-ENOMEM);
269 goto error2;
272 if (mad_reg_req) {
273 reg_req = kmalloc(sizeof *reg_req, GFP_KERNEL);
274 if (!reg_req) {
275 ret = ERR_PTR(-ENOMEM);
276 goto error3;
278 /* Make a copy of the MAD registration request */
279 memcpy(reg_req, mad_reg_req, sizeof *reg_req);
282 /* Now, fill in the various structures */
283 mad_agent_priv->qp_info = &port_priv->qp_info[qpn];
284 mad_agent_priv->reg_req = reg_req;
285 mad_agent_priv->agent.rmpp_version = rmpp_version;
286 mad_agent_priv->agent.device = device;
287 mad_agent_priv->agent.recv_handler = recv_handler;
288 mad_agent_priv->agent.send_handler = send_handler;
289 mad_agent_priv->agent.context = context;
290 mad_agent_priv->agent.qp = port_priv->qp_info[qpn].qp;
291 mad_agent_priv->agent.port_num = port_num;
293 spin_lock_irqsave(&port_priv->reg_lock, flags);
294 mad_agent_priv->agent.hi_tid = ++ib_mad_client_id;
297 * Make sure MAD registration (if supplied)
298 * is non overlapping with any existing ones
300 if (mad_reg_req) {
301 mgmt_class = convert_mgmt_class(mad_reg_req->mgmt_class);
302 if (!is_vendor_class(mgmt_class)) {
303 class = port_priv->version[mad_reg_req->
304 mgmt_class_version].class;
305 if (class) {
306 method = class->method_table[mgmt_class];
307 if (method) {
308 if (method_in_use(&method,
309 mad_reg_req))
310 goto error4;
313 ret2 = add_nonoui_reg_req(mad_reg_req, mad_agent_priv,
314 mgmt_class);
315 } else {
316 /* "New" vendor class range */
317 vendor = port_priv->version[mad_reg_req->
318 mgmt_class_version].vendor;
319 if (vendor) {
320 vclass = vendor_class_index(mgmt_class);
321 vendor_class = vendor->vendor_class[vclass];
322 if (vendor_class) {
323 if (is_vendor_method_in_use(
324 vendor_class,
325 mad_reg_req))
326 goto error4;
329 ret2 = add_oui_reg_req(mad_reg_req, mad_agent_priv);
331 if (ret2) {
332 ret = ERR_PTR(ret2);
333 goto error4;
337 /* Add mad agent into port's agent list */
338 list_add_tail(&mad_agent_priv->agent_list, &port_priv->agent_list);
339 spin_unlock_irqrestore(&port_priv->reg_lock, flags);
341 spin_lock_init(&mad_agent_priv->lock);
342 INIT_LIST_HEAD(&mad_agent_priv->send_list);
343 INIT_LIST_HEAD(&mad_agent_priv->wait_list);
344 INIT_LIST_HEAD(&mad_agent_priv->done_list);
345 INIT_LIST_HEAD(&mad_agent_priv->rmpp_list);
346 INIT_WORK(&mad_agent_priv->timed_work, timeout_sends, mad_agent_priv);
347 INIT_LIST_HEAD(&mad_agent_priv->local_list);
348 INIT_WORK(&mad_agent_priv->local_work, local_completions,
349 mad_agent_priv);
350 atomic_set(&mad_agent_priv->refcount, 1);
351 init_waitqueue_head(&mad_agent_priv->wait);
353 return &mad_agent_priv->agent;
355 error4:
356 spin_unlock_irqrestore(&port_priv->reg_lock, flags);
357 kfree(reg_req);
358 error3:
359 kfree(mad_agent_priv);
360 error2:
361 ib_dereg_mr(mad_agent_priv->agent.mr);
362 error1:
363 return ret;
365 EXPORT_SYMBOL(ib_register_mad_agent);
367 static inline int is_snooping_sends(int mad_snoop_flags)
369 return (mad_snoop_flags &
370 (/*IB_MAD_SNOOP_POSTED_SENDS |
371 IB_MAD_SNOOP_RMPP_SENDS |*/
372 IB_MAD_SNOOP_SEND_COMPLETIONS /*|
373 IB_MAD_SNOOP_RMPP_SEND_COMPLETIONS*/));
376 static inline int is_snooping_recvs(int mad_snoop_flags)
378 return (mad_snoop_flags &
379 (IB_MAD_SNOOP_RECVS /*|
380 IB_MAD_SNOOP_RMPP_RECVS*/));
383 static int register_snoop_agent(struct ib_mad_qp_info *qp_info,
384 struct ib_mad_snoop_private *mad_snoop_priv)
386 struct ib_mad_snoop_private **new_snoop_table;
387 unsigned long flags;
388 int i;
390 spin_lock_irqsave(&qp_info->snoop_lock, flags);
391 /* Check for empty slot in array. */
392 for (i = 0; i < qp_info->snoop_table_size; i++)
393 if (!qp_info->snoop_table[i])
394 break;
396 if (i == qp_info->snoop_table_size) {
397 /* Grow table. */
398 new_snoop_table = kmalloc(sizeof mad_snoop_priv *
399 qp_info->snoop_table_size + 1,
400 GFP_ATOMIC);
401 if (!new_snoop_table) {
402 i = -ENOMEM;
403 goto out;
405 if (qp_info->snoop_table) {
406 memcpy(new_snoop_table, qp_info->snoop_table,
407 sizeof mad_snoop_priv *
408 qp_info->snoop_table_size);
409 kfree(qp_info->snoop_table);
411 qp_info->snoop_table = new_snoop_table;
412 qp_info->snoop_table_size++;
414 qp_info->snoop_table[i] = mad_snoop_priv;
415 atomic_inc(&qp_info->snoop_count);
416 out:
417 spin_unlock_irqrestore(&qp_info->snoop_lock, flags);
418 return i;
421 struct ib_mad_agent *ib_register_mad_snoop(struct ib_device *device,
422 u8 port_num,
423 enum ib_qp_type qp_type,
424 int mad_snoop_flags,
425 ib_mad_snoop_handler snoop_handler,
426 ib_mad_recv_handler recv_handler,
427 void *context)
429 struct ib_mad_port_private *port_priv;
430 struct ib_mad_agent *ret;
431 struct ib_mad_snoop_private *mad_snoop_priv;
432 int qpn;
434 /* Validate parameters */
435 if ((is_snooping_sends(mad_snoop_flags) && !snoop_handler) ||
436 (is_snooping_recvs(mad_snoop_flags) && !recv_handler)) {
437 ret = ERR_PTR(-EINVAL);
438 goto error1;
440 qpn = get_spl_qp_index(qp_type);
441 if (qpn == -1) {
442 ret = ERR_PTR(-EINVAL);
443 goto error1;
445 port_priv = ib_get_mad_port(device, port_num);
446 if (!port_priv) {
447 ret = ERR_PTR(-ENODEV);
448 goto error1;
450 /* Allocate structures */
451 mad_snoop_priv = kmalloc(sizeof *mad_snoop_priv, GFP_KERNEL);
452 if (!mad_snoop_priv) {
453 ret = ERR_PTR(-ENOMEM);
454 goto error1;
457 /* Now, fill in the various structures */
458 memset(mad_snoop_priv, 0, sizeof *mad_snoop_priv);
459 mad_snoop_priv->qp_info = &port_priv->qp_info[qpn];
460 mad_snoop_priv->agent.device = device;
461 mad_snoop_priv->agent.recv_handler = recv_handler;
462 mad_snoop_priv->agent.snoop_handler = snoop_handler;
463 mad_snoop_priv->agent.context = context;
464 mad_snoop_priv->agent.qp = port_priv->qp_info[qpn].qp;
465 mad_snoop_priv->agent.port_num = port_num;
466 mad_snoop_priv->mad_snoop_flags = mad_snoop_flags;
467 init_waitqueue_head(&mad_snoop_priv->wait);
468 mad_snoop_priv->snoop_index = register_snoop_agent(
469 &port_priv->qp_info[qpn],
470 mad_snoop_priv);
471 if (mad_snoop_priv->snoop_index < 0) {
472 ret = ERR_PTR(mad_snoop_priv->snoop_index);
473 goto error2;
476 atomic_set(&mad_snoop_priv->refcount, 1);
477 return &mad_snoop_priv->agent;
479 error2:
480 kfree(mad_snoop_priv);
481 error1:
482 return ret;
484 EXPORT_SYMBOL(ib_register_mad_snoop);
486 static void unregister_mad_agent(struct ib_mad_agent_private *mad_agent_priv)
488 struct ib_mad_port_private *port_priv;
489 unsigned long flags;
491 /* Note that we could still be handling received MADs */
494 * Canceling all sends results in dropping received response
495 * MADs, preventing us from queuing additional work
497 cancel_mads(mad_agent_priv);
498 port_priv = mad_agent_priv->qp_info->port_priv;
499 cancel_delayed_work(&mad_agent_priv->timed_work);
501 spin_lock_irqsave(&port_priv->reg_lock, flags);
502 remove_mad_reg_req(mad_agent_priv);
503 list_del(&mad_agent_priv->agent_list);
504 spin_unlock_irqrestore(&port_priv->reg_lock, flags);
506 flush_workqueue(port_priv->wq);
507 ib_cancel_rmpp_recvs(mad_agent_priv);
509 atomic_dec(&mad_agent_priv->refcount);
510 wait_event(mad_agent_priv->wait,
511 !atomic_read(&mad_agent_priv->refcount));
513 if (mad_agent_priv->reg_req)
514 kfree(mad_agent_priv->reg_req);
515 ib_dereg_mr(mad_agent_priv->agent.mr);
516 kfree(mad_agent_priv);
519 static void unregister_mad_snoop(struct ib_mad_snoop_private *mad_snoop_priv)
521 struct ib_mad_qp_info *qp_info;
522 unsigned long flags;
524 qp_info = mad_snoop_priv->qp_info;
525 spin_lock_irqsave(&qp_info->snoop_lock, flags);
526 qp_info->snoop_table[mad_snoop_priv->snoop_index] = NULL;
527 atomic_dec(&qp_info->snoop_count);
528 spin_unlock_irqrestore(&qp_info->snoop_lock, flags);
530 atomic_dec(&mad_snoop_priv->refcount);
531 wait_event(mad_snoop_priv->wait,
532 !atomic_read(&mad_snoop_priv->refcount));
534 kfree(mad_snoop_priv);
538 * ib_unregister_mad_agent - Unregisters a client from using MAD services
540 int ib_unregister_mad_agent(struct ib_mad_agent *mad_agent)
542 struct ib_mad_agent_private *mad_agent_priv;
543 struct ib_mad_snoop_private *mad_snoop_priv;
545 /* If the TID is zero, the agent can only snoop. */
546 if (mad_agent->hi_tid) {
547 mad_agent_priv = container_of(mad_agent,
548 struct ib_mad_agent_private,
549 agent);
550 unregister_mad_agent(mad_agent_priv);
551 } else {
552 mad_snoop_priv = container_of(mad_agent,
553 struct ib_mad_snoop_private,
554 agent);
555 unregister_mad_snoop(mad_snoop_priv);
557 return 0;
559 EXPORT_SYMBOL(ib_unregister_mad_agent);
561 static inline int response_mad(struct ib_mad *mad)
563 /* Trap represses are responses although response bit is reset */
564 return ((mad->mad_hdr.method == IB_MGMT_METHOD_TRAP_REPRESS) ||
565 (mad->mad_hdr.method & IB_MGMT_METHOD_RESP));
568 static void dequeue_mad(struct ib_mad_list_head *mad_list)
570 struct ib_mad_queue *mad_queue;
571 unsigned long flags;
573 BUG_ON(!mad_list->mad_queue);
574 mad_queue = mad_list->mad_queue;
575 spin_lock_irqsave(&mad_queue->lock, flags);
576 list_del(&mad_list->list);
577 mad_queue->count--;
578 spin_unlock_irqrestore(&mad_queue->lock, flags);
581 static void snoop_send(struct ib_mad_qp_info *qp_info,
582 struct ib_send_wr *send_wr,
583 struct ib_mad_send_wc *mad_send_wc,
584 int mad_snoop_flags)
586 struct ib_mad_snoop_private *mad_snoop_priv;
587 unsigned long flags;
588 int i;
590 spin_lock_irqsave(&qp_info->snoop_lock, flags);
591 for (i = 0; i < qp_info->snoop_table_size; i++) {
592 mad_snoop_priv = qp_info->snoop_table[i];
593 if (!mad_snoop_priv ||
594 !(mad_snoop_priv->mad_snoop_flags & mad_snoop_flags))
595 continue;
597 atomic_inc(&mad_snoop_priv->refcount);
598 spin_unlock_irqrestore(&qp_info->snoop_lock, flags);
599 mad_snoop_priv->agent.snoop_handler(&mad_snoop_priv->agent,
600 send_wr, mad_send_wc);
601 if (atomic_dec_and_test(&mad_snoop_priv->refcount))
602 wake_up(&mad_snoop_priv->wait);
603 spin_lock_irqsave(&qp_info->snoop_lock, flags);
605 spin_unlock_irqrestore(&qp_info->snoop_lock, flags);
608 static void snoop_recv(struct ib_mad_qp_info *qp_info,
609 struct ib_mad_recv_wc *mad_recv_wc,
610 int mad_snoop_flags)
612 struct ib_mad_snoop_private *mad_snoop_priv;
613 unsigned long flags;
614 int i;
616 spin_lock_irqsave(&qp_info->snoop_lock, flags);
617 for (i = 0; i < qp_info->snoop_table_size; i++) {
618 mad_snoop_priv = qp_info->snoop_table[i];
619 if (!mad_snoop_priv ||
620 !(mad_snoop_priv->mad_snoop_flags & mad_snoop_flags))
621 continue;
623 atomic_inc(&mad_snoop_priv->refcount);
624 spin_unlock_irqrestore(&qp_info->snoop_lock, flags);
625 mad_snoop_priv->agent.recv_handler(&mad_snoop_priv->agent,
626 mad_recv_wc);
627 if (atomic_dec_and_test(&mad_snoop_priv->refcount))
628 wake_up(&mad_snoop_priv->wait);
629 spin_lock_irqsave(&qp_info->snoop_lock, flags);
631 spin_unlock_irqrestore(&qp_info->snoop_lock, flags);
634 static void build_smp_wc(u64 wr_id, u16 slid, u16 pkey_index, u8 port_num,
635 struct ib_wc *wc)
637 memset(wc, 0, sizeof *wc);
638 wc->wr_id = wr_id;
639 wc->status = IB_WC_SUCCESS;
640 wc->opcode = IB_WC_RECV;
641 wc->pkey_index = pkey_index;
642 wc->byte_len = sizeof(struct ib_mad) + sizeof(struct ib_grh);
643 wc->src_qp = IB_QP0;
644 wc->qp_num = IB_QP0;
645 wc->slid = slid;
646 wc->sl = 0;
647 wc->dlid_path_bits = 0;
648 wc->port_num = port_num;
652 * Return 0 if SMP is to be sent
653 * Return 1 if SMP was consumed locally (whether or not solicited)
654 * Return < 0 if error
656 static int handle_outgoing_dr_smp(struct ib_mad_agent_private *mad_agent_priv,
657 struct ib_smp *smp,
658 struct ib_send_wr *send_wr)
660 int ret;
661 unsigned long flags;
662 struct ib_mad_local_private *local;
663 struct ib_mad_private *mad_priv;
664 struct ib_mad_port_private *port_priv;
665 struct ib_mad_agent_private *recv_mad_agent = NULL;
666 struct ib_device *device = mad_agent_priv->agent.device;
667 u8 port_num = mad_agent_priv->agent.port_num;
668 struct ib_wc mad_wc;
670 if (!smi_handle_dr_smp_send(smp, device->node_type, port_num)) {
671 ret = -EINVAL;
672 printk(KERN_ERR PFX "Invalid directed route\n");
673 goto out;
675 /* Check to post send on QP or process locally */
676 ret = smi_check_local_dr_smp(smp, device, port_num);
677 if (!ret || !device->process_mad)
678 goto out;
680 local = kmalloc(sizeof *local, GFP_ATOMIC);
681 if (!local) {
682 ret = -ENOMEM;
683 printk(KERN_ERR PFX "No memory for ib_mad_local_private\n");
684 goto out;
686 local->mad_priv = NULL;
687 local->recv_mad_agent = NULL;
688 mad_priv = kmem_cache_alloc(ib_mad_cache, GFP_ATOMIC);
689 if (!mad_priv) {
690 ret = -ENOMEM;
691 printk(KERN_ERR PFX "No memory for local response MAD\n");
692 kfree(local);
693 goto out;
696 build_smp_wc(send_wr->wr_id, be16_to_cpu(smp->dr_slid),
697 send_wr->wr.ud.pkey_index,
698 send_wr->wr.ud.port_num, &mad_wc);
700 /* No GRH for DR SMP */
701 ret = device->process_mad(device, 0, port_num, &mad_wc, NULL,
702 (struct ib_mad *)smp,
703 (struct ib_mad *)&mad_priv->mad);
704 switch (ret)
706 case IB_MAD_RESULT_SUCCESS | IB_MAD_RESULT_REPLY:
707 if (response_mad(&mad_priv->mad.mad) &&
708 mad_agent_priv->agent.recv_handler) {
709 local->mad_priv = mad_priv;
710 local->recv_mad_agent = mad_agent_priv;
712 * Reference MAD agent until receive
713 * side of local completion handled
715 atomic_inc(&mad_agent_priv->refcount);
716 } else
717 kmem_cache_free(ib_mad_cache, mad_priv);
718 break;
719 case IB_MAD_RESULT_SUCCESS | IB_MAD_RESULT_CONSUMED:
720 kmem_cache_free(ib_mad_cache, mad_priv);
721 break;
722 case IB_MAD_RESULT_SUCCESS:
723 /* Treat like an incoming receive MAD */
724 port_priv = ib_get_mad_port(mad_agent_priv->agent.device,
725 mad_agent_priv->agent.port_num);
726 if (port_priv) {
727 mad_priv->mad.mad.mad_hdr.tid =
728 ((struct ib_mad *)smp)->mad_hdr.tid;
729 recv_mad_agent = find_mad_agent(port_priv,
730 &mad_priv->mad.mad);
732 if (!port_priv || !recv_mad_agent) {
733 kmem_cache_free(ib_mad_cache, mad_priv);
734 kfree(local);
735 ret = 0;
736 goto out;
738 local->mad_priv = mad_priv;
739 local->recv_mad_agent = recv_mad_agent;
740 break;
741 default:
742 kmem_cache_free(ib_mad_cache, mad_priv);
743 kfree(local);
744 ret = -EINVAL;
745 goto out;
748 local->send_wr = *send_wr;
749 local->send_wr.sg_list = local->sg_list;
750 memcpy(local->sg_list, send_wr->sg_list,
751 sizeof *send_wr->sg_list * send_wr->num_sge);
752 local->send_wr.next = NULL;
753 local->tid = send_wr->wr.ud.mad_hdr->tid;
754 local->wr_id = send_wr->wr_id;
755 /* Reference MAD agent until send side of local completion handled */
756 atomic_inc(&mad_agent_priv->refcount);
757 /* Queue local completion to local list */
758 spin_lock_irqsave(&mad_agent_priv->lock, flags);
759 list_add_tail(&local->completion_list, &mad_agent_priv->local_list);
760 spin_unlock_irqrestore(&mad_agent_priv->lock, flags);
761 queue_work(mad_agent_priv->qp_info->port_priv->wq,
762 &mad_agent_priv->local_work);
763 ret = 1;
764 out:
765 return ret;
768 static int get_buf_length(int hdr_len, int data_len)
770 int seg_size, pad;
772 seg_size = sizeof(struct ib_mad) - hdr_len;
773 if (data_len && seg_size) {
774 pad = seg_size - data_len % seg_size;
775 if (pad == seg_size)
776 pad = 0;
777 } else
778 pad = seg_size;
779 return hdr_len + data_len + pad;
782 struct ib_mad_send_buf * ib_create_send_mad(struct ib_mad_agent *mad_agent,
783 u32 remote_qpn, u16 pkey_index,
784 struct ib_ah *ah, int rmpp_active,
785 int hdr_len, int data_len,
786 unsigned int __nocast gfp_mask)
788 struct ib_mad_agent_private *mad_agent_priv;
789 struct ib_mad_send_buf *send_buf;
790 int buf_size;
791 void *buf;
793 mad_agent_priv = container_of(mad_agent,
794 struct ib_mad_agent_private, agent);
795 buf_size = get_buf_length(hdr_len, data_len);
797 if ((!mad_agent->rmpp_version &&
798 (rmpp_active || buf_size > sizeof(struct ib_mad))) ||
799 (!rmpp_active && buf_size > sizeof(struct ib_mad)))
800 return ERR_PTR(-EINVAL);
802 buf = kmalloc(sizeof *send_buf + buf_size, gfp_mask);
803 if (!buf)
804 return ERR_PTR(-ENOMEM);
805 memset(buf, 0, sizeof *send_buf + buf_size);
807 send_buf = buf + buf_size;
808 send_buf->mad = buf;
810 send_buf->sge.addr = dma_map_single(mad_agent->device->dma_device,
811 buf, buf_size, DMA_TO_DEVICE);
812 pci_unmap_addr_set(send_buf, mapping, send_buf->sge.addr);
813 send_buf->sge.length = buf_size;
814 send_buf->sge.lkey = mad_agent->mr->lkey;
816 send_buf->send_wr.wr_id = (unsigned long) send_buf;
817 send_buf->send_wr.sg_list = &send_buf->sge;
818 send_buf->send_wr.num_sge = 1;
819 send_buf->send_wr.opcode = IB_WR_SEND;
820 send_buf->send_wr.send_flags = IB_SEND_SIGNALED;
821 send_buf->send_wr.wr.ud.ah = ah;
822 send_buf->send_wr.wr.ud.mad_hdr = &send_buf->mad->mad_hdr;
823 send_buf->send_wr.wr.ud.remote_qpn = remote_qpn;
824 send_buf->send_wr.wr.ud.remote_qkey = IB_QP_SET_QKEY;
825 send_buf->send_wr.wr.ud.pkey_index = pkey_index;
827 if (rmpp_active) {
828 struct ib_rmpp_mad *rmpp_mad;
829 rmpp_mad = (struct ib_rmpp_mad *)send_buf->mad;
830 rmpp_mad->rmpp_hdr.paylen_newwin = cpu_to_be32(hdr_len -
831 offsetof(struct ib_rmpp_mad, data) + data_len);
832 rmpp_mad->rmpp_hdr.rmpp_version = mad_agent->rmpp_version;
833 rmpp_mad->rmpp_hdr.rmpp_type = IB_MGMT_RMPP_TYPE_DATA;
834 ib_set_rmpp_flags(&rmpp_mad->rmpp_hdr,
835 IB_MGMT_RMPP_FLAG_ACTIVE);
838 send_buf->mad_agent = mad_agent;
839 atomic_inc(&mad_agent_priv->refcount);
840 return send_buf;
842 EXPORT_SYMBOL(ib_create_send_mad);
844 void ib_free_send_mad(struct ib_mad_send_buf *send_buf)
846 struct ib_mad_agent_private *mad_agent_priv;
848 mad_agent_priv = container_of(send_buf->mad_agent,
849 struct ib_mad_agent_private, agent);
851 dma_unmap_single(send_buf->mad_agent->device->dma_device,
852 pci_unmap_addr(send_buf, mapping),
853 send_buf->sge.length, DMA_TO_DEVICE);
854 kfree(send_buf->mad);
856 if (atomic_dec_and_test(&mad_agent_priv->refcount))
857 wake_up(&mad_agent_priv->wait);
859 EXPORT_SYMBOL(ib_free_send_mad);
861 int ib_send_mad(struct ib_mad_send_wr_private *mad_send_wr)
863 struct ib_mad_qp_info *qp_info;
864 struct ib_send_wr *bad_send_wr;
865 struct list_head *list;
866 unsigned long flags;
867 int ret;
869 /* Set WR ID to find mad_send_wr upon completion */
870 qp_info = mad_send_wr->mad_agent_priv->qp_info;
871 mad_send_wr->send_wr.wr_id = (unsigned long)&mad_send_wr->mad_list;
872 mad_send_wr->mad_list.mad_queue = &qp_info->send_queue;
874 spin_lock_irqsave(&qp_info->send_queue.lock, flags);
875 if (qp_info->send_queue.count < qp_info->send_queue.max_active) {
876 ret = ib_post_send(mad_send_wr->mad_agent_priv->agent.qp,
877 &mad_send_wr->send_wr, &bad_send_wr);
878 list = &qp_info->send_queue.list;
879 } else {
880 ret = 0;
881 list = &qp_info->overflow_list;
884 if (!ret) {
885 qp_info->send_queue.count++;
886 list_add_tail(&mad_send_wr->mad_list.list, list);
888 spin_unlock_irqrestore(&qp_info->send_queue.lock, flags);
889 return ret;
893 * ib_post_send_mad - Posts MAD(s) to the send queue of the QP associated
894 * with the registered client
896 int ib_post_send_mad(struct ib_mad_agent *mad_agent,
897 struct ib_send_wr *send_wr,
898 struct ib_send_wr **bad_send_wr)
900 int ret = -EINVAL;
901 struct ib_mad_agent_private *mad_agent_priv;
903 /* Validate supplied parameters */
904 if (!bad_send_wr)
905 goto error1;
907 if (!mad_agent || !send_wr)
908 goto error2;
910 if (!mad_agent->send_handler)
911 goto error2;
913 mad_agent_priv = container_of(mad_agent,
914 struct ib_mad_agent_private,
915 agent);
917 /* Walk list of send WRs and post each on send list */
918 while (send_wr) {
919 unsigned long flags;
920 struct ib_send_wr *next_send_wr;
921 struct ib_mad_send_wr_private *mad_send_wr;
922 struct ib_smp *smp;
924 /* Validate more parameters */
925 if (send_wr->num_sge > IB_MAD_SEND_REQ_MAX_SG)
926 goto error2;
928 if (send_wr->wr.ud.timeout_ms && !mad_agent->recv_handler)
929 goto error2;
931 if (!send_wr->wr.ud.mad_hdr) {
932 printk(KERN_ERR PFX "MAD header must be supplied "
933 "in WR %p\n", send_wr);
934 goto error2;
938 * Save pointer to next work request to post in case the
939 * current one completes, and the user modifies the work
940 * request associated with the completion
942 next_send_wr = (struct ib_send_wr *)send_wr->next;
944 smp = (struct ib_smp *)send_wr->wr.ud.mad_hdr;
945 if (smp->mgmt_class == IB_MGMT_CLASS_SUBN_DIRECTED_ROUTE) {
946 ret = handle_outgoing_dr_smp(mad_agent_priv, smp,
947 send_wr);
948 if (ret < 0) /* error */
949 goto error2;
950 else if (ret == 1) /* locally consumed */
951 goto next;
954 /* Allocate MAD send WR tracking structure */
955 mad_send_wr = kmalloc(sizeof *mad_send_wr, GFP_ATOMIC);
956 if (!mad_send_wr) {
957 printk(KERN_ERR PFX "No memory for "
958 "ib_mad_send_wr_private\n");
959 ret = -ENOMEM;
960 goto error2;
962 memset(mad_send_wr, 0, sizeof *mad_send_wr);
964 mad_send_wr->send_wr = *send_wr;
965 mad_send_wr->send_wr.sg_list = mad_send_wr->sg_list;
966 memcpy(mad_send_wr->sg_list, send_wr->sg_list,
967 sizeof *send_wr->sg_list * send_wr->num_sge);
968 mad_send_wr->wr_id = send_wr->wr_id;
969 mad_send_wr->tid = send_wr->wr.ud.mad_hdr->tid;
970 mad_send_wr->mad_agent_priv = mad_agent_priv;
971 /* Timeout will be updated after send completes */
972 mad_send_wr->timeout = msecs_to_jiffies(send_wr->wr.
973 ud.timeout_ms);
974 mad_send_wr->retries = mad_send_wr->send_wr.wr.ud.retries;
975 /* One reference for each work request to QP + response */
976 mad_send_wr->refcount = 1 + (mad_send_wr->timeout > 0);
977 mad_send_wr->status = IB_WC_SUCCESS;
979 /* Reference MAD agent until send completes */
980 atomic_inc(&mad_agent_priv->refcount);
981 spin_lock_irqsave(&mad_agent_priv->lock, flags);
982 list_add_tail(&mad_send_wr->agent_list,
983 &mad_agent_priv->send_list);
984 spin_unlock_irqrestore(&mad_agent_priv->lock, flags);
986 if (mad_agent_priv->agent.rmpp_version) {
987 ret = ib_send_rmpp_mad(mad_send_wr);
988 if (ret >= 0 && ret != IB_RMPP_RESULT_CONSUMED)
989 ret = ib_send_mad(mad_send_wr);
990 } else
991 ret = ib_send_mad(mad_send_wr);
992 if (ret < 0) {
993 /* Fail send request */
994 spin_lock_irqsave(&mad_agent_priv->lock, flags);
995 list_del(&mad_send_wr->agent_list);
996 spin_unlock_irqrestore(&mad_agent_priv->lock, flags);
997 atomic_dec(&mad_agent_priv->refcount);
998 goto error2;
1000 next:
1001 send_wr = next_send_wr;
1003 return 0;
1005 error2:
1006 *bad_send_wr = send_wr;
1007 error1:
1008 return ret;
1010 EXPORT_SYMBOL(ib_post_send_mad);
1013 * ib_free_recv_mad - Returns data buffers used to receive
1014 * a MAD to the access layer
1016 void ib_free_recv_mad(struct ib_mad_recv_wc *mad_recv_wc)
1018 struct ib_mad_recv_buf *mad_recv_buf, *temp_recv_buf;
1019 struct ib_mad_private_header *mad_priv_hdr;
1020 struct ib_mad_private *priv;
1021 struct list_head free_list;
1023 INIT_LIST_HEAD(&free_list);
1024 list_splice_init(&mad_recv_wc->rmpp_list, &free_list);
1026 list_for_each_entry_safe(mad_recv_buf, temp_recv_buf,
1027 &free_list, list) {
1028 mad_recv_wc = container_of(mad_recv_buf, struct ib_mad_recv_wc,
1029 recv_buf);
1030 mad_priv_hdr = container_of(mad_recv_wc,
1031 struct ib_mad_private_header,
1032 recv_wc);
1033 priv = container_of(mad_priv_hdr, struct ib_mad_private,
1034 header);
1035 kmem_cache_free(ib_mad_cache, priv);
1038 EXPORT_SYMBOL(ib_free_recv_mad);
1040 struct ib_mad_agent *ib_redirect_mad_qp(struct ib_qp *qp,
1041 u8 rmpp_version,
1042 ib_mad_send_handler send_handler,
1043 ib_mad_recv_handler recv_handler,
1044 void *context)
1046 return ERR_PTR(-EINVAL); /* XXX: for now */
1048 EXPORT_SYMBOL(ib_redirect_mad_qp);
1050 int ib_process_mad_wc(struct ib_mad_agent *mad_agent,
1051 struct ib_wc *wc)
1053 printk(KERN_ERR PFX "ib_process_mad_wc() not implemented yet\n");
1054 return 0;
1056 EXPORT_SYMBOL(ib_process_mad_wc);
1058 static int method_in_use(struct ib_mad_mgmt_method_table **method,
1059 struct ib_mad_reg_req *mad_reg_req)
1061 int i;
1063 for (i = find_first_bit(mad_reg_req->method_mask, IB_MGMT_MAX_METHODS);
1064 i < IB_MGMT_MAX_METHODS;
1065 i = find_next_bit(mad_reg_req->method_mask, IB_MGMT_MAX_METHODS,
1066 1+i)) {
1067 if ((*method)->agent[i]) {
1068 printk(KERN_ERR PFX "Method %d already in use\n", i);
1069 return -EINVAL;
1072 return 0;
1075 static int allocate_method_table(struct ib_mad_mgmt_method_table **method)
1077 /* Allocate management method table */
1078 *method = kmalloc(sizeof **method, GFP_ATOMIC);
1079 if (!*method) {
1080 printk(KERN_ERR PFX "No memory for "
1081 "ib_mad_mgmt_method_table\n");
1082 return -ENOMEM;
1084 /* Clear management method table */
1085 memset(*method, 0, sizeof **method);
1087 return 0;
1091 * Check to see if there are any methods still in use
1093 static int check_method_table(struct ib_mad_mgmt_method_table *method)
1095 int i;
1097 for (i = 0; i < IB_MGMT_MAX_METHODS; i++)
1098 if (method->agent[i])
1099 return 1;
1100 return 0;
1104 * Check to see if there are any method tables for this class still in use
1106 static int check_class_table(struct ib_mad_mgmt_class_table *class)
1108 int i;
1110 for (i = 0; i < MAX_MGMT_CLASS; i++)
1111 if (class->method_table[i])
1112 return 1;
1113 return 0;
1116 static int check_vendor_class(struct ib_mad_mgmt_vendor_class *vendor_class)
1118 int i;
1120 for (i = 0; i < MAX_MGMT_OUI; i++)
1121 if (vendor_class->method_table[i])
1122 return 1;
1123 return 0;
1126 static int find_vendor_oui(struct ib_mad_mgmt_vendor_class *vendor_class,
1127 char *oui)
1129 int i;
1131 for (i = 0; i < MAX_MGMT_OUI; i++)
1132 /* Is there matching OUI for this vendor class ? */
1133 if (!memcmp(vendor_class->oui[i], oui, 3))
1134 return i;
1136 return -1;
1139 static int check_vendor_table(struct ib_mad_mgmt_vendor_class_table *vendor)
1141 int i;
1143 for (i = 0; i < MAX_MGMT_VENDOR_RANGE2; i++)
1144 if (vendor->vendor_class[i])
1145 return 1;
1147 return 0;
1150 static void remove_methods_mad_agent(struct ib_mad_mgmt_method_table *method,
1151 struct ib_mad_agent_private *agent)
1153 int i;
1155 /* Remove any methods for this mad agent */
1156 for (i = 0; i < IB_MGMT_MAX_METHODS; i++) {
1157 if (method->agent[i] == agent) {
1158 method->agent[i] = NULL;
1163 static int add_nonoui_reg_req(struct ib_mad_reg_req *mad_reg_req,
1164 struct ib_mad_agent_private *agent_priv,
1165 u8 mgmt_class)
1167 struct ib_mad_port_private *port_priv;
1168 struct ib_mad_mgmt_class_table **class;
1169 struct ib_mad_mgmt_method_table **method;
1170 int i, ret;
1172 port_priv = agent_priv->qp_info->port_priv;
1173 class = &port_priv->version[mad_reg_req->mgmt_class_version].class;
1174 if (!*class) {
1175 /* Allocate management class table for "new" class version */
1176 *class = kmalloc(sizeof **class, GFP_ATOMIC);
1177 if (!*class) {
1178 printk(KERN_ERR PFX "No memory for "
1179 "ib_mad_mgmt_class_table\n");
1180 ret = -ENOMEM;
1181 goto error1;
1183 /* Clear management class table */
1184 memset(*class, 0, sizeof(**class));
1185 /* Allocate method table for this management class */
1186 method = &(*class)->method_table[mgmt_class];
1187 if ((ret = allocate_method_table(method)))
1188 goto error2;
1189 } else {
1190 method = &(*class)->method_table[mgmt_class];
1191 if (!*method) {
1192 /* Allocate method table for this management class */
1193 if ((ret = allocate_method_table(method)))
1194 goto error1;
1198 /* Now, make sure methods are not already in use */
1199 if (method_in_use(method, mad_reg_req))
1200 goto error3;
1202 /* Finally, add in methods being registered */
1203 for (i = find_first_bit(mad_reg_req->method_mask,
1204 IB_MGMT_MAX_METHODS);
1205 i < IB_MGMT_MAX_METHODS;
1206 i = find_next_bit(mad_reg_req->method_mask, IB_MGMT_MAX_METHODS,
1207 1+i)) {
1208 (*method)->agent[i] = agent_priv;
1210 return 0;
1212 error3:
1213 /* Remove any methods for this mad agent */
1214 remove_methods_mad_agent(*method, agent_priv);
1215 /* Now, check to see if there are any methods in use */
1216 if (!check_method_table(*method)) {
1217 /* If not, release management method table */
1218 kfree(*method);
1219 *method = NULL;
1221 ret = -EINVAL;
1222 goto error1;
1223 error2:
1224 kfree(*class);
1225 *class = NULL;
1226 error1:
1227 return ret;
1230 static int add_oui_reg_req(struct ib_mad_reg_req *mad_reg_req,
1231 struct ib_mad_agent_private *agent_priv)
1233 struct ib_mad_port_private *port_priv;
1234 struct ib_mad_mgmt_vendor_class_table **vendor_table;
1235 struct ib_mad_mgmt_vendor_class_table *vendor = NULL;
1236 struct ib_mad_mgmt_vendor_class *vendor_class = NULL;
1237 struct ib_mad_mgmt_method_table **method;
1238 int i, ret = -ENOMEM;
1239 u8 vclass;
1241 /* "New" vendor (with OUI) class */
1242 vclass = vendor_class_index(mad_reg_req->mgmt_class);
1243 port_priv = agent_priv->qp_info->port_priv;
1244 vendor_table = &port_priv->version[
1245 mad_reg_req->mgmt_class_version].vendor;
1246 if (!*vendor_table) {
1247 /* Allocate mgmt vendor class table for "new" class version */
1248 vendor = kmalloc(sizeof *vendor, GFP_ATOMIC);
1249 if (!vendor) {
1250 printk(KERN_ERR PFX "No memory for "
1251 "ib_mad_mgmt_vendor_class_table\n");
1252 goto error1;
1254 /* Clear management vendor class table */
1255 memset(vendor, 0, sizeof(*vendor));
1256 *vendor_table = vendor;
1258 if (!(*vendor_table)->vendor_class[vclass]) {
1259 /* Allocate table for this management vendor class */
1260 vendor_class = kmalloc(sizeof *vendor_class, GFP_ATOMIC);
1261 if (!vendor_class) {
1262 printk(KERN_ERR PFX "No memory for "
1263 "ib_mad_mgmt_vendor_class\n");
1264 goto error2;
1266 memset(vendor_class, 0, sizeof(*vendor_class));
1267 (*vendor_table)->vendor_class[vclass] = vendor_class;
1269 for (i = 0; i < MAX_MGMT_OUI; i++) {
1270 /* Is there matching OUI for this vendor class ? */
1271 if (!memcmp((*vendor_table)->vendor_class[vclass]->oui[i],
1272 mad_reg_req->oui, 3)) {
1273 method = &(*vendor_table)->vendor_class[
1274 vclass]->method_table[i];
1275 BUG_ON(!*method);
1276 goto check_in_use;
1279 for (i = 0; i < MAX_MGMT_OUI; i++) {
1280 /* OUI slot available ? */
1281 if (!is_vendor_oui((*vendor_table)->vendor_class[
1282 vclass]->oui[i])) {
1283 method = &(*vendor_table)->vendor_class[
1284 vclass]->method_table[i];
1285 BUG_ON(*method);
1286 /* Allocate method table for this OUI */
1287 if ((ret = allocate_method_table(method)))
1288 goto error3;
1289 memcpy((*vendor_table)->vendor_class[vclass]->oui[i],
1290 mad_reg_req->oui, 3);
1291 goto check_in_use;
1294 printk(KERN_ERR PFX "All OUI slots in use\n");
1295 goto error3;
1297 check_in_use:
1298 /* Now, make sure methods are not already in use */
1299 if (method_in_use(method, mad_reg_req))
1300 goto error4;
1302 /* Finally, add in methods being registered */
1303 for (i = find_first_bit(mad_reg_req->method_mask,
1304 IB_MGMT_MAX_METHODS);
1305 i < IB_MGMT_MAX_METHODS;
1306 i = find_next_bit(mad_reg_req->method_mask, IB_MGMT_MAX_METHODS,
1307 1+i)) {
1308 (*method)->agent[i] = agent_priv;
1310 return 0;
1312 error4:
1313 /* Remove any methods for this mad agent */
1314 remove_methods_mad_agent(*method, agent_priv);
1315 /* Now, check to see if there are any methods in use */
1316 if (!check_method_table(*method)) {
1317 /* If not, release management method table */
1318 kfree(*method);
1319 *method = NULL;
1321 ret = -EINVAL;
1322 error3:
1323 if (vendor_class) {
1324 (*vendor_table)->vendor_class[vclass] = NULL;
1325 kfree(vendor_class);
1327 error2:
1328 if (vendor) {
1329 *vendor_table = NULL;
1330 kfree(vendor);
1332 error1:
1333 return ret;
1336 static void remove_mad_reg_req(struct ib_mad_agent_private *agent_priv)
1338 struct ib_mad_port_private *port_priv;
1339 struct ib_mad_mgmt_class_table *class;
1340 struct ib_mad_mgmt_method_table *method;
1341 struct ib_mad_mgmt_vendor_class_table *vendor;
1342 struct ib_mad_mgmt_vendor_class *vendor_class;
1343 int index;
1344 u8 mgmt_class;
1347 * Was MAD registration request supplied
1348 * with original registration ?
1350 if (!agent_priv->reg_req) {
1351 goto out;
1354 port_priv = agent_priv->qp_info->port_priv;
1355 mgmt_class = convert_mgmt_class(agent_priv->reg_req->mgmt_class);
1356 class = port_priv->version[
1357 agent_priv->reg_req->mgmt_class_version].class;
1358 if (!class)
1359 goto vendor_check;
1361 method = class->method_table[mgmt_class];
1362 if (method) {
1363 /* Remove any methods for this mad agent */
1364 remove_methods_mad_agent(method, agent_priv);
1365 /* Now, check to see if there are any methods still in use */
1366 if (!check_method_table(method)) {
1367 /* If not, release management method table */
1368 kfree(method);
1369 class->method_table[mgmt_class] = NULL;
1370 /* Any management classes left ? */
1371 if (!check_class_table(class)) {
1372 /* If not, release management class table */
1373 kfree(class);
1374 port_priv->version[
1375 agent_priv->reg_req->
1376 mgmt_class_version].class = NULL;
1381 vendor_check:
1382 if (!is_vendor_class(mgmt_class))
1383 goto out;
1385 /* normalize mgmt_class to vendor range 2 */
1386 mgmt_class = vendor_class_index(agent_priv->reg_req->mgmt_class);
1387 vendor = port_priv->version[
1388 agent_priv->reg_req->mgmt_class_version].vendor;
1390 if (!vendor)
1391 goto out;
1393 vendor_class = vendor->vendor_class[mgmt_class];
1394 if (vendor_class) {
1395 index = find_vendor_oui(vendor_class, agent_priv->reg_req->oui);
1396 if (index < 0)
1397 goto out;
1398 method = vendor_class->method_table[index];
1399 if (method) {
1400 /* Remove any methods for this mad agent */
1401 remove_methods_mad_agent(method, agent_priv);
1403 * Now, check to see if there are
1404 * any methods still in use
1406 if (!check_method_table(method)) {
1407 /* If not, release management method table */
1408 kfree(method);
1409 vendor_class->method_table[index] = NULL;
1410 memset(vendor_class->oui[index], 0, 3);
1411 /* Any OUIs left ? */
1412 if (!check_vendor_class(vendor_class)) {
1413 /* If not, release vendor class table */
1414 kfree(vendor_class);
1415 vendor->vendor_class[mgmt_class] = NULL;
1416 /* Any other vendor classes left ? */
1417 if (!check_vendor_table(vendor)) {
1418 kfree(vendor);
1419 port_priv->version[
1420 agent_priv->reg_req->
1421 mgmt_class_version].
1422 vendor = NULL;
1429 out:
1430 return;
1433 static struct ib_mad_agent_private *
1434 find_mad_agent(struct ib_mad_port_private *port_priv,
1435 struct ib_mad *mad)
1437 struct ib_mad_agent_private *mad_agent = NULL;
1438 unsigned long flags;
1440 spin_lock_irqsave(&port_priv->reg_lock, flags);
1441 if (response_mad(mad)) {
1442 u32 hi_tid;
1443 struct ib_mad_agent_private *entry;
1446 * Routing is based on high 32 bits of transaction ID
1447 * of MAD.
1449 hi_tid = be64_to_cpu(mad->mad_hdr.tid) >> 32;
1450 list_for_each_entry(entry, &port_priv->agent_list,
1451 agent_list) {
1452 if (entry->agent.hi_tid == hi_tid) {
1453 mad_agent = entry;
1454 break;
1457 } else {
1458 struct ib_mad_mgmt_class_table *class;
1459 struct ib_mad_mgmt_method_table *method;
1460 struct ib_mad_mgmt_vendor_class_table *vendor;
1461 struct ib_mad_mgmt_vendor_class *vendor_class;
1462 struct ib_vendor_mad *vendor_mad;
1463 int index;
1466 * Routing is based on version, class, and method
1467 * For "newer" vendor MADs, also based on OUI
1469 if (mad->mad_hdr.class_version >= MAX_MGMT_VERSION)
1470 goto out;
1471 if (!is_vendor_class(mad->mad_hdr.mgmt_class)) {
1472 class = port_priv->version[
1473 mad->mad_hdr.class_version].class;
1474 if (!class)
1475 goto out;
1476 method = class->method_table[convert_mgmt_class(
1477 mad->mad_hdr.mgmt_class)];
1478 if (method)
1479 mad_agent = method->agent[mad->mad_hdr.method &
1480 ~IB_MGMT_METHOD_RESP];
1481 } else {
1482 vendor = port_priv->version[
1483 mad->mad_hdr.class_version].vendor;
1484 if (!vendor)
1485 goto out;
1486 vendor_class = vendor->vendor_class[vendor_class_index(
1487 mad->mad_hdr.mgmt_class)];
1488 if (!vendor_class)
1489 goto out;
1490 /* Find matching OUI */
1491 vendor_mad = (struct ib_vendor_mad *)mad;
1492 index = find_vendor_oui(vendor_class, vendor_mad->oui);
1493 if (index == -1)
1494 goto out;
1495 method = vendor_class->method_table[index];
1496 if (method) {
1497 mad_agent = method->agent[mad->mad_hdr.method &
1498 ~IB_MGMT_METHOD_RESP];
1503 if (mad_agent) {
1504 if (mad_agent->agent.recv_handler)
1505 atomic_inc(&mad_agent->refcount);
1506 else {
1507 printk(KERN_NOTICE PFX "No receive handler for client "
1508 "%p on port %d\n",
1509 &mad_agent->agent, port_priv->port_num);
1510 mad_agent = NULL;
1513 out:
1514 spin_unlock_irqrestore(&port_priv->reg_lock, flags);
1516 return mad_agent;
1519 static int validate_mad(struct ib_mad *mad, u32 qp_num)
1521 int valid = 0;
1523 /* Make sure MAD base version is understood */
1524 if (mad->mad_hdr.base_version != IB_MGMT_BASE_VERSION) {
1525 printk(KERN_ERR PFX "MAD received with unsupported base "
1526 "version %d\n", mad->mad_hdr.base_version);
1527 goto out;
1530 /* Filter SMI packets sent to other than QP0 */
1531 if ((mad->mad_hdr.mgmt_class == IB_MGMT_CLASS_SUBN_LID_ROUTED) ||
1532 (mad->mad_hdr.mgmt_class == IB_MGMT_CLASS_SUBN_DIRECTED_ROUTE)) {
1533 if (qp_num == 0)
1534 valid = 1;
1535 } else {
1536 /* Filter GSI packets sent to QP0 */
1537 if (qp_num != 0)
1538 valid = 1;
1541 out:
1542 return valid;
1545 static int is_data_mad(struct ib_mad_agent_private *mad_agent_priv,
1546 struct ib_mad_hdr *mad_hdr)
1548 struct ib_rmpp_mad *rmpp_mad;
1550 rmpp_mad = (struct ib_rmpp_mad *)mad_hdr;
1551 return !mad_agent_priv->agent.rmpp_version ||
1552 !(ib_get_rmpp_flags(&rmpp_mad->rmpp_hdr) &
1553 IB_MGMT_RMPP_FLAG_ACTIVE) ||
1554 (rmpp_mad->rmpp_hdr.rmpp_type == IB_MGMT_RMPP_TYPE_DATA);
1557 struct ib_mad_send_wr_private*
1558 ib_find_send_mad(struct ib_mad_agent_private *mad_agent_priv, __be64 tid)
1560 struct ib_mad_send_wr_private *mad_send_wr;
1562 list_for_each_entry(mad_send_wr, &mad_agent_priv->wait_list,
1563 agent_list) {
1564 if (mad_send_wr->tid == tid)
1565 return mad_send_wr;
1569 * It's possible to receive the response before we've
1570 * been notified that the send has completed
1572 list_for_each_entry(mad_send_wr, &mad_agent_priv->send_list,
1573 agent_list) {
1574 if (is_data_mad(mad_agent_priv,
1575 mad_send_wr->send_wr.wr.ud.mad_hdr) &&
1576 mad_send_wr->tid == tid && mad_send_wr->timeout) {
1577 /* Verify request has not been canceled */
1578 return (mad_send_wr->status == IB_WC_SUCCESS) ?
1579 mad_send_wr : NULL;
1582 return NULL;
1585 void ib_mark_mad_done(struct ib_mad_send_wr_private *mad_send_wr)
1587 mad_send_wr->timeout = 0;
1588 if (mad_send_wr->refcount == 1) {
1589 list_del(&mad_send_wr->agent_list);
1590 list_add_tail(&mad_send_wr->agent_list,
1591 &mad_send_wr->mad_agent_priv->done_list);
1595 static void ib_mad_complete_recv(struct ib_mad_agent_private *mad_agent_priv,
1596 struct ib_mad_recv_wc *mad_recv_wc)
1598 struct ib_mad_send_wr_private *mad_send_wr;
1599 struct ib_mad_send_wc mad_send_wc;
1600 unsigned long flags;
1601 __be64 tid;
1603 INIT_LIST_HEAD(&mad_recv_wc->rmpp_list);
1604 list_add(&mad_recv_wc->recv_buf.list, &mad_recv_wc->rmpp_list);
1605 if (mad_agent_priv->agent.rmpp_version) {
1606 mad_recv_wc = ib_process_rmpp_recv_wc(mad_agent_priv,
1607 mad_recv_wc);
1608 if (!mad_recv_wc) {
1609 if (atomic_dec_and_test(&mad_agent_priv->refcount))
1610 wake_up(&mad_agent_priv->wait);
1611 return;
1615 /* Complete corresponding request */
1616 if (response_mad(mad_recv_wc->recv_buf.mad)) {
1617 tid = mad_recv_wc->recv_buf.mad->mad_hdr.tid;
1618 spin_lock_irqsave(&mad_agent_priv->lock, flags);
1619 mad_send_wr = ib_find_send_mad(mad_agent_priv, tid);
1620 if (!mad_send_wr) {
1621 spin_unlock_irqrestore(&mad_agent_priv->lock, flags);
1622 ib_free_recv_mad(mad_recv_wc);
1623 if (atomic_dec_and_test(&mad_agent_priv->refcount))
1624 wake_up(&mad_agent_priv->wait);
1625 return;
1627 ib_mark_mad_done(mad_send_wr);
1628 spin_unlock_irqrestore(&mad_agent_priv->lock, flags);
1630 /* Defined behavior is to complete response before request */
1631 mad_recv_wc->wc->wr_id = mad_send_wr->wr_id;
1632 mad_agent_priv->agent.recv_handler(&mad_agent_priv->agent,
1633 mad_recv_wc);
1634 atomic_dec(&mad_agent_priv->refcount);
1636 mad_send_wc.status = IB_WC_SUCCESS;
1637 mad_send_wc.vendor_err = 0;
1638 mad_send_wc.wr_id = mad_send_wr->wr_id;
1639 ib_mad_complete_send_wr(mad_send_wr, &mad_send_wc);
1640 } else {
1641 mad_agent_priv->agent.recv_handler(&mad_agent_priv->agent,
1642 mad_recv_wc);
1643 if (atomic_dec_and_test(&mad_agent_priv->refcount))
1644 wake_up(&mad_agent_priv->wait);
1648 static void ib_mad_recv_done_handler(struct ib_mad_port_private *port_priv,
1649 struct ib_wc *wc)
1651 struct ib_mad_qp_info *qp_info;
1652 struct ib_mad_private_header *mad_priv_hdr;
1653 struct ib_mad_private *recv, *response;
1654 struct ib_mad_list_head *mad_list;
1655 struct ib_mad_agent_private *mad_agent;
1657 response = kmem_cache_alloc(ib_mad_cache, GFP_KERNEL);
1658 if (!response)
1659 printk(KERN_ERR PFX "ib_mad_recv_done_handler no memory "
1660 "for response buffer\n");
1662 mad_list = (struct ib_mad_list_head *)(unsigned long)wc->wr_id;
1663 qp_info = mad_list->mad_queue->qp_info;
1664 dequeue_mad(mad_list);
1666 mad_priv_hdr = container_of(mad_list, struct ib_mad_private_header,
1667 mad_list);
1668 recv = container_of(mad_priv_hdr, struct ib_mad_private, header);
1669 dma_unmap_single(port_priv->device->dma_device,
1670 pci_unmap_addr(&recv->header, mapping),
1671 sizeof(struct ib_mad_private) -
1672 sizeof(struct ib_mad_private_header),
1673 DMA_FROM_DEVICE);
1675 /* Setup MAD receive work completion from "normal" work completion */
1676 recv->header.wc = *wc;
1677 recv->header.recv_wc.wc = &recv->header.wc;
1678 recv->header.recv_wc.mad_len = sizeof(struct ib_mad);
1679 recv->header.recv_wc.recv_buf.mad = &recv->mad.mad;
1680 recv->header.recv_wc.recv_buf.grh = &recv->grh;
1682 if (atomic_read(&qp_info->snoop_count))
1683 snoop_recv(qp_info, &recv->header.recv_wc, IB_MAD_SNOOP_RECVS);
1685 /* Validate MAD */
1686 if (!validate_mad(&recv->mad.mad, qp_info->qp->qp_num))
1687 goto out;
1689 if (recv->mad.mad.mad_hdr.mgmt_class ==
1690 IB_MGMT_CLASS_SUBN_DIRECTED_ROUTE) {
1691 if (!smi_handle_dr_smp_recv(&recv->mad.smp,
1692 port_priv->device->node_type,
1693 port_priv->port_num,
1694 port_priv->device->phys_port_cnt))
1695 goto out;
1696 if (!smi_check_forward_dr_smp(&recv->mad.smp))
1697 goto local;
1698 if (!smi_handle_dr_smp_send(&recv->mad.smp,
1699 port_priv->device->node_type,
1700 port_priv->port_num))
1701 goto out;
1702 if (!smi_check_local_dr_smp(&recv->mad.smp,
1703 port_priv->device,
1704 port_priv->port_num))
1705 goto out;
1708 local:
1709 /* Give driver "right of first refusal" on incoming MAD */
1710 if (port_priv->device->process_mad) {
1711 int ret;
1713 if (!response) {
1714 printk(KERN_ERR PFX "No memory for response MAD\n");
1716 * Is it better to assume that
1717 * it wouldn't be processed ?
1719 goto out;
1722 ret = port_priv->device->process_mad(port_priv->device, 0,
1723 port_priv->port_num,
1724 wc, &recv->grh,
1725 &recv->mad.mad,
1726 &response->mad.mad);
1727 if (ret & IB_MAD_RESULT_SUCCESS) {
1728 if (ret & IB_MAD_RESULT_CONSUMED)
1729 goto out;
1730 if (ret & IB_MAD_RESULT_REPLY) {
1731 /* Send response */
1732 if (!agent_send(response, &recv->grh, wc,
1733 port_priv->device,
1734 port_priv->port_num))
1735 response = NULL;
1736 goto out;
1741 mad_agent = find_mad_agent(port_priv, &recv->mad.mad);
1742 if (mad_agent) {
1743 ib_mad_complete_recv(mad_agent, &recv->header.recv_wc);
1745 * recv is freed up in error cases in ib_mad_complete_recv
1746 * or via recv_handler in ib_mad_complete_recv()
1748 recv = NULL;
1751 out:
1752 /* Post another receive request for this QP */
1753 if (response) {
1754 ib_mad_post_receive_mads(qp_info, response);
1755 if (recv)
1756 kmem_cache_free(ib_mad_cache, recv);
1757 } else
1758 ib_mad_post_receive_mads(qp_info, recv);
1761 static void adjust_timeout(struct ib_mad_agent_private *mad_agent_priv)
1763 struct ib_mad_send_wr_private *mad_send_wr;
1764 unsigned long delay;
1766 if (list_empty(&mad_agent_priv->wait_list)) {
1767 cancel_delayed_work(&mad_agent_priv->timed_work);
1768 } else {
1769 mad_send_wr = list_entry(mad_agent_priv->wait_list.next,
1770 struct ib_mad_send_wr_private,
1771 agent_list);
1773 if (time_after(mad_agent_priv->timeout,
1774 mad_send_wr->timeout)) {
1775 mad_agent_priv->timeout = mad_send_wr->timeout;
1776 cancel_delayed_work(&mad_agent_priv->timed_work);
1777 delay = mad_send_wr->timeout - jiffies;
1778 if ((long)delay <= 0)
1779 delay = 1;
1780 queue_delayed_work(mad_agent_priv->qp_info->
1781 port_priv->wq,
1782 &mad_agent_priv->timed_work, delay);
1787 static void wait_for_response(struct ib_mad_send_wr_private *mad_send_wr)
1789 struct ib_mad_agent_private *mad_agent_priv;
1790 struct ib_mad_send_wr_private *temp_mad_send_wr;
1791 struct list_head *list_item;
1792 unsigned long delay;
1794 mad_agent_priv = mad_send_wr->mad_agent_priv;
1795 list_del(&mad_send_wr->agent_list);
1797 delay = mad_send_wr->timeout;
1798 mad_send_wr->timeout += jiffies;
1800 if (delay) {
1801 list_for_each_prev(list_item, &mad_agent_priv->wait_list) {
1802 temp_mad_send_wr = list_entry(list_item,
1803 struct ib_mad_send_wr_private,
1804 agent_list);
1805 if (time_after(mad_send_wr->timeout,
1806 temp_mad_send_wr->timeout))
1807 break;
1810 else
1811 list_item = &mad_agent_priv->wait_list;
1812 list_add(&mad_send_wr->agent_list, list_item);
1814 /* Reschedule a work item if we have a shorter timeout */
1815 if (mad_agent_priv->wait_list.next == &mad_send_wr->agent_list) {
1816 cancel_delayed_work(&mad_agent_priv->timed_work);
1817 queue_delayed_work(mad_agent_priv->qp_info->port_priv->wq,
1818 &mad_agent_priv->timed_work, delay);
1822 void ib_reset_mad_timeout(struct ib_mad_send_wr_private *mad_send_wr,
1823 int timeout_ms)
1825 mad_send_wr->timeout = msecs_to_jiffies(timeout_ms);
1826 wait_for_response(mad_send_wr);
1830 * Process a send work completion
1832 void ib_mad_complete_send_wr(struct ib_mad_send_wr_private *mad_send_wr,
1833 struct ib_mad_send_wc *mad_send_wc)
1835 struct ib_mad_agent_private *mad_agent_priv;
1836 unsigned long flags;
1837 int ret;
1839 mad_agent_priv = mad_send_wr->mad_agent_priv;
1840 spin_lock_irqsave(&mad_agent_priv->lock, flags);
1841 if (mad_agent_priv->agent.rmpp_version) {
1842 ret = ib_process_rmpp_send_wc(mad_send_wr, mad_send_wc);
1843 if (ret == IB_RMPP_RESULT_CONSUMED)
1844 goto done;
1845 } else
1846 ret = IB_RMPP_RESULT_UNHANDLED;
1848 if (mad_send_wc->status != IB_WC_SUCCESS &&
1849 mad_send_wr->status == IB_WC_SUCCESS) {
1850 mad_send_wr->status = mad_send_wc->status;
1851 mad_send_wr->refcount -= (mad_send_wr->timeout > 0);
1854 if (--mad_send_wr->refcount > 0) {
1855 if (mad_send_wr->refcount == 1 && mad_send_wr->timeout &&
1856 mad_send_wr->status == IB_WC_SUCCESS) {
1857 wait_for_response(mad_send_wr);
1859 goto done;
1862 /* Remove send from MAD agent and notify client of completion */
1863 list_del(&mad_send_wr->agent_list);
1864 adjust_timeout(mad_agent_priv);
1865 spin_unlock_irqrestore(&mad_agent_priv->lock, flags);
1867 if (mad_send_wr->status != IB_WC_SUCCESS )
1868 mad_send_wc->status = mad_send_wr->status;
1869 if (ret != IB_RMPP_RESULT_INTERNAL)
1870 mad_agent_priv->agent.send_handler(&mad_agent_priv->agent,
1871 mad_send_wc);
1873 /* Release reference on agent taken when sending */
1874 if (atomic_dec_and_test(&mad_agent_priv->refcount))
1875 wake_up(&mad_agent_priv->wait);
1877 kfree(mad_send_wr);
1878 return;
1879 done:
1880 spin_unlock_irqrestore(&mad_agent_priv->lock, flags);
1883 static void ib_mad_send_done_handler(struct ib_mad_port_private *port_priv,
1884 struct ib_wc *wc)
1886 struct ib_mad_send_wr_private *mad_send_wr, *queued_send_wr;
1887 struct ib_mad_list_head *mad_list;
1888 struct ib_mad_qp_info *qp_info;
1889 struct ib_mad_queue *send_queue;
1890 struct ib_send_wr *bad_send_wr;
1891 unsigned long flags;
1892 int ret;
1894 mad_list = (struct ib_mad_list_head *)(unsigned long)wc->wr_id;
1895 mad_send_wr = container_of(mad_list, struct ib_mad_send_wr_private,
1896 mad_list);
1897 send_queue = mad_list->mad_queue;
1898 qp_info = send_queue->qp_info;
1900 retry:
1901 queued_send_wr = NULL;
1902 spin_lock_irqsave(&send_queue->lock, flags);
1903 list_del(&mad_list->list);
1905 /* Move queued send to the send queue */
1906 if (send_queue->count-- > send_queue->max_active) {
1907 mad_list = container_of(qp_info->overflow_list.next,
1908 struct ib_mad_list_head, list);
1909 queued_send_wr = container_of(mad_list,
1910 struct ib_mad_send_wr_private,
1911 mad_list);
1912 list_del(&mad_list->list);
1913 list_add_tail(&mad_list->list, &send_queue->list);
1915 spin_unlock_irqrestore(&send_queue->lock, flags);
1917 /* Restore client wr_id in WC and complete send */
1918 wc->wr_id = mad_send_wr->wr_id;
1919 if (atomic_read(&qp_info->snoop_count))
1920 snoop_send(qp_info, &mad_send_wr->send_wr,
1921 (struct ib_mad_send_wc *)wc,
1922 IB_MAD_SNOOP_SEND_COMPLETIONS);
1923 ib_mad_complete_send_wr(mad_send_wr, (struct ib_mad_send_wc *)wc);
1925 if (queued_send_wr) {
1926 ret = ib_post_send(qp_info->qp, &queued_send_wr->send_wr,
1927 &bad_send_wr);
1928 if (ret) {
1929 printk(KERN_ERR PFX "ib_post_send failed: %d\n", ret);
1930 mad_send_wr = queued_send_wr;
1931 wc->status = IB_WC_LOC_QP_OP_ERR;
1932 goto retry;
1937 static void mark_sends_for_retry(struct ib_mad_qp_info *qp_info)
1939 struct ib_mad_send_wr_private *mad_send_wr;
1940 struct ib_mad_list_head *mad_list;
1941 unsigned long flags;
1943 spin_lock_irqsave(&qp_info->send_queue.lock, flags);
1944 list_for_each_entry(mad_list, &qp_info->send_queue.list, list) {
1945 mad_send_wr = container_of(mad_list,
1946 struct ib_mad_send_wr_private,
1947 mad_list);
1948 mad_send_wr->retry = 1;
1950 spin_unlock_irqrestore(&qp_info->send_queue.lock, flags);
1953 static void mad_error_handler(struct ib_mad_port_private *port_priv,
1954 struct ib_wc *wc)
1956 struct ib_mad_list_head *mad_list;
1957 struct ib_mad_qp_info *qp_info;
1958 struct ib_mad_send_wr_private *mad_send_wr;
1959 int ret;
1961 /* Determine if failure was a send or receive */
1962 mad_list = (struct ib_mad_list_head *)(unsigned long)wc->wr_id;
1963 qp_info = mad_list->mad_queue->qp_info;
1964 if (mad_list->mad_queue == &qp_info->recv_queue)
1966 * Receive errors indicate that the QP has entered the error
1967 * state - error handling/shutdown code will cleanup
1969 return;
1972 * Send errors will transition the QP to SQE - move
1973 * QP to RTS and repost flushed work requests
1975 mad_send_wr = container_of(mad_list, struct ib_mad_send_wr_private,
1976 mad_list);
1977 if (wc->status == IB_WC_WR_FLUSH_ERR) {
1978 if (mad_send_wr->retry) {
1979 /* Repost send */
1980 struct ib_send_wr *bad_send_wr;
1982 mad_send_wr->retry = 0;
1983 ret = ib_post_send(qp_info->qp, &mad_send_wr->send_wr,
1984 &bad_send_wr);
1985 if (ret)
1986 ib_mad_send_done_handler(port_priv, wc);
1987 } else
1988 ib_mad_send_done_handler(port_priv, wc);
1989 } else {
1990 struct ib_qp_attr *attr;
1992 /* Transition QP to RTS and fail offending send */
1993 attr = kmalloc(sizeof *attr, GFP_KERNEL);
1994 if (attr) {
1995 attr->qp_state = IB_QPS_RTS;
1996 attr->cur_qp_state = IB_QPS_SQE;
1997 ret = ib_modify_qp(qp_info->qp, attr,
1998 IB_QP_STATE | IB_QP_CUR_STATE);
1999 kfree(attr);
2000 if (ret)
2001 printk(KERN_ERR PFX "mad_error_handler - "
2002 "ib_modify_qp to RTS : %d\n", ret);
2003 else
2004 mark_sends_for_retry(qp_info);
2006 ib_mad_send_done_handler(port_priv, wc);
2011 * IB MAD completion callback
2013 static void ib_mad_completion_handler(void *data)
2015 struct ib_mad_port_private *port_priv;
2016 struct ib_wc wc;
2018 port_priv = (struct ib_mad_port_private *)data;
2019 ib_req_notify_cq(port_priv->cq, IB_CQ_NEXT_COMP);
2021 while (ib_poll_cq(port_priv->cq, 1, &wc) == 1) {
2022 if (wc.status == IB_WC_SUCCESS) {
2023 switch (wc.opcode) {
2024 case IB_WC_SEND:
2025 ib_mad_send_done_handler(port_priv, &wc);
2026 break;
2027 case IB_WC_RECV:
2028 ib_mad_recv_done_handler(port_priv, &wc);
2029 break;
2030 default:
2031 BUG_ON(1);
2032 break;
2034 } else
2035 mad_error_handler(port_priv, &wc);
2039 static void cancel_mads(struct ib_mad_agent_private *mad_agent_priv)
2041 unsigned long flags;
2042 struct ib_mad_send_wr_private *mad_send_wr, *temp_mad_send_wr;
2043 struct ib_mad_send_wc mad_send_wc;
2044 struct list_head cancel_list;
2046 INIT_LIST_HEAD(&cancel_list);
2048 spin_lock_irqsave(&mad_agent_priv->lock, flags);
2049 list_for_each_entry_safe(mad_send_wr, temp_mad_send_wr,
2050 &mad_agent_priv->send_list, agent_list) {
2051 if (mad_send_wr->status == IB_WC_SUCCESS) {
2052 mad_send_wr->status = IB_WC_WR_FLUSH_ERR;
2053 mad_send_wr->refcount -= (mad_send_wr->timeout > 0);
2057 /* Empty wait list to prevent receives from finding a request */
2058 list_splice_init(&mad_agent_priv->wait_list, &cancel_list);
2059 /* Empty local completion list as well */
2060 list_splice_init(&mad_agent_priv->local_list, &cancel_list);
2061 spin_unlock_irqrestore(&mad_agent_priv->lock, flags);
2063 /* Report all cancelled requests */
2064 mad_send_wc.status = IB_WC_WR_FLUSH_ERR;
2065 mad_send_wc.vendor_err = 0;
2067 list_for_each_entry_safe(mad_send_wr, temp_mad_send_wr,
2068 &cancel_list, agent_list) {
2069 mad_send_wc.wr_id = mad_send_wr->wr_id;
2070 mad_agent_priv->agent.send_handler(&mad_agent_priv->agent,
2071 &mad_send_wc);
2073 list_del(&mad_send_wr->agent_list);
2074 kfree(mad_send_wr);
2075 atomic_dec(&mad_agent_priv->refcount);
2079 static struct ib_mad_send_wr_private*
2080 find_send_by_wr_id(struct ib_mad_agent_private *mad_agent_priv, u64 wr_id)
2082 struct ib_mad_send_wr_private *mad_send_wr;
2084 list_for_each_entry(mad_send_wr, &mad_agent_priv->wait_list,
2085 agent_list) {
2086 if (mad_send_wr->wr_id == wr_id)
2087 return mad_send_wr;
2090 list_for_each_entry(mad_send_wr, &mad_agent_priv->send_list,
2091 agent_list) {
2092 if (is_data_mad(mad_agent_priv,
2093 mad_send_wr->send_wr.wr.ud.mad_hdr) &&
2094 mad_send_wr->wr_id == wr_id)
2095 return mad_send_wr;
2097 return NULL;
2100 int ib_modify_mad(struct ib_mad_agent *mad_agent, u64 wr_id, u32 timeout_ms)
2102 struct ib_mad_agent_private *mad_agent_priv;
2103 struct ib_mad_send_wr_private *mad_send_wr;
2104 unsigned long flags;
2105 int active;
2107 mad_agent_priv = container_of(mad_agent, struct ib_mad_agent_private,
2108 agent);
2109 spin_lock_irqsave(&mad_agent_priv->lock, flags);
2110 mad_send_wr = find_send_by_wr_id(mad_agent_priv, wr_id);
2111 if (!mad_send_wr || mad_send_wr->status != IB_WC_SUCCESS) {
2112 spin_unlock_irqrestore(&mad_agent_priv->lock, flags);
2113 return -EINVAL;
2116 active = (!mad_send_wr->timeout || mad_send_wr->refcount > 1);
2117 if (!timeout_ms) {
2118 mad_send_wr->status = IB_WC_WR_FLUSH_ERR;
2119 mad_send_wr->refcount -= (mad_send_wr->timeout > 0);
2122 mad_send_wr->send_wr.wr.ud.timeout_ms = timeout_ms;
2123 if (active)
2124 mad_send_wr->timeout = msecs_to_jiffies(timeout_ms);
2125 else
2126 ib_reset_mad_timeout(mad_send_wr, timeout_ms);
2128 spin_unlock_irqrestore(&mad_agent_priv->lock, flags);
2129 return 0;
2131 EXPORT_SYMBOL(ib_modify_mad);
2133 void ib_cancel_mad(struct ib_mad_agent *mad_agent, u64 wr_id)
2135 ib_modify_mad(mad_agent, wr_id, 0);
2137 EXPORT_SYMBOL(ib_cancel_mad);
2139 static void local_completions(void *data)
2141 struct ib_mad_agent_private *mad_agent_priv;
2142 struct ib_mad_local_private *local;
2143 struct ib_mad_agent_private *recv_mad_agent;
2144 unsigned long flags;
2145 int recv = 0;
2146 struct ib_wc wc;
2147 struct ib_mad_send_wc mad_send_wc;
2149 mad_agent_priv = (struct ib_mad_agent_private *)data;
2151 spin_lock_irqsave(&mad_agent_priv->lock, flags);
2152 while (!list_empty(&mad_agent_priv->local_list)) {
2153 local = list_entry(mad_agent_priv->local_list.next,
2154 struct ib_mad_local_private,
2155 completion_list);
2156 spin_unlock_irqrestore(&mad_agent_priv->lock, flags);
2157 if (local->mad_priv) {
2158 recv_mad_agent = local->recv_mad_agent;
2159 if (!recv_mad_agent) {
2160 printk(KERN_ERR PFX "No receive MAD agent for local completion\n");
2161 goto local_send_completion;
2164 recv = 1;
2166 * Defined behavior is to complete response
2167 * before request
2169 build_smp_wc(local->wr_id,
2170 be16_to_cpu(IB_LID_PERMISSIVE),
2171 0 /* pkey index */,
2172 recv_mad_agent->agent.port_num, &wc);
2174 local->mad_priv->header.recv_wc.wc = &wc;
2175 local->mad_priv->header.recv_wc.mad_len =
2176 sizeof(struct ib_mad);
2177 INIT_LIST_HEAD(&local->mad_priv->header.recv_wc.rmpp_list);
2178 list_add(&local->mad_priv->header.recv_wc.recv_buf.list,
2179 &local->mad_priv->header.recv_wc.rmpp_list);
2180 local->mad_priv->header.recv_wc.recv_buf.grh = NULL;
2181 local->mad_priv->header.recv_wc.recv_buf.mad =
2182 &local->mad_priv->mad.mad;
2183 if (atomic_read(&recv_mad_agent->qp_info->snoop_count))
2184 snoop_recv(recv_mad_agent->qp_info,
2185 &local->mad_priv->header.recv_wc,
2186 IB_MAD_SNOOP_RECVS);
2187 recv_mad_agent->agent.recv_handler(
2188 &recv_mad_agent->agent,
2189 &local->mad_priv->header.recv_wc);
2190 spin_lock_irqsave(&recv_mad_agent->lock, flags);
2191 atomic_dec(&recv_mad_agent->refcount);
2192 spin_unlock_irqrestore(&recv_mad_agent->lock, flags);
2195 local_send_completion:
2196 /* Complete send */
2197 mad_send_wc.status = IB_WC_SUCCESS;
2198 mad_send_wc.vendor_err = 0;
2199 mad_send_wc.wr_id = local->wr_id;
2200 if (atomic_read(&mad_agent_priv->qp_info->snoop_count))
2201 snoop_send(mad_agent_priv->qp_info, &local->send_wr,
2202 &mad_send_wc,
2203 IB_MAD_SNOOP_SEND_COMPLETIONS);
2204 mad_agent_priv->agent.send_handler(&mad_agent_priv->agent,
2205 &mad_send_wc);
2207 spin_lock_irqsave(&mad_agent_priv->lock, flags);
2208 list_del(&local->completion_list);
2209 atomic_dec(&mad_agent_priv->refcount);
2210 if (!recv)
2211 kmem_cache_free(ib_mad_cache, local->mad_priv);
2212 kfree(local);
2214 spin_unlock_irqrestore(&mad_agent_priv->lock, flags);
2217 static int retry_send(struct ib_mad_send_wr_private *mad_send_wr)
2219 int ret;
2221 if (!mad_send_wr->retries--)
2222 return -ETIMEDOUT;
2224 mad_send_wr->timeout = msecs_to_jiffies(mad_send_wr->send_wr.
2225 wr.ud.timeout_ms);
2227 if (mad_send_wr->mad_agent_priv->agent.rmpp_version) {
2228 ret = ib_retry_rmpp(mad_send_wr);
2229 switch (ret) {
2230 case IB_RMPP_RESULT_UNHANDLED:
2231 ret = ib_send_mad(mad_send_wr);
2232 break;
2233 case IB_RMPP_RESULT_CONSUMED:
2234 ret = 0;
2235 break;
2236 default:
2237 ret = -ECOMM;
2238 break;
2240 } else
2241 ret = ib_send_mad(mad_send_wr);
2243 if (!ret) {
2244 mad_send_wr->refcount++;
2245 list_add_tail(&mad_send_wr->agent_list,
2246 &mad_send_wr->mad_agent_priv->send_list);
2248 return ret;
2251 static void timeout_sends(void *data)
2253 struct ib_mad_agent_private *mad_agent_priv;
2254 struct ib_mad_send_wr_private *mad_send_wr;
2255 struct ib_mad_send_wc mad_send_wc;
2256 unsigned long flags, delay;
2258 mad_agent_priv = (struct ib_mad_agent_private *)data;
2259 mad_send_wc.vendor_err = 0;
2261 spin_lock_irqsave(&mad_agent_priv->lock, flags);
2262 while (!list_empty(&mad_agent_priv->wait_list)) {
2263 mad_send_wr = list_entry(mad_agent_priv->wait_list.next,
2264 struct ib_mad_send_wr_private,
2265 agent_list);
2267 if (time_after(mad_send_wr->timeout, jiffies)) {
2268 delay = mad_send_wr->timeout - jiffies;
2269 if ((long)delay <= 0)
2270 delay = 1;
2271 queue_delayed_work(mad_agent_priv->qp_info->
2272 port_priv->wq,
2273 &mad_agent_priv->timed_work, delay);
2274 break;
2277 list_del(&mad_send_wr->agent_list);
2278 if (mad_send_wr->status == IB_WC_SUCCESS &&
2279 !retry_send(mad_send_wr))
2280 continue;
2282 spin_unlock_irqrestore(&mad_agent_priv->lock, flags);
2284 if (mad_send_wr->status == IB_WC_SUCCESS)
2285 mad_send_wc.status = IB_WC_RESP_TIMEOUT_ERR;
2286 else
2287 mad_send_wc.status = mad_send_wr->status;
2288 mad_send_wc.wr_id = mad_send_wr->wr_id;
2289 mad_agent_priv->agent.send_handler(&mad_agent_priv->agent,
2290 &mad_send_wc);
2292 kfree(mad_send_wr);
2293 atomic_dec(&mad_agent_priv->refcount);
2294 spin_lock_irqsave(&mad_agent_priv->lock, flags);
2296 spin_unlock_irqrestore(&mad_agent_priv->lock, flags);
2299 static void ib_mad_thread_completion_handler(struct ib_cq *cq, void *arg)
2301 struct ib_mad_port_private *port_priv = cq->cq_context;
2303 queue_work(port_priv->wq, &port_priv->work);
2307 * Allocate receive MADs and post receive WRs for them
2309 static int ib_mad_post_receive_mads(struct ib_mad_qp_info *qp_info,
2310 struct ib_mad_private *mad)
2312 unsigned long flags;
2313 int post, ret;
2314 struct ib_mad_private *mad_priv;
2315 struct ib_sge sg_list;
2316 struct ib_recv_wr recv_wr, *bad_recv_wr;
2317 struct ib_mad_queue *recv_queue = &qp_info->recv_queue;
2319 /* Initialize common scatter list fields */
2320 sg_list.length = sizeof *mad_priv - sizeof mad_priv->header;
2321 sg_list.lkey = (*qp_info->port_priv->mr).lkey;
2323 /* Initialize common receive WR fields */
2324 recv_wr.next = NULL;
2325 recv_wr.sg_list = &sg_list;
2326 recv_wr.num_sge = 1;
2328 do {
2329 /* Allocate and map receive buffer */
2330 if (mad) {
2331 mad_priv = mad;
2332 mad = NULL;
2333 } else {
2334 mad_priv = kmem_cache_alloc(ib_mad_cache, GFP_KERNEL);
2335 if (!mad_priv) {
2336 printk(KERN_ERR PFX "No memory for receive buffer\n");
2337 ret = -ENOMEM;
2338 break;
2341 sg_list.addr = dma_map_single(qp_info->port_priv->
2342 device->dma_device,
2343 &mad_priv->grh,
2344 sizeof *mad_priv -
2345 sizeof mad_priv->header,
2346 DMA_FROM_DEVICE);
2347 pci_unmap_addr_set(&mad_priv->header, mapping, sg_list.addr);
2348 recv_wr.wr_id = (unsigned long)&mad_priv->header.mad_list;
2349 mad_priv->header.mad_list.mad_queue = recv_queue;
2351 /* Post receive WR */
2352 spin_lock_irqsave(&recv_queue->lock, flags);
2353 post = (++recv_queue->count < recv_queue->max_active);
2354 list_add_tail(&mad_priv->header.mad_list.list, &recv_queue->list);
2355 spin_unlock_irqrestore(&recv_queue->lock, flags);
2356 ret = ib_post_recv(qp_info->qp, &recv_wr, &bad_recv_wr);
2357 if (ret) {
2358 spin_lock_irqsave(&recv_queue->lock, flags);
2359 list_del(&mad_priv->header.mad_list.list);
2360 recv_queue->count--;
2361 spin_unlock_irqrestore(&recv_queue->lock, flags);
2362 dma_unmap_single(qp_info->port_priv->device->dma_device,
2363 pci_unmap_addr(&mad_priv->header,
2364 mapping),
2365 sizeof *mad_priv -
2366 sizeof mad_priv->header,
2367 DMA_FROM_DEVICE);
2368 kmem_cache_free(ib_mad_cache, mad_priv);
2369 printk(KERN_ERR PFX "ib_post_recv failed: %d\n", ret);
2370 break;
2372 } while (post);
2374 return ret;
2378 * Return all the posted receive MADs
2380 static void cleanup_recv_queue(struct ib_mad_qp_info *qp_info)
2382 struct ib_mad_private_header *mad_priv_hdr;
2383 struct ib_mad_private *recv;
2384 struct ib_mad_list_head *mad_list;
2386 while (!list_empty(&qp_info->recv_queue.list)) {
2388 mad_list = list_entry(qp_info->recv_queue.list.next,
2389 struct ib_mad_list_head, list);
2390 mad_priv_hdr = container_of(mad_list,
2391 struct ib_mad_private_header,
2392 mad_list);
2393 recv = container_of(mad_priv_hdr, struct ib_mad_private,
2394 header);
2396 /* Remove from posted receive MAD list */
2397 list_del(&mad_list->list);
2399 dma_unmap_single(qp_info->port_priv->device->dma_device,
2400 pci_unmap_addr(&recv->header, mapping),
2401 sizeof(struct ib_mad_private) -
2402 sizeof(struct ib_mad_private_header),
2403 DMA_FROM_DEVICE);
2404 kmem_cache_free(ib_mad_cache, recv);
2407 qp_info->recv_queue.count = 0;
2411 * Start the port
2413 static int ib_mad_port_start(struct ib_mad_port_private *port_priv)
2415 int ret, i;
2416 struct ib_qp_attr *attr;
2417 struct ib_qp *qp;
2419 attr = kmalloc(sizeof *attr, GFP_KERNEL);
2420 if (!attr) {
2421 printk(KERN_ERR PFX "Couldn't kmalloc ib_qp_attr\n");
2422 return -ENOMEM;
2425 for (i = 0; i < IB_MAD_QPS_CORE; i++) {
2426 qp = port_priv->qp_info[i].qp;
2428 * PKey index for QP1 is irrelevant but
2429 * one is needed for the Reset to Init transition
2431 attr->qp_state = IB_QPS_INIT;
2432 attr->pkey_index = 0;
2433 attr->qkey = (qp->qp_num == 0) ? 0 : IB_QP1_QKEY;
2434 ret = ib_modify_qp(qp, attr, IB_QP_STATE |
2435 IB_QP_PKEY_INDEX | IB_QP_QKEY);
2436 if (ret) {
2437 printk(KERN_ERR PFX "Couldn't change QP%d state to "
2438 "INIT: %d\n", i, ret);
2439 goto out;
2442 attr->qp_state = IB_QPS_RTR;
2443 ret = ib_modify_qp(qp, attr, IB_QP_STATE);
2444 if (ret) {
2445 printk(KERN_ERR PFX "Couldn't change QP%d state to "
2446 "RTR: %d\n", i, ret);
2447 goto out;
2450 attr->qp_state = IB_QPS_RTS;
2451 attr->sq_psn = IB_MAD_SEND_Q_PSN;
2452 ret = ib_modify_qp(qp, attr, IB_QP_STATE | IB_QP_SQ_PSN);
2453 if (ret) {
2454 printk(KERN_ERR PFX "Couldn't change QP%d state to "
2455 "RTS: %d\n", i, ret);
2456 goto out;
2460 ret = ib_req_notify_cq(port_priv->cq, IB_CQ_NEXT_COMP);
2461 if (ret) {
2462 printk(KERN_ERR PFX "Failed to request completion "
2463 "notification: %d\n", ret);
2464 goto out;
2467 for (i = 0; i < IB_MAD_QPS_CORE; i++) {
2468 ret = ib_mad_post_receive_mads(&port_priv->qp_info[i], NULL);
2469 if (ret) {
2470 printk(KERN_ERR PFX "Couldn't post receive WRs\n");
2471 goto out;
2474 out:
2475 kfree(attr);
2476 return ret;
2479 static void qp_event_handler(struct ib_event *event, void *qp_context)
2481 struct ib_mad_qp_info *qp_info = qp_context;
2483 /* It's worse than that! He's dead, Jim! */
2484 printk(KERN_ERR PFX "Fatal error (%d) on MAD QP (%d)\n",
2485 event->event, qp_info->qp->qp_num);
2488 static void init_mad_queue(struct ib_mad_qp_info *qp_info,
2489 struct ib_mad_queue *mad_queue)
2491 mad_queue->qp_info = qp_info;
2492 mad_queue->count = 0;
2493 spin_lock_init(&mad_queue->lock);
2494 INIT_LIST_HEAD(&mad_queue->list);
2497 static void init_mad_qp(struct ib_mad_port_private *port_priv,
2498 struct ib_mad_qp_info *qp_info)
2500 qp_info->port_priv = port_priv;
2501 init_mad_queue(qp_info, &qp_info->send_queue);
2502 init_mad_queue(qp_info, &qp_info->recv_queue);
2503 INIT_LIST_HEAD(&qp_info->overflow_list);
2504 spin_lock_init(&qp_info->snoop_lock);
2505 qp_info->snoop_table = NULL;
2506 qp_info->snoop_table_size = 0;
2507 atomic_set(&qp_info->snoop_count, 0);
2510 static int create_mad_qp(struct ib_mad_qp_info *qp_info,
2511 enum ib_qp_type qp_type)
2513 struct ib_qp_init_attr qp_init_attr;
2514 int ret;
2516 memset(&qp_init_attr, 0, sizeof qp_init_attr);
2517 qp_init_attr.send_cq = qp_info->port_priv->cq;
2518 qp_init_attr.recv_cq = qp_info->port_priv->cq;
2519 qp_init_attr.sq_sig_type = IB_SIGNAL_ALL_WR;
2520 qp_init_attr.cap.max_send_wr = IB_MAD_QP_SEND_SIZE;
2521 qp_init_attr.cap.max_recv_wr = IB_MAD_QP_RECV_SIZE;
2522 qp_init_attr.cap.max_send_sge = IB_MAD_SEND_REQ_MAX_SG;
2523 qp_init_attr.cap.max_recv_sge = IB_MAD_RECV_REQ_MAX_SG;
2524 qp_init_attr.qp_type = qp_type;
2525 qp_init_attr.port_num = qp_info->port_priv->port_num;
2526 qp_init_attr.qp_context = qp_info;
2527 qp_init_attr.event_handler = qp_event_handler;
2528 qp_info->qp = ib_create_qp(qp_info->port_priv->pd, &qp_init_attr);
2529 if (IS_ERR(qp_info->qp)) {
2530 printk(KERN_ERR PFX "Couldn't create ib_mad QP%d\n",
2531 get_spl_qp_index(qp_type));
2532 ret = PTR_ERR(qp_info->qp);
2533 goto error;
2535 /* Use minimum queue sizes unless the CQ is resized */
2536 qp_info->send_queue.max_active = IB_MAD_QP_SEND_SIZE;
2537 qp_info->recv_queue.max_active = IB_MAD_QP_RECV_SIZE;
2538 return 0;
2540 error:
2541 return ret;
2544 static void destroy_mad_qp(struct ib_mad_qp_info *qp_info)
2546 ib_destroy_qp(qp_info->qp);
2547 if (qp_info->snoop_table)
2548 kfree(qp_info->snoop_table);
2552 * Open the port
2553 * Create the QP, PD, MR, and CQ if needed
2555 static int ib_mad_port_open(struct ib_device *device,
2556 int port_num)
2558 int ret, cq_size;
2559 struct ib_mad_port_private *port_priv;
2560 unsigned long flags;
2561 char name[sizeof "ib_mad123"];
2563 /* Create new device info */
2564 port_priv = kmalloc(sizeof *port_priv, GFP_KERNEL);
2565 if (!port_priv) {
2566 printk(KERN_ERR PFX "No memory for ib_mad_port_private\n");
2567 return -ENOMEM;
2569 memset(port_priv, 0, sizeof *port_priv);
2570 port_priv->device = device;
2571 port_priv->port_num = port_num;
2572 spin_lock_init(&port_priv->reg_lock);
2573 INIT_LIST_HEAD(&port_priv->agent_list);
2574 init_mad_qp(port_priv, &port_priv->qp_info[0]);
2575 init_mad_qp(port_priv, &port_priv->qp_info[1]);
2577 cq_size = (IB_MAD_QP_SEND_SIZE + IB_MAD_QP_RECV_SIZE) * 2;
2578 port_priv->cq = ib_create_cq(port_priv->device,
2579 ib_mad_thread_completion_handler,
2580 NULL, port_priv, cq_size);
2581 if (IS_ERR(port_priv->cq)) {
2582 printk(KERN_ERR PFX "Couldn't create ib_mad CQ\n");
2583 ret = PTR_ERR(port_priv->cq);
2584 goto error3;
2587 port_priv->pd = ib_alloc_pd(device);
2588 if (IS_ERR(port_priv->pd)) {
2589 printk(KERN_ERR PFX "Couldn't create ib_mad PD\n");
2590 ret = PTR_ERR(port_priv->pd);
2591 goto error4;
2594 port_priv->mr = ib_get_dma_mr(port_priv->pd, IB_ACCESS_LOCAL_WRITE);
2595 if (IS_ERR(port_priv->mr)) {
2596 printk(KERN_ERR PFX "Couldn't get ib_mad DMA MR\n");
2597 ret = PTR_ERR(port_priv->mr);
2598 goto error5;
2601 ret = create_mad_qp(&port_priv->qp_info[0], IB_QPT_SMI);
2602 if (ret)
2603 goto error6;
2604 ret = create_mad_qp(&port_priv->qp_info[1], IB_QPT_GSI);
2605 if (ret)
2606 goto error7;
2608 snprintf(name, sizeof name, "ib_mad%d", port_num);
2609 port_priv->wq = create_singlethread_workqueue(name);
2610 if (!port_priv->wq) {
2611 ret = -ENOMEM;
2612 goto error8;
2614 INIT_WORK(&port_priv->work, ib_mad_completion_handler, port_priv);
2616 ret = ib_mad_port_start(port_priv);
2617 if (ret) {
2618 printk(KERN_ERR PFX "Couldn't start port\n");
2619 goto error9;
2622 spin_lock_irqsave(&ib_mad_port_list_lock, flags);
2623 list_add_tail(&port_priv->port_list, &ib_mad_port_list);
2624 spin_unlock_irqrestore(&ib_mad_port_list_lock, flags);
2625 return 0;
2627 error9:
2628 destroy_workqueue(port_priv->wq);
2629 error8:
2630 destroy_mad_qp(&port_priv->qp_info[1]);
2631 error7:
2632 destroy_mad_qp(&port_priv->qp_info[0]);
2633 error6:
2634 ib_dereg_mr(port_priv->mr);
2635 error5:
2636 ib_dealloc_pd(port_priv->pd);
2637 error4:
2638 ib_destroy_cq(port_priv->cq);
2639 cleanup_recv_queue(&port_priv->qp_info[1]);
2640 cleanup_recv_queue(&port_priv->qp_info[0]);
2641 error3:
2642 kfree(port_priv);
2644 return ret;
2648 * Close the port
2649 * If there are no classes using the port, free the port
2650 * resources (CQ, MR, PD, QP) and remove the port's info structure
2652 static int ib_mad_port_close(struct ib_device *device, int port_num)
2654 struct ib_mad_port_private *port_priv;
2655 unsigned long flags;
2657 spin_lock_irqsave(&ib_mad_port_list_lock, flags);
2658 port_priv = __ib_get_mad_port(device, port_num);
2659 if (port_priv == NULL) {
2660 spin_unlock_irqrestore(&ib_mad_port_list_lock, flags);
2661 printk(KERN_ERR PFX "Port %d not found\n", port_num);
2662 return -ENODEV;
2664 list_del(&port_priv->port_list);
2665 spin_unlock_irqrestore(&ib_mad_port_list_lock, flags);
2667 /* Stop processing completions. */
2668 flush_workqueue(port_priv->wq);
2669 destroy_workqueue(port_priv->wq);
2670 destroy_mad_qp(&port_priv->qp_info[1]);
2671 destroy_mad_qp(&port_priv->qp_info[0]);
2672 ib_dereg_mr(port_priv->mr);
2673 ib_dealloc_pd(port_priv->pd);
2674 ib_destroy_cq(port_priv->cq);
2675 cleanup_recv_queue(&port_priv->qp_info[1]);
2676 cleanup_recv_queue(&port_priv->qp_info[0]);
2677 /* XXX: Handle deallocation of MAD registration tables */
2679 kfree(port_priv);
2681 return 0;
2684 static void ib_mad_init_device(struct ib_device *device)
2686 int num_ports, cur_port, i;
2688 if (device->node_type == IB_NODE_SWITCH) {
2689 num_ports = 1;
2690 cur_port = 0;
2691 } else {
2692 num_ports = device->phys_port_cnt;
2693 cur_port = 1;
2695 for (i = 0; i < num_ports; i++, cur_port++) {
2696 if (ib_mad_port_open(device, cur_port)) {
2697 printk(KERN_ERR PFX "Couldn't open %s port %d\n",
2698 device->name, cur_port);
2699 goto error_device_open;
2701 if (ib_agent_port_open(device, cur_port)) {
2702 printk(KERN_ERR PFX "Couldn't open %s port %d "
2703 "for agents\n",
2704 device->name, cur_port);
2705 goto error_device_open;
2708 return;
2710 error_device_open:
2711 while (i > 0) {
2712 cur_port--;
2713 if (ib_agent_port_close(device, cur_port))
2714 printk(KERN_ERR PFX "Couldn't close %s port %d "
2715 "for agents\n",
2716 device->name, cur_port);
2717 if (ib_mad_port_close(device, cur_port))
2718 printk(KERN_ERR PFX "Couldn't close %s port %d\n",
2719 device->name, cur_port);
2720 i--;
2724 static void ib_mad_remove_device(struct ib_device *device)
2726 int i, num_ports, cur_port;
2728 if (device->node_type == IB_NODE_SWITCH) {
2729 num_ports = 1;
2730 cur_port = 0;
2731 } else {
2732 num_ports = device->phys_port_cnt;
2733 cur_port = 1;
2735 for (i = 0; i < num_ports; i++, cur_port++) {
2736 if (ib_agent_port_close(device, cur_port))
2737 printk(KERN_ERR PFX "Couldn't close %s port %d "
2738 "for agents\n",
2739 device->name, cur_port);
2740 if (ib_mad_port_close(device, cur_port))
2741 printk(KERN_ERR PFX "Couldn't close %s port %d\n",
2742 device->name, cur_port);
2746 static struct ib_client mad_client = {
2747 .name = "mad",
2748 .add = ib_mad_init_device,
2749 .remove = ib_mad_remove_device
2752 static int __init ib_mad_init_module(void)
2754 int ret;
2756 spin_lock_init(&ib_mad_port_list_lock);
2757 spin_lock_init(&ib_agent_port_list_lock);
2759 ib_mad_cache = kmem_cache_create("ib_mad",
2760 sizeof(struct ib_mad_private),
2762 SLAB_HWCACHE_ALIGN,
2763 NULL,
2764 NULL);
2765 if (!ib_mad_cache) {
2766 printk(KERN_ERR PFX "Couldn't create ib_mad cache\n");
2767 ret = -ENOMEM;
2768 goto error1;
2771 INIT_LIST_HEAD(&ib_mad_port_list);
2773 if (ib_register_client(&mad_client)) {
2774 printk(KERN_ERR PFX "Couldn't register ib_mad client\n");
2775 ret = -EINVAL;
2776 goto error2;
2779 return 0;
2781 error2:
2782 kmem_cache_destroy(ib_mad_cache);
2783 error1:
2784 return ret;
2787 static void __exit ib_mad_cleanup_module(void)
2789 ib_unregister_client(&mad_client);
2791 if (kmem_cache_destroy(ib_mad_cache)) {
2792 printk(KERN_DEBUG PFX "Failed to destroy ib_mad cache\n");
2796 module_init(ib_mad_init_module);
2797 module_exit(ib_mad_cleanup_module);