提交 9d187177 编写于 作者: B Bart Van Assche 提交者: Doug Ledford

IB/core: Simplify sa_path_set_[sd]lid() calls

Instead of making every caller convert the second argument of
sa_path_set_slid() and sa_path_set_dlid() to big endian format,
make these two functions accept LIDs in CPU endian format.
This patch does not change any functionality.
Signed-off-by: NBart Van Assche <bart.vanassche@wdc.com>
Cc: Sean Hefty <sean.hefty@intel.com>
Cc: Dasaratharaman Chandramouli <dasaratharaman.chandramouli@intel.com>
Cc: Don Hiatt <don.hiatt@intel.com>
Cc: Ira Weiny <ira.weiny@intel.com>
Signed-off-by: NDoug Ledford <dledford@redhat.com>
上级 9cc12ad6
...@@ -1472,31 +1472,29 @@ static void cm_format_path_lid_from_req(struct cm_req_msg *req_msg, ...@@ -1472,31 +1472,29 @@ static void cm_format_path_lid_from_req(struct cm_req_msg *req_msg,
if (primary_path->rec_type != SA_PATH_REC_TYPE_OPA) { if (primary_path->rec_type != SA_PATH_REC_TYPE_OPA) {
sa_path_set_dlid(primary_path, sa_path_set_dlid(primary_path,
htonl(ntohs(req_msg->primary_local_lid))); ntohs(req_msg->primary_local_lid));
sa_path_set_slid(primary_path, sa_path_set_slid(primary_path,
htonl(ntohs(req_msg->primary_remote_lid))); ntohs(req_msg->primary_remote_lid));
} else { } else {
lid = opa_get_lid_from_gid(&req_msg->primary_local_gid); lid = opa_get_lid_from_gid(&req_msg->primary_local_gid);
sa_path_set_dlid(primary_path, cpu_to_be32(lid)); sa_path_set_dlid(primary_path, lid);
lid = opa_get_lid_from_gid(&req_msg->primary_remote_gid); lid = opa_get_lid_from_gid(&req_msg->primary_remote_gid);
sa_path_set_slid(primary_path, cpu_to_be32(lid)); sa_path_set_slid(primary_path, lid);
} }
if (!cm_req_has_alt_path(req_msg)) if (!cm_req_has_alt_path(req_msg))
return; return;
if (alt_path->rec_type != SA_PATH_REC_TYPE_OPA) { if (alt_path->rec_type != SA_PATH_REC_TYPE_OPA) {
sa_path_set_dlid(alt_path, sa_path_set_dlid(alt_path, ntohs(req_msg->alt_local_lid));
htonl(ntohs(req_msg->alt_local_lid))); sa_path_set_slid(alt_path, ntohs(req_msg->alt_remote_lid));
sa_path_set_slid(alt_path,
htonl(ntohs(req_msg->alt_remote_lid)));
} else { } else {
lid = opa_get_lid_from_gid(&req_msg->alt_local_gid); lid = opa_get_lid_from_gid(&req_msg->alt_local_gid);
sa_path_set_dlid(alt_path, cpu_to_be32(lid)); sa_path_set_dlid(alt_path, lid);
lid = opa_get_lid_from_gid(&req_msg->alt_remote_gid); lid = opa_get_lid_from_gid(&req_msg->alt_remote_gid);
sa_path_set_slid(alt_path, cpu_to_be32(lid)); sa_path_set_slid(alt_path, lid);
} }
} }
...@@ -3037,14 +3035,14 @@ static void cm_format_path_lid_from_lap(struct cm_lap_msg *lap_msg, ...@@ -3037,14 +3035,14 @@ static void cm_format_path_lid_from_lap(struct cm_lap_msg *lap_msg,
u32 lid; u32 lid;
if (path->rec_type != SA_PATH_REC_TYPE_OPA) { if (path->rec_type != SA_PATH_REC_TYPE_OPA) {
sa_path_set_dlid(path, htonl(ntohs(lap_msg->alt_local_lid))); sa_path_set_dlid(path, ntohs(lap_msg->alt_local_lid));
sa_path_set_slid(path, htonl(ntohs(lap_msg->alt_remote_lid))); sa_path_set_slid(path, ntohs(lap_msg->alt_remote_lid));
} else { } else {
lid = opa_get_lid_from_gid(&lap_msg->alt_local_gid); lid = opa_get_lid_from_gid(&lap_msg->alt_local_gid);
sa_path_set_dlid(path, cpu_to_be32(lid)); sa_path_set_dlid(path, lid);
lid = opa_get_lid_from_gid(&lap_msg->alt_remote_gid); lid = opa_get_lid_from_gid(&lap_msg->alt_remote_gid);
sa_path_set_slid(path, cpu_to_be32(lid)); sa_path_set_slid(path, lid);
} }
} }
......
...@@ -176,18 +176,18 @@ EXPORT_SYMBOL(ib_copy_path_rec_to_user); ...@@ -176,18 +176,18 @@ EXPORT_SYMBOL(ib_copy_path_rec_to_user);
void ib_copy_path_rec_from_user(struct sa_path_rec *dst, void ib_copy_path_rec_from_user(struct sa_path_rec *dst,
struct ib_user_path_rec *src) struct ib_user_path_rec *src)
{ {
__be32 slid, dlid; u32 slid, dlid;
memset(dst, 0, sizeof(*dst)); memset(dst, 0, sizeof(*dst));
if ((ib_is_opa_gid((union ib_gid *)src->sgid)) || if ((ib_is_opa_gid((union ib_gid *)src->sgid)) ||
(ib_is_opa_gid((union ib_gid *)src->dgid))) { (ib_is_opa_gid((union ib_gid *)src->dgid))) {
dst->rec_type = SA_PATH_REC_TYPE_OPA; dst->rec_type = SA_PATH_REC_TYPE_OPA;
slid = htonl(opa_get_lid_from_gid((union ib_gid *)src->sgid)); slid = opa_get_lid_from_gid((union ib_gid *)src->sgid);
dlid = htonl(opa_get_lid_from_gid((union ib_gid *)src->dgid)); dlid = opa_get_lid_from_gid((union ib_gid *)src->dgid);
} else { } else {
dst->rec_type = SA_PATH_REC_TYPE_IB; dst->rec_type = SA_PATH_REC_TYPE_IB;
slid = htonl(ntohs(src->slid)); slid = ntohs(src->slid);
dlid = htonl(ntohs(src->dlid)); dlid = ntohs(src->dlid);
} }
memcpy(dst->dgid.raw, src->dgid, sizeof dst->dgid); memcpy(dst->dgid.raw, src->dgid, sizeof dst->dgid);
memcpy(dst->sgid.raw, src->sgid, sizeof dst->sgid); memcpy(dst->sgid.raw, src->sgid, sizeof dst->sgid);
......
...@@ -2403,7 +2403,7 @@ static void srp_cm_rej_handler(struct ib_cm_id *cm_id, ...@@ -2403,7 +2403,7 @@ static void srp_cm_rej_handler(struct ib_cm_id *cm_id,
switch (event->param.rej_rcvd.reason) { switch (event->param.rej_rcvd.reason) {
case IB_CM_REJ_PORT_CM_REDIRECT: case IB_CM_REJ_PORT_CM_REDIRECT:
cpi = event->param.rej_rcvd.ari; cpi = event->param.rej_rcvd.ari;
sa_path_set_dlid(&ch->path, htonl(ntohs(cpi->redirect_lid))); sa_path_set_dlid(&ch->path, ntohs(cpi->redirect_lid));
ch->path.pkey = cpi->redirect_pkey; ch->path.pkey = cpi->redirect_pkey;
cm_id->remote_cm_qpn = be32_to_cpu(cpi->redirect_qp) & 0x00ffffff; cm_id->remote_cm_qpn = be32_to_cpu(cpi->redirect_qp) & 0x00ffffff;
memcpy(ch->path.dgid.raw, cpi->redirect_gid, 16); memcpy(ch->path.dgid.raw, cpi->redirect_gid, 16);
......
...@@ -590,20 +590,20 @@ static inline bool sa_path_is_roce(struct sa_path_rec *rec) ...@@ -590,20 +590,20 @@ static inline bool sa_path_is_roce(struct sa_path_rec *rec)
(rec->rec_type == SA_PATH_REC_TYPE_ROCE_V2)); (rec->rec_type == SA_PATH_REC_TYPE_ROCE_V2));
} }
static inline void sa_path_set_slid(struct sa_path_rec *rec, __be32 slid) static inline void sa_path_set_slid(struct sa_path_rec *rec, u32 slid)
{ {
if (rec->rec_type == SA_PATH_REC_TYPE_IB) if (rec->rec_type == SA_PATH_REC_TYPE_IB)
rec->ib.slid = htons(ntohl(slid)); rec->ib.slid = cpu_to_be16(slid);
else if (rec->rec_type == SA_PATH_REC_TYPE_OPA) else if (rec->rec_type == SA_PATH_REC_TYPE_OPA)
rec->opa.slid = slid; rec->opa.slid = cpu_to_be32(slid);
} }
static inline void sa_path_set_dlid(struct sa_path_rec *rec, __be32 dlid) static inline void sa_path_set_dlid(struct sa_path_rec *rec, u32 dlid)
{ {
if (rec->rec_type == SA_PATH_REC_TYPE_IB) if (rec->rec_type == SA_PATH_REC_TYPE_IB)
rec->ib.dlid = htons(ntohl(dlid)); rec->ib.dlid = cpu_to_be16(dlid);
else if (rec->rec_type == SA_PATH_REC_TYPE_OPA) else if (rec->rec_type == SA_PATH_REC_TYPE_OPA)
rec->opa.dlid = dlid; rec->opa.dlid = cpu_to_be32(dlid);
} }
static inline void sa_path_set_raw_traffic(struct sa_path_rec *rec, static inline void sa_path_set_raw_traffic(struct sa_path_rec *rec,
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册