[openib-general] RE: [PATCH] Opensm - fix LinkRecord get
Yael Kalka
yael at mellanox.co.il
Thu Dec 1 04:40:49 PST 2005
Hi Hal,
Regarding your question - the answer is that there shouldn't be an
error message in this case.
Assume the following:
A LinkRecord request is received with FromLid and ToLid, both Lids of
switches.
In this case __osm_lr_rcv_get_port_links function will be called with
both src and dest port objects not NULL (the osm_port_t depends on the
Lid).
The __osm_lr_rcv_get_physp_link function will be called with all
possible couple
of 2 such physical ports (for all possible port numbers) - also couples
that are
not connected.
This call is not an error, but part of the flow.
Yael
-----Original Message-----
From: Hal Rosenstock [mailto:halr at voltaire.com]
Sent: Wednesday, November 30, 2005 4:20 PM
To: Yael Kalka
Cc: openib-general at openib.org; Eitan Zahavi
Subject: Re: [PATCH] Opensm - fix LinkRecord get
On Wed, 2005-11-30 at 07:35, Yael Kalka wrote:
> Hi Hal,
>
> During some tests I've noticed that in LinkRecord queries there are
> some bugs:
> 1. Trying to ensure the two physical ports are connected comparison
> isn't done correctly.
> 2. When __osm_lr_rcv_get_physp_link is called with physical ports not
> null - there is no check that the value returned is actually different
> than null. As a result we can get several links with the same value.
>
> This patch fixes both issues.
Thanks. Applied.
Some minor comments below.
-- Hal
> Thanks,
> Yael
>
> Signed-off-by: Yael Kalka <yael at mellanox.co.il>
>
> Index: opensm/osm_sa_link_record.c
> ===================================================================
> --- opensm/osm_sa_link_record.c (revision 4231)
> +++ opensm/osm_sa_link_record.c (working copy)
> @@ -235,7 +235,7 @@ __osm_lr_rcv_get_physp_link(
> Ensure the two physp's are actually connected.
> If not, bail out.
> */
> - if( osm_physp_get_remote( p_src_physp ) != p_src_physp )
> + if( osm_physp_get_remote( p_src_physp ) != p_dest_physp )
> goto Exit;
Should there be an error message here ?
> }
> else
> @@ -393,12 +393,16 @@ __osm_lr_rcv_get_port_links(
> {
> p_dest_physp = osm_port_get_phys_ptr( p_dest_port,
> dest_port_num );
> + /* both physical ports should be with data */
> + if (p_src_physp && p_dest_physp)
> + {
> __osm_lr_rcv_get_physp_link( p_rcv, p_lr, p_src_physp,
> p_dest_physp, comp_mask,
> p_list, p_req_physp );
> }
> }
> }
> + }
Formatting was off here (and similarly below)... I fixed it in the
change that was just committed.
> else
> {
> /*
> @@ -412,17 +416,22 @@ __osm_lr_rcv_get_port_links(
> if (port_num < p_src_port->physp_tbl_size)
> {
> p_src_physp = osm_port_get_phys_ptr( p_src_port, port_num
);
> + if (p_src_physp)
> + {
> __osm_lr_rcv_get_physp_link( p_rcv, p_lr, p_src_physp,
> NULL, comp_mask, p_list,
> p_req_physp );
> }
> }
> + }
> else
> {
> num_ports = osm_port_get_num_physp( p_src_port );
> for( port_num = 1; port_num < num_ports; port_num++ )
> {
> p_src_physp = osm_port_get_phys_ptr( p_src_port, port_num
);
> + if (p_src_physp)
> + {
> __osm_lr_rcv_get_physp_link( p_rcv, p_lr, p_src_physp,
> NULL, comp_mask, p_list,
> p_req_physp );
> @@ -430,6 +439,7 @@ __osm_lr_rcv_get_port_links(
> }
> }
> }
> + }
> else
> {
> if( p_dest_port )
> @@ -446,11 +456,14 @@ __osm_lr_rcv_get_port_links(
> {
> p_dest_physp = osm_port_get_phys_ptr(
> p_dest_port, port_num );
> + if (p_dest_physp)
> + {
> __osm_lr_rcv_get_physp_link( p_rcv, p_lr, NULL,
> p_dest_physp, comp_mask,
> p_list, p_req_physp );
> }
> }
> + }
> else
> {
> num_ports = osm_port_get_num_physp( p_dest_port );
> @@ -458,12 +471,15 @@ __osm_lr_rcv_get_port_links(
> {
> p_dest_physp = osm_port_get_phys_ptr(
> p_dest_port, port_num );
> + if (p_dest_physp)
> + {
> __osm_lr_rcv_get_physp_link( p_rcv, p_lr, NULL,
> p_dest_physp, comp_mask,
> p_list, p_req_physp );
> }
> }
> }
> + }
> else
> {
> /*
>
More information about the general
mailing list