@@ -70,7 +70,8 @@ typedef struct osm_nr_search_ctxt {
static ib_api_status_t nr_rcv_new_nr(osm_sa_t * sa,
IN const osm_node_t * p_node,
IN cl_qlist_t * p_list,
- IN ib_net64_t port_guid, IN ib_net16_t lid)
+ IN ib_net64_t port_guid, IN ib_net16_t lid,
+ IN unsigned int port_num)
{
osm_nr_item_t *p_rec_item;
ib_api_status_t status = IB_SUCCESS;
@@ -97,6 +98,9 @@ static ib_api_status_t nr_rcv_new_nr(osm_sa_t * sa,
p_rec_item->rec.node_info = p_node->node_info;
p_rec_item->rec.node_info.port_guid = port_guid;
+ p_rec_item->rec.node_info.port_num_vendor_id =
+ (p_rec_item->rec.node_info.port_num_vendor_id & IB_NODE_INFO_VEND_ID_MASK) |
+ ((port_num << IB_NODE_INFO_PORT_NUM_SHIFT) & IB_NODE_INFO_PORT_NUM_MASK);
memcpy(&(p_rec_item->rec.node_desc), &(p_node->node_desc),
IB_NODE_DESCRIPTION_SIZE);
cl_qlist_insert_tail(p_list, &p_rec_item->list_item);
@@ -110,6 +114,7 @@ static void nr_rcv_create_nr(IN osm_sa_t * sa, IN osm_node_t * p_node,
IN cl_qlist_t * p_list,
IN ib_net64_t const match_port_guid,
IN ib_net16_t const match_lid,
+ IN unsigned int const match_port_num,
IN const osm_physp_t * p_req_physp,
IN const ib_net64_t comp_mask)
{
@@ -173,7 +178,11 @@ static void nr_rcv_create_nr(IN osm_sa_t * sa, IN osm_node_t * p_node,
continue;
}
- nr_rcv_new_nr(sa, p_node, p_list, port_guid, base_lid);
+ if ((comp_mask & IB_NR_COMPMASK_PORTNUM) &&
+ (port_num != match_port_num))
+ continue;
+
+ nr_rcv_new_nr(sa, p_node, p_list, port_guid, base_lid, port_num);
}
OSM_LOG_EXIT(sa->p_log);
@@ -189,6 +198,7 @@ static void nr_rcv_by_comp_mask(IN cl_map_item_t * p_map_item, IN void *context)
ib_net64_t comp_mask = p_ctxt->comp_mask;
ib_net64_t match_port_guid = 0;
ib_net16_t match_lid = 0;
+ unsigned int match_port_num = 0;
OSM_LOG_ENTER(p_ctxt->sa->p_log);
@@ -249,10 +259,8 @@ static void nr_rcv_by_comp_mask(IN cl_map_item_t * p_map_item, IN void *context)
p_rcvd_rec->node_info.revision)
goto Exit;
- if ((comp_mask & IB_NR_COMPMASK_PORTNUM) &&
- ib_node_info_get_local_port_num(&p_node->node_info) !=
- ib_node_info_get_local_port_num(&p_rcvd_rec->node_info))
- goto Exit;
+ if (comp_mask & IB_NR_COMPMASK_PORTNUM)
+ match_port_num = ib_node_info_get_local_port_num(&p_rcvd_rec->node_info);
if ((comp_mask & IB_NR_COMPMASK_VENDID) &&
ib_node_info_get_vendor_id(&p_node->node_info) !=
@@ -265,7 +273,7 @@ static void nr_rcv_by_comp_mask(IN cl_map_item_t * p_map_item, IN void *context)
goto Exit;
nr_rcv_create_nr(sa, p_node, p_ctxt->p_list, match_port_guid,
- match_lid, p_req_physp, comp_mask);
+ match_lid, match_port_num, p_req_physp, comp_mask);
Exit:
OSM_LOG_EXIT(p_ctxt->sa->p_log);