[ofa-general] Re: [PATCH V2 1/3] Create a new library libibnetdisc

Ira Weiny weiny2 at llnl.gov
Tue Dec 23 14:24:51 PST 2008


On Sun, 21 Dec 2008 17:27:08 +0200
Sasha Khapyorsky <sashak at voltaire.com> wrote:

> On 16:20 Thu 11 Dec     , Ira Weiny wrote:
> > 
> 
> [snip...]
> 
> > diff --git a/infiniband-diags/libibnetdisc/test/iblinkinfotest.c b/infiniband-diags/libibnetdisc/test/iblinkinfotest.c
> > new file mode 100644
> > index 0000000..6e63f4a
> > --- /dev/null
> > +++ b/infiniband-diags/libibnetdisc/test/iblinkinfotest.c
> > @@ -0,0 +1,395 @@
> > +/*
> > + * Copyright (c) 2004-2007 Voltaire Inc.  All rights reserved.
> > + * Copyright (c) 2007 Xsigo Systems Inc.  All rights reserved.
> > + * Copyright (c) 2008 Lawrence Livermore National Lab.  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
> > + * General Public License (GPL) Version 2, available from the file
> > + * COPYING in the main directory of this source tree, or the
> > + * OpenIB.org BSD license below:
> > + *
> > + *     Redistribution and use in source and binary forms, with or
> > + *     without modification, are permitted provided that the following
> > + *     conditions are met:
> > + *
> > + *      - Redistributions of source code must retain the above
> > + *        copyright notice, this list of conditions and the following
> > + *        disclaimer.
> > + *
> > + *      - Redistributions in binary form must reproduce the above
> > + *        copyright notice, this list of conditions and the following
> > + *        disclaimer in the documentation and/or other materials
> > + *        provided with the distribution.
> > + *
> > + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
> > + * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
> > + * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
> > + * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
> > + * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
> > + * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
> > + * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
> > + * SOFTWARE.
> > + *
> > + */
> > +
> > +#if HAVE_CONFIG_H
> > +#  include <config.h>
> > +#endif /* HAVE_CONFIG_H */
> > +
> > +#define _GNU_SOURCE
> > +#include <stdio.h>
> > +#include <stdlib.h>
> > +#include <unistd.h>
> > +#include <stdarg.h>
> > +#include <time.h>
> > +#include <string.h>
> > +#include <getopt.h>
> > +#include <errno.h>
> > +#include <inttypes.h>
> > +
> > +#include <infiniband/complib/cl_nodenamemap.h>
> > +#include <infiniband/ibnetdisc.h>
> > +
> > +char *argv0 = "iblinkinfotest";
> > +static FILE *f;
> > +
> > +static char *node_name_map_file = NULL;
> > +static nn_map_t *node_name_map = NULL;
> > +
> > +static int timeout_ms = 500;
> > +
> > +static int debug = 0;
> > +#define	DEBUG(str, args...) \
> > +	if (debug) fprintf(stderr, str, ##args)
> > +
> > +static int down_links_only = 0;
> > +static int line_mode = 0;
> > +static int add_sw_settings = 0;
> > +static int print_port_guids = 0;
> > +
> > +static unsigned int
> > +get_max(unsigned int num)
> > +{
> > +	unsigned int v = num; // 32-bit word to find the log base 2 of
> > +	unsigned r = 0; // r will be lg(v)
> > +
> > +	while (v >>= 1) // unroll for more speed...
> > +	{
> > +		r++;
> > +	}
> > +
> > +	return (1 << r);
> > +}
> > +
> > +void
> > +get_msg(char *width_msg, char *speed_msg, int msg_size, ibnd_port_t *port)
> > +{
> > +	int max_speed = 0;
> > +
> > +	int max_width = get_max(port->info.link_width_supported
> > +				& port->remoteport->info.link_width_supported);
> > +	if ((max_width & port->info.link_width_active) == 0) {
> > +		// we are not at the max supported width
> > +		// print what we could be at.
> > +		snprintf(width_msg, msg_size, "Could be %s",
> > +			ibnd_linkwidth_str(max_width));
> > +	}
> > +
> > +	max_speed = get_max(port->info.link_speed_supported
> > +				& port->remoteport->info.link_speed_supported);
> > +	if ((max_speed & port->info.link_speed_active) == 0) {
> > +		// we are not at the max supported speed
> > +		// print what we could be at.
> > +		snprintf(speed_msg, msg_size, "Could be %s",
> > +			ibnd_linkspeed_str(max_speed, 1));
> > +	}
> > +}
> > +
> > +void
> > +print_port(ibnd_node_t *node, ibnd_port_t *port)
> > +{
> > +	char remote_guid_str[256];
> > +	char remote_str[256];
> > +	char link_str[256];
> > +	char width_msg[256];
> > +	char speed_msg[256];
> > +	char ext_port_str[256];
> > +
> > +	if (!port)
> > +		return;
> > +
> > +	remote_guid_str[0] = '\0';
> > +	remote_str[0] = '\0';
> > +	link_str[0] = '\0';
> > +	width_msg[0] = '\0';
> > +	speed_msg[0] = '\0';
> > +
> > +	if (port->remoteport) {
> > +		char  remote_name_buf[256];
> > +		strncpy(remote_name_buf, port->remoteport->node->nodedesc, 256);
> > +
> > +		if (port->remoteport->ext_portnum)
> > +			snprintf(ext_port_str, 256, "%d", port->remoteport->ext_portnum);
> > +		else
> > +			ext_port_str[0] = '\0';
> > +
> > +		get_msg(width_msg, speed_msg, 256, port);
> > +		if (line_mode) {
> > +			if (print_port_guids) {
> > +				snprintf(remote_guid_str, 256,
> > +					"0x%016lx ",
> > +					port->remoteport->guid);
> 
> Here and below, printing uint64_t as %lx generates warning on 32-bit
> machine. I would suggest to use portable string macros - PRIx64.
> 

Fixed,
Ira




More information about the general mailing list