according to rpc error field
Signed-off-by: Hal Rosenstock <[email protected]> --- diff --git a/src/vendor.c b/src/vendor.c index 11efd76..22d6843 100644 --- a/src/vendor.c +++ b/src/vendor.c @@ -1,5 +1,6 @@ /* * Copyright (c) 2004-2009 Voltaire Inc. All rights reserved. + * Copyright (c) 2011 Mellanox Technologies LTD. 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 @@ -38,6 +39,7 @@ #include <stdio.h> #include <stdlib.h> #include <string.h> +#include <errno.h> #include <infiniband/mad.h> #include "mad_internal.h" @@ -61,8 +63,10 @@ uint8_t *ib_vendor_call_via(void *data, ib_portid_t * portid, ib_vendor_call_t * call, struct ibmad_port * srcport) { - ib_rpc_t rpc = { 0 }; + ib_rpc_v1_t rpc = { 0 }; + ib_rpc_t *rpcold = (ib_rpc_t *)(void *)&rpc; int range1 = 0, resp_expected; + void *p_ret; DEBUG("route %s data %p", portid2str(portid), data); if (portid->lid <= 0) @@ -74,7 +78,7 @@ uint8_t *ib_vendor_call_via(void *data, ib_portid_t * portid, resp_expected = response_expected(call->method); - rpc.mgtclass = call->mgmt_class; + rpc.mgtclass = call->mgmt_class | IB_MAD_RPC_VERSION1; rpc.method = call->method; rpc.attr.id = call->attrid; @@ -97,8 +101,11 @@ uint8_t *ib_vendor_call_via(void *data, ib_portid_t * portid, if (!portid->qkey) portid->qkey = IB_DEFAULT_QP1_QKEY; - if (resp_expected) - return mad_rpc_rmpp(srcport, &rpc, portid, 0, data); /* FIXME: no RMPP for now */ + if (resp_expected) { + p_ret = mad_rpc_rmpp(srcport, rpcold, portid, 0, data); /* FIXME: no RMPP for now */ + errno = rpc.error; + return p_ret; + } - return mad_send_via(&rpc, portid, 0, data, srcport) < 0 ? 0 : data; /* FIXME: no RMPP for now */ + return mad_send_via(rpcold, portid, 0, data, srcport) < 0 ? 0 : data; /* FIXME: no RMPP for now */ } -- To unsubscribe from this list: send the line "unsubscribe linux-rdma" in the body of a message to [email protected] More majordomo info at http://vger.kernel.org/majordomo-info.html
