|
Packit |
13e616 |
/*
|
|
Packit |
13e616 |
* Copyright (c) 2004-2008 Voltaire, Inc. All rights reserved.
|
|
Packit |
13e616 |
* Copyright (c) 2002-2005 Mellanox Technologies LTD. All rights reserved.
|
|
Packit |
13e616 |
* Copyright (c) 1996-2003 Intel Corporation. All rights reserved.
|
|
Packit |
13e616 |
*
|
|
Packit |
13e616 |
* This software is available to you under a choice of one of two
|
|
Packit |
13e616 |
* licenses. You may choose to be licensed under the terms of the GNU
|
|
Packit |
13e616 |
* General Public License (GPL) Version 2, available from the file
|
|
Packit |
13e616 |
* COPYING in the main directory of this source tree, or the
|
|
Packit |
13e616 |
* OpenIB.org BSD license below:
|
|
Packit |
13e616 |
*
|
|
Packit |
13e616 |
* Redistribution and use in source and binary forms, with or
|
|
Packit |
13e616 |
* without modification, are permitted provided that the following
|
|
Packit |
13e616 |
* conditions are met:
|
|
Packit |
13e616 |
*
|
|
Packit |
13e616 |
* - Redistributions of source code must retain the above
|
|
Packit |
13e616 |
* copyright notice, this list of conditions and the following
|
|
Packit |
13e616 |
* disclaimer.
|
|
Packit |
13e616 |
*
|
|
Packit |
13e616 |
* - Redistributions in binary form must reproduce the above
|
|
Packit |
13e616 |
* copyright notice, this list of conditions and the following
|
|
Packit |
13e616 |
* disclaimer in the documentation and/or other materials
|
|
Packit |
13e616 |
* provided with the distribution.
|
|
Packit |
13e616 |
*
|
|
Packit |
13e616 |
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
Packit |
13e616 |
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
Packit |
13e616 |
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
|
Packit |
13e616 |
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
|
|
Packit |
13e616 |
* BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
|
|
Packit |
13e616 |
* ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
|
Packit |
13e616 |
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
Packit |
13e616 |
* SOFTWARE.
|
|
Packit |
13e616 |
*
|
|
Packit |
13e616 |
*/
|
|
Packit |
13e616 |
|
|
Packit |
13e616 |
/*
|
|
Packit |
13e616 |
* Abstract:
|
|
Packit |
13e616 |
* Declaration of osm_stats_t.
|
|
Packit |
13e616 |
* This object represents the OpenSM statistics object.
|
|
Packit |
13e616 |
* This object is part of the OpenSM family of objects.
|
|
Packit |
13e616 |
*/
|
|
Packit |
13e616 |
|
|
Packit |
13e616 |
#ifndef _OSM_STATS_H_
|
|
Packit |
13e616 |
#define _OSM_STATS_H_
|
|
Packit |
13e616 |
|
|
Packit |
13e616 |
#ifdef HAVE_LIBPTHREAD
|
|
Packit |
13e616 |
#include <pthread.h>
|
|
Packit |
13e616 |
#else
|
|
Packit |
13e616 |
#include <complib/cl_event.h>
|
|
Packit |
13e616 |
#endif
|
|
Packit |
13e616 |
#include <complib/cl_atomic.h>
|
|
Packit |
13e616 |
#include <opensm/osm_base.h>
|
|
Packit |
13e616 |
|
|
Packit |
13e616 |
#ifdef __cplusplus
|
|
Packit |
13e616 |
# define BEGIN_C_DECLS extern "C" {
|
|
Packit |
13e616 |
# define END_C_DECLS }
|
|
Packit |
13e616 |
#else /* !__cplusplus */
|
|
Packit |
13e616 |
# define BEGIN_C_DECLS
|
|
Packit |
13e616 |
# define END_C_DECLS
|
|
Packit |
13e616 |
#endif /* __cplusplus */
|
|
Packit |
13e616 |
|
|
Packit |
13e616 |
BEGIN_C_DECLS
|
|
Packit |
13e616 |
/****h* OpenSM/Statistics
|
|
Packit |
13e616 |
* NAME
|
|
Packit |
13e616 |
* OpenSM
|
|
Packit |
13e616 |
*
|
|
Packit |
13e616 |
* DESCRIPTION
|
|
Packit |
13e616 |
* The OpenSM object encapsulates the information needed by the
|
|
Packit |
13e616 |
* OpenSM to track interesting traffic and internal statistics.
|
|
Packit |
13e616 |
*
|
|
Packit |
13e616 |
* AUTHOR
|
|
Packit |
13e616 |
* Steve King, Intel
|
|
Packit |
13e616 |
*
|
|
Packit |
13e616 |
*********/
|
|
Packit |
13e616 |
/****s* OpenSM: Statistics/osm_stats_t
|
|
Packit |
13e616 |
* NAME
|
|
Packit |
13e616 |
* osm_stats_t
|
|
Packit |
13e616 |
*
|
|
Packit |
13e616 |
* DESCRIPTION
|
|
Packit |
13e616 |
* OpenSM statistics block.
|
|
Packit |
13e616 |
*
|
|
Packit |
13e616 |
* SYNOPSIS
|
|
Packit |
13e616 |
*/
|
|
Packit |
13e616 |
typedef struct osm_stats {
|
|
Packit |
13e616 |
atomic32_t qp0_mads_outstanding;
|
|
Packit |
13e616 |
atomic32_t qp0_mads_outstanding_on_wire;
|
|
Packit |
13e616 |
atomic32_t qp0_mads_rcvd;
|
|
Packit |
13e616 |
atomic32_t qp0_mads_sent;
|
|
Packit |
13e616 |
atomic32_t qp0_unicasts_sent;
|
|
Packit |
13e616 |
atomic32_t qp0_mads_rcvd_unknown;
|
|
Packit |
13e616 |
atomic32_t sa_mads_outstanding;
|
|
Packit |
13e616 |
atomic32_t sa_mads_rcvd;
|
|
Packit |
13e616 |
atomic32_t sa_mads_sent;
|
|
Packit |
13e616 |
atomic32_t sa_mads_rcvd_unknown;
|
|
Packit |
13e616 |
atomic32_t sa_mads_ignored;
|
|
Packit |
13e616 |
#ifdef HAVE_LIBPTHREAD
|
|
Packit |
13e616 |
pthread_mutex_t mutex;
|
|
Packit |
13e616 |
pthread_cond_t cond;
|
|
Packit |
13e616 |
#else
|
|
Packit |
13e616 |
cl_event_t event;
|
|
Packit |
13e616 |
#endif
|
|
Packit |
13e616 |
} osm_stats_t;
|
|
Packit |
13e616 |
/*
|
|
Packit |
13e616 |
* FIELDS
|
|
Packit |
13e616 |
* qp0_mads_outstanding
|
|
Packit |
13e616 |
* Contains the number of MADs outstanding on QP0.
|
|
Packit |
13e616 |
* When this value reaches zero, OpenSM has discovered all
|
|
Packit |
13e616 |
* nodes on the subnet, and finished retrieving attributes.
|
|
Packit |
13e616 |
* At that time, subnet configuration may begin.
|
|
Packit |
13e616 |
* This variable must be manipulated using atomic instructions.
|
|
Packit |
13e616 |
*
|
|
Packit |
13e616 |
* qp0_mads_outstanding_on_wire
|
|
Packit |
13e616 |
* The number of MADs outstanding on the wire at any moment.
|
|
Packit |
13e616 |
*
|
|
Packit |
13e616 |
* qp0_mads_rcvd
|
|
Packit |
13e616 |
* Total number of QP0 MADs received.
|
|
Packit |
13e616 |
*
|
|
Packit |
13e616 |
* qp0_mads_sent
|
|
Packit |
13e616 |
* Total number of QP0 MADs sent.
|
|
Packit |
13e616 |
*
|
|
Packit |
13e616 |
* qp0_unicasts_sent
|
|
Packit |
13e616 |
* Total number of response-less MADs sent on the wire. This count
|
|
Packit |
13e616 |
* includes getresp(), send() and trap() methods.
|
|
Packit |
13e616 |
*
|
|
Packit |
13e616 |
* qp0_mads_rcvd_unknown
|
|
Packit |
13e616 |
* Total number of unknown QP0 MADs received. This includes
|
|
Packit |
13e616 |
* unrecognized attribute IDs and methods.
|
|
Packit |
13e616 |
*
|
|
Packit |
13e616 |
* sa_mads_outstanding
|
|
Packit |
13e616 |
* Contains the number of SA MADs outstanding on QP1.
|
|
Packit |
13e616 |
*
|
|
Packit |
13e616 |
* sa_mads_rcvd
|
|
Packit |
13e616 |
* Total number of SA MADs received.
|
|
Packit |
13e616 |
*
|
|
Packit |
13e616 |
* sa_mads_sent
|
|
Packit |
13e616 |
* Total number of SA MADs sent.
|
|
Packit |
13e616 |
*
|
|
Packit |
13e616 |
* sa_mads_rcvd_unknown
|
|
Packit |
13e616 |
* Total number of unknown SA MADs received. This includes
|
|
Packit |
13e616 |
* unrecognized attribute IDs and methods.
|
|
Packit |
13e616 |
*
|
|
Packit |
13e616 |
* sa_mads_ignored
|
|
Packit |
13e616 |
* Total number of SA MADs received because SM is not
|
|
Packit |
13e616 |
* master or SM is in first time sweep.
|
|
Packit |
13e616 |
*
|
|
Packit |
13e616 |
* SEE ALSO
|
|
Packit |
13e616 |
***************/
|
|
Packit |
13e616 |
|
|
Packit |
13e616 |
static inline uint32_t osm_stats_inc_qp0_outstanding(osm_stats_t *stats)
|
|
Packit |
13e616 |
{
|
|
Packit |
13e616 |
uint32_t outstanding;
|
|
Packit |
13e616 |
|
|
Packit |
13e616 |
#ifdef HAVE_LIBPTHREAD
|
|
Packit |
13e616 |
pthread_mutex_lock(&stats->mutex);
|
|
Packit |
13e616 |
outstanding = ++stats->qp0_mads_outstanding;
|
|
Packit |
13e616 |
pthread_mutex_unlock(&stats->mutex);
|
|
Packit |
13e616 |
#else
|
|
Packit |
13e616 |
outstanding = cl_atomic_inc(&stats->qp0_mads_outstanding);
|
|
Packit |
13e616 |
#endif
|
|
Packit |
13e616 |
|
|
Packit |
13e616 |
return outstanding;
|
|
Packit |
13e616 |
}
|
|
Packit |
13e616 |
|
|
Packit |
13e616 |
static inline uint32_t osm_stats_dec_qp0_outstanding(osm_stats_t *stats)
|
|
Packit |
13e616 |
{
|
|
Packit |
13e616 |
uint32_t outstanding;
|
|
Packit |
13e616 |
|
|
Packit |
13e616 |
#ifdef HAVE_LIBPTHREAD
|
|
Packit |
13e616 |
pthread_mutex_lock(&stats->mutex);
|
|
Packit |
13e616 |
outstanding = --stats->qp0_mads_outstanding;
|
|
Packit |
13e616 |
if (!outstanding)
|
|
Packit |
13e616 |
pthread_cond_signal(&stats->cond);
|
|
Packit |
13e616 |
pthread_mutex_unlock(&stats->mutex);
|
|
Packit |
13e616 |
#else
|
|
Packit |
13e616 |
outstanding = cl_atomic_dec(&stats->qp0_mads_outstanding);
|
|
Packit |
13e616 |
if (!outstanding)
|
|
Packit |
13e616 |
cl_event_signal(&stats->event);
|
|
Packit |
13e616 |
#endif
|
|
Packit |
13e616 |
|
|
Packit |
13e616 |
return outstanding;
|
|
Packit |
13e616 |
}
|
|
Packit |
13e616 |
|
|
Packit |
13e616 |
END_C_DECLS
|
|
Packit |
13e616 |
#endif /* _OSM_STATS_H_ */
|