Blame include/opensm/osm_db_pack.h

Packit 13e616
/*
Packit 13e616
 * Copyright (c) 2004-2009 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
/****h* OpenSM/DB-Pack
Packit 13e616
* NAME
Packit 13e616
*	Database Types
Packit 13e616
*
Packit 13e616
* DESCRIPTION
Packit 13e616
*	This module provides packing and unpacking of the database
Packit 13e616
*  storage into specific types.
Packit 13e616
*
Packit 13e616
*  The following domains/conversions are supported:
Packit 13e616
*  guid2lid - key is a guid and data is a lid.
Packit 13e616
*
Packit 13e616
* AUTHOR
Packit 13e616
*	Eitan Zahavi, Mellanox Technologies LTD
Packit 13e616
*
Packit 13e616
*********/
Packit 13e616
Packit 13e616
#ifndef _OSM_DB_PACK_H_
Packit 13e616
#define _OSM_DB_PACK_H_
Packit 13e616
Packit 13e616
#include <opensm/osm_db.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
/****f* OpenSM: DB-Pack/osm_db_guid2lid_init
Packit 13e616
* NAME
Packit 13e616
*	osm_db_guid2lid_init
Packit 13e616
*
Packit 13e616
* DESCRIPTION
Packit 13e616
*	Initialize a domain for the guid2lid table
Packit 13e616
*
Packit 13e616
* SYNOPSIS
Packit 13e616
*/
Packit 13e616
static inline osm_db_domain_t *osm_db_guid2lid_init(IN osm_db_t * p_db)
Packit 13e616
{
Packit 13e616
	return (osm_db_domain_init(p_db, "guid2lid"));
Packit 13e616
}
Packit 13e616
Packit 13e616
/*
Packit 13e616
* PARAMETERS
Packit 13e616
*	p_db
Packit 13e616
*		[in] Pointer to the database object to construct
Packit 13e616
*
Packit 13e616
* RETURN VALUES
Packit 13e616
*	The pointer to the new allocated domain object or NULL.
Packit 13e616
*
Packit 13e616
* NOTE: DB domains are destroyed by the osm_db_destroy
Packit 13e616
*
Packit 13e616
* SEE ALSO
Packit 13e616
*	Database, osm_db_init, osm_db_destroy
Packit 13e616
*********/
Packit 13e616
Packit 13e616
/****f* OpenSM: DB-Pack/osm_db_guid2lid_init
Packit 13e616
* NAME
Packit 13e616
*	osm_db_guid2lid_init
Packit 13e616
*
Packit 13e616
* DESCRIPTION
Packit 13e616
*	Initialize a domain for the guid2lid table
Packit 13e616
*
Packit 13e616
* SYNOPSIS
Packit 13e616
*/
Packit 13e616
typedef struct osm_db_guid_elem {
Packit 13e616
	cl_list_item_t item;
Packit 13e616
	uint64_t guid;
Packit 13e616
} osm_db_guid_elem_t;
Packit 13e616
/*
Packit 13e616
* FIELDS
Packit 13e616
*	item
Packit 13e616
*		required for list manipulations
Packit 13e616
*
Packit 13e616
*  guid
Packit 13e616
*
Packit 13e616
************/
Packit 13e616
Packit 13e616
/****f* OpenSM: DB-Pack/osm_db_guid2lid_guids
Packit 13e616
* NAME
Packit 13e616
*	osm_db_guid2lid_guids
Packit 13e616
*
Packit 13e616
* DESCRIPTION
Packit 13e616
*	Provides back a list of guid elements.
Packit 13e616
*
Packit 13e616
* SYNOPSIS
Packit 13e616
*/
Packit 13e616
int osm_db_guid2lid_guids(IN osm_db_domain_t * p_g2l,
Packit 13e616
			  OUT cl_qlist_t * p_guid_list);
Packit 13e616
/*
Packit 13e616
* PARAMETERS
Packit 13e616
*	p_g2l
Packit 13e616
*		[in] Pointer to the guid2lid domain
Packit 13e616
*
Packit 13e616
*  p_guid_list
Packit 13e616
*     [out] A quick list of guid elements of type osm_db_guid_elem_t
Packit 13e616
*
Packit 13e616
* RETURN VALUES
Packit 13e616
*	0 if successful
Packit 13e616
*
Packit 13e616
* NOTE: the output qlist should be initialized and each item freed
Packit 13e616
*       by the caller, then destroyed.
Packit 13e616
*
Packit 13e616
* SEE ALSO
Packit 13e616
* osm_db_guid2lid_init, osm_db_guid2lid_guids, osm_db_guid2lid_get
Packit 13e616
* osm_db_guid2lid_set, osm_db_guid2lid_delete
Packit 13e616
*********/
Packit 13e616
Packit 13e616
/****f* OpenSM: DB-Pack/osm_db_guid2lid_get
Packit 13e616
* NAME
Packit 13e616
*	osm_db_guid2lid_get
Packit 13e616
*
Packit 13e616
* DESCRIPTION
Packit 13e616
*	Get a lid range by given guid.
Packit 13e616
*
Packit 13e616
* SYNOPSIS
Packit 13e616
*/
Packit 13e616
int osm_db_guid2lid_get(IN osm_db_domain_t * p_g2l, IN uint64_t guid,
Packit 13e616
			OUT uint16_t * p_min_lid, OUT uint16_t * p_max_lid);
Packit 13e616
/*
Packit 13e616
* PARAMETERS
Packit 13e616
*	p_g2l
Packit 13e616
*		[in] Pointer to the guid2lid domain
Packit 13e616
*
Packit 13e616
*  guid
Packit 13e616
*     [in] The guid to look for
Packit 13e616
*
Packit 13e616
*  p_min_lid
Packit 13e616
*     [out] Pointer to the resulting min lid in host order.
Packit 13e616
*
Packit 13e616
*  p_max_lid
Packit 13e616
*     [out] Pointer to the resulting max lid in host order.
Packit 13e616
*
Packit 13e616
* RETURN VALUES
Packit 13e616
*	0 if successful. The lid will be set to 0 if not found.
Packit 13e616
*
Packit 13e616
* SEE ALSO
Packit 13e616
* osm_db_guid2lid_init, osm_db_guid2lid_guids
Packit 13e616
* osm_db_guid2lid_set, osm_db_guid2lid_delete
Packit 13e616
*********/
Packit 13e616
Packit 13e616
/****f* OpenSM: DB-Pack/osm_db_guid2lid_set
Packit 13e616
* NAME
Packit 13e616
*	osm_db_guid2lid_set
Packit 13e616
*
Packit 13e616
* DESCRIPTION
Packit 13e616
*	Set a lid range for the given guid.
Packit 13e616
*
Packit 13e616
* SYNOPSIS
Packit 13e616
*/
Packit 13e616
int osm_db_guid2lid_set(IN osm_db_domain_t * p_g2l, IN uint64_t guid,
Packit 13e616
			IN uint16_t min_lid, IN uint16_t max_lid);
Packit 13e616
/*
Packit 13e616
* PARAMETERS
Packit 13e616
*	p_g2l
Packit 13e616
*		[in] Pointer to the guid2lid domain
Packit 13e616
*
Packit 13e616
*  guid
Packit 13e616
*     [in] The guid to look for
Packit 13e616
*
Packit 13e616
*  min_lid
Packit 13e616
*     [in] The min lid value to set
Packit 13e616
*
Packit 13e616
*  max_lid
Packit 13e616
*     [in] The max lid value to set
Packit 13e616
*
Packit 13e616
* RETURN VALUES
Packit 13e616
*	0 if successful
Packit 13e616
*
Packit 13e616
* SEE ALSO
Packit 13e616
* osm_db_guid2lid_init, osm_db_guid2lid_guids
Packit 13e616
* osm_db_guid2lid_get, osm_db_guid2lid_delete
Packit 13e616
*********/
Packit 13e616
Packit 13e616
/****f* OpenSM: DB-Pack/osm_db_guid2lid_delete
Packit 13e616
* NAME
Packit 13e616
*	osm_db_guid2lid_delete
Packit 13e616
*
Packit 13e616
* DESCRIPTION
Packit 13e616
*	Delete the entry by the given guid
Packit 13e616
*
Packit 13e616
* SYNOPSIS
Packit 13e616
*/
Packit 13e616
int osm_db_guid2lid_delete(IN osm_db_domain_t * p_g2l, IN uint64_t guid);
Packit 13e616
/*
Packit 13e616
* PARAMETERS
Packit 13e616
*	p_g2l
Packit 13e616
*		[in] Pointer to the guid2lid domain
Packit 13e616
*
Packit 13e616
*  guid
Packit 13e616
*     [in] The guid to look for
Packit 13e616
*
Packit 13e616
* RETURN VALUES
Packit 13e616
*	0 if successful otherwise 1
Packit 13e616
*
Packit 13e616
* SEE ALSO
Packit 13e616
* osm_db_guid2lid_init, osm_db_guid2lid_guids
Packit 13e616
* osm_db_guid2lid_get, osm_db_guid2lid_set
Packit 13e616
*********/
Packit 13e616
Packit 13e616
/****f* OpenSM: DB-Pack/osm_db_guid2mkey_init
Packit 13e616
* NAME
Packit 13e616
*	osm_db_guid2mkey_init
Packit 13e616
*
Packit 13e616
* DESCRIPTION
Packit 13e616
*	Initialize a domain for the guid2mkey table
Packit 13e616
*
Packit 13e616
* SYNOPSIS
Packit 13e616
*/
Packit 13e616
static inline osm_db_domain_t *osm_db_guid2mkey_init(IN osm_db_t * p_db)
Packit 13e616
{
Packit 13e616
	return osm_db_domain_init(p_db, "guid2mkey");
Packit 13e616
}
Packit 13e616
Packit 13e616
/*
Packit 13e616
* PARAMETERS
Packit 13e616
*	p_db
Packit 13e616
*		[in] Pointer to the database object to construct
Packit 13e616
*
Packit 13e616
* RETURN VALUES
Packit 13e616
*	The pointer to the new allocated domain object or NULL.
Packit 13e616
*
Packit 13e616
* NOTE: DB domains are destroyed by the osm_db_destroy
Packit 13e616
*
Packit 13e616
* SEE ALSO
Packit 13e616
*	Database, osm_db_init, osm_db_destroy
Packit 13e616
*********/
Packit 13e616
Packit 13e616
/****f* OpenSM: DB-Pack/osm_db_guid2mkey_guids
Packit 13e616
* NAME
Packit 13e616
*	osm_db_guid2mkey_guids
Packit 13e616
*
Packit 13e616
* DESCRIPTION
Packit 13e616
*	Provides back a list of guid elements.
Packit 13e616
*
Packit 13e616
* SYNOPSIS
Packit 13e616
*/
Packit 13e616
int osm_db_guid2mkey_guids(IN osm_db_domain_t * p_g2m,
Packit 13e616
			  OUT cl_qlist_t * p_guid_list);
Packit 13e616
/*
Packit 13e616
* PARAMETERS
Packit 13e616
*	p_g2l
Packit 13e616
*		[in] Pointer to the guid2mkey domain
Packit 13e616
*
Packit 13e616
*  p_guid_list
Packit 13e616
*     [out] A quick list of guid elements of type osm_db_guid_elem_t
Packit 13e616
*
Packit 13e616
* RETURN VALUES
Packit 13e616
*	0 if successful
Packit 13e616
*
Packit 13e616
* NOTE: the output qlist should be initialized and each item freed
Packit 13e616
*       by the caller, then destroyed.
Packit 13e616
*
Packit 13e616
* SEE ALSO
Packit 13e616
* osm_db_guid2mkey_init, osm_db_guid2mkey_guids, osm_db_guid2mkey_get
Packit 13e616
* osm_db_guid2mkey_set, osm_db_guid2mkey_delete
Packit 13e616
*********/
Packit 13e616
Packit 13e616
/****f* OpenSM: DB-Pack/osm_db_guid2mkey_get
Packit 13e616
* NAME
Packit 13e616
*	osm_db_guid2mkey_get
Packit 13e616
*
Packit 13e616
* DESCRIPTION
Packit 13e616
*	Get the mkey for the given guid.
Packit 13e616
*
Packit 13e616
* SYNOPSIS
Packit 13e616
*/
Packit 13e616
int osm_db_guid2mkey_get(IN osm_db_domain_t * p_g2m, IN uint64_t guid,
Packit 13e616
			 OUT uint64_t * p_mkey);
Packit 13e616
/*
Packit 13e616
* PARAMETERS
Packit 13e616
*	p_g2m
Packit 13e616
*		[in] Pointer to the guid2mkey domain
Packit 13e616
*
Packit 13e616
*  guid
Packit 13e616
*     [in] The guid to look for
Packit 13e616
*
Packit 13e616
*  p_mkey
Packit 13e616
*     [out] Pointer to the resulting mkey in host order.
Packit 13e616
*
Packit 13e616
* RETURN VALUES
Packit 13e616
*	0 if successful. The lid will be set to 0 if not found.
Packit 13e616
*
Packit 13e616
* SEE ALSO
Packit 13e616
* osm_db_guid2mkey_init, osm_db_guid2mkey_guids
Packit 13e616
* osm_db_guid2mkey_set, osm_db_guid2mkey_delete
Packit 13e616
*********/
Packit 13e616
Packit 13e616
/****f* OpenSM: DB-Pack/osm_db_guid2mkey_set
Packit 13e616
* NAME
Packit 13e616
*	osm_db_guid2mkey_set
Packit 13e616
*
Packit 13e616
* DESCRIPTION
Packit 13e616
*	Set the mkey for the given guid.
Packit 13e616
*
Packit 13e616
* SYNOPSIS
Packit 13e616
*/
Packit 13e616
int osm_db_guid2mkey_set(IN osm_db_domain_t * p_g2m, IN uint64_t guid,
Packit 13e616
			 IN uint64_t mkey);
Packit 13e616
/*
Packit 13e616
* PARAMETERS
Packit 13e616
*	p_g2m
Packit 13e616
*		[in] Pointer to the guid2mkey domain
Packit 13e616
*
Packit 13e616
*  guid
Packit 13e616
*     [in] The guid to look for
Packit 13e616
*
Packit 13e616
*  mkey
Packit 13e616
*     [in] The mkey value to set, in host order
Packit 13e616
*
Packit 13e616
* RETURN VALUES
Packit 13e616
*	0 if successful
Packit 13e616
*
Packit 13e616
* SEE ALSO
Packit 13e616
* osm_db_guid2mkey_init, osm_db_guid2mkey_guids
Packit 13e616
* osm_db_guid2mkey_get, osm_db_guid2mkey_delete
Packit 13e616
*********/
Packit 13e616
Packit 13e616
/****f* OpenSM: DB-Pack/osm_db_guid2mkey_delete
Packit 13e616
* NAME
Packit 13e616
*	osm_db_guid2mkey_delete
Packit 13e616
*
Packit 13e616
* DESCRIPTION
Packit 13e616
*	Delete the entry by the given guid
Packit 13e616
*
Packit 13e616
* SYNOPSIS
Packit 13e616
*/
Packit 13e616
int osm_db_guid2mkey_delete(IN osm_db_domain_t * p_g2m, IN uint64_t guid);
Packit 13e616
/*
Packit 13e616
* PARAMETERS
Packit 13e616
*	p_g2m
Packit 13e616
*		[in] Pointer to the guid2mkey domain
Packit 13e616
*
Packit 13e616
*  guid
Packit 13e616
*     [in] The guid to look for
Packit 13e616
*
Packit 13e616
* RETURN VALUES
Packit 13e616
*	0 if successful otherwise 1
Packit 13e616
*
Packit 13e616
* SEE ALSO
Packit 13e616
* osm_db_guid2mkey_init, osm_db_guid2mkey_guids
Packit 13e616
* osm_db_guid2mkey_get, osm_db_guid2mkey_set
Packit 13e616
*********/
Packit 13e616
Packit 13e616
/****f* OpenSM: DB-Pack/osm_db_neighbor_init
Packit 13e616
* NAME
Packit 13e616
*	osm_db_neighbor_init
Packit 13e616
*
Packit 13e616
* DESCRIPTION
Packit 13e616
*	Initialize a domain for the neighbors table
Packit 13e616
*
Packit 13e616
* SYNOPSIS
Packit 13e616
*/
Packit 13e616
static inline osm_db_domain_t *osm_db_neighbor_init(IN osm_db_t * p_db)
Packit 13e616
{
Packit 13e616
	return osm_db_domain_init(p_db, "neighbors");
Packit 13e616
}
Packit 13e616
Packit 13e616
/*
Packit 13e616
* PARAMETERS
Packit 13e616
*	p_db
Packit 13e616
*		[in] Pointer to the database object to construct
Packit 13e616
*
Packit 13e616
* RETURN VALUES
Packit 13e616
*	The pointer to the new allocated domain object or NULL.
Packit 13e616
*
Packit 13e616
* NOTE: DB domains are destroyed by the osm_db_destroy
Packit 13e616
*
Packit 13e616
* SEE ALSO
Packit 13e616
*	Database, osm_db_init, osm_db_destroy
Packit 13e616
*********/
Packit 13e616
Packit 13e616
/****f* OpenSM: DB-Pack/osm_db_neighbor_elem
Packit 13e616
* NAME
Packit 13e616
*	osm_db_neighbor_elem
Packit 13e616
*
Packit 13e616
* DESCRIPTION
Packit 13e616
*	Initialize a domain for the neighbor table
Packit 13e616
*
Packit 13e616
* SYNOPSIS
Packit 13e616
*/
Packit 13e616
typedef struct osm_db_neighbor_elem {
Packit 13e616
	cl_list_item_t item;
Packit 13e616
	uint64_t guid;
Packit 13e616
	uint8_t portnum;
Packit 13e616
} osm_db_neighbor_elem_t;
Packit 13e616
/*
Packit 13e616
* FIELDS
Packit 13e616
*	item
Packit 13e616
*		required for list manipulations
Packit 13e616
*
Packit 13e616
*  guid
Packit 13e616
*  portnum
Packit 13e616
*
Packit 13e616
************/
Packit 13e616
Packit 13e616
/****f* OpenSM: DB-Pack/osm_db_neighbor_guids
Packit 13e616
* NAME
Packit 13e616
*	osm_db_neighbor_guids
Packit 13e616
*
Packit 13e616
* DESCRIPTION
Packit 13e616
*	Provides back a list of neighbor elements.
Packit 13e616
*
Packit 13e616
* SYNOPSIS
Packit 13e616
*/
Packit 13e616
int osm_db_neighbor_guids(IN osm_db_domain_t * p_neighbor,
Packit 13e616
			  OUT cl_qlist_t * p_guid_list);
Packit 13e616
/*
Packit 13e616
* PARAMETERS
Packit 13e616
*	p_neighbor
Packit 13e616
*		[in] Pointer to the neighbor domain
Packit 13e616
*
Packit 13e616
*  p_guid_list
Packit 13e616
*     [out] A quick list of neighbor elements of type osm_db_neighbor_elem_t
Packit 13e616
*
Packit 13e616
* RETURN VALUES
Packit 13e616
*	0 if successful
Packit 13e616
*
Packit 13e616
* NOTE: the output qlist should be initialized and each item freed
Packit 13e616
*       by the caller, then destroyed.
Packit 13e616
*
Packit 13e616
* SEE ALSO
Packit 13e616
* osm_db_neighbor_init, osm_db_neighbor_guids, osm_db_neighbor_get
Packit 13e616
* osm_db_neighbor_set, osm_db_neighbor_delete
Packit 13e616
*********/
Packit 13e616
Packit 13e616
/****f* OpenSM: DB-Pack/osm_db_neighbor_get
Packit 13e616
* NAME
Packit 13e616
*	osm_db_neighbor_get
Packit 13e616
*
Packit 13e616
* DESCRIPTION
Packit 13e616
*	Get a neighbor's guid by given guid/port.
Packit 13e616
*
Packit 13e616
* SYNOPSIS
Packit 13e616
*/
Packit 13e616
int osm_db_neighbor_get(IN osm_db_domain_t * p_neighbor, IN uint64_t guid1,
Packit 13e616
			IN uint8_t port1, OUT uint64_t * p_guid2,
Packit 13e616
			OUT uint8_t * p_port2);
Packit 13e616
/*
Packit 13e616
* PARAMETERS
Packit 13e616
*	p_neighbor
Packit 13e616
*		[in] Pointer to the neighbor domain
Packit 13e616
*
Packit 13e616
*  guid1
Packit 13e616
*     [in] The guid to look for
Packit 13e616
*
Packit 13e616
*  port1
Packit 13e616
*     [in] The port to look for
Packit 13e616
*
Packit 13e616
*  p_guid2
Packit 13e616
*     [out] Pointer to the resulting guid of the neighboring port.
Packit 13e616
*
Packit 13e616
*  p_port2
Packit 13e616
*     [out] Pointer to the resulting port of the neighboring port.
Packit 13e616
*
Packit 13e616
* RETURN VALUES
Packit 13e616
*	0 if successful. The lid will be set to 0 if not found.
Packit 13e616
*
Packit 13e616
* SEE ALSO
Packit 13e616
* osm_db_neighbor_init, osm_db_neighbor_guids
Packit 13e616
* osm_db_neighbor_set, osm_db_neighbor_delete
Packit 13e616
*********/
Packit 13e616
Packit 13e616
/****f* OpenSM: DB-Pack/osm_db_neighbor_set
Packit 13e616
* NAME
Packit 13e616
*	osm_db_neighbor_set
Packit 13e616
*
Packit 13e616
* DESCRIPTION
Packit 13e616
*	Set up a relationship between two ports
Packit 13e616
*
Packit 13e616
* SYNOPSIS
Packit 13e616
*/
Packit 13e616
int osm_db_neighbor_set(IN osm_db_domain_t * p_neighbor, IN uint64_t guid1,
Packit 13e616
			IN uint8_t port1, IN uint64_t guid2, IN uint8_t port2);
Packit 13e616
/*
Packit 13e616
* PARAMETERS
Packit 13e616
*	p_neighbor
Packit 13e616
*		[in] Pointer to the neighbor domain
Packit 13e616
*
Packit 13e616
*  guid1
Packit 13e616
*     [in] The first guid in the relationship
Packit 13e616
*
Packit 13e616
*  port1
Packit 13e616
*     [in] The first port in the relationship
Packit 13e616
*
Packit 13e616
*  guid2
Packit 13e616
*     [in] The second guid in the relationship
Packit 13e616
*
Packit 13e616
*  port2
Packit 13e616
*     [in] The second port in the relationship
Packit 13e616
*
Packit 13e616
* RETURN VALUES
Packit 13e616
*	0 if successful
Packit 13e616
*
Packit 13e616
* SEE ALSO
Packit 13e616
* osm_db_neighbor_init, osm_db_neighbor_guids
Packit 13e616
* osm_db_neighbor_get, osm_db_neighbor_delete
Packit 13e616
*********/
Packit 13e616
Packit 13e616
/****f* OpenSM: DB-Pack/osm_db_neighbor_delete
Packit 13e616
* NAME
Packit 13e616
*	osm_db_neighbor_delete
Packit 13e616
*
Packit 13e616
* DESCRIPTION
Packit 13e616
*	Delete the relationship between two ports
Packit 13e616
*
Packit 13e616
* SYNOPSIS
Packit 13e616
*/
Packit 13e616
int osm_db_neighbor_delete(IN osm_db_domain_t * p_neighbor,
Packit 13e616
			   IN uint64_t guid, IN uint8_t port);
Packit 13e616
/*
Packit 13e616
* PARAMETERS
Packit 13e616
*	p_neighbor
Packit 13e616
*		[in] Pointer to the neighbor domain
Packit 13e616
*
Packit 13e616
*  guid
Packit 13e616
*     [in] The guid to look for
Packit 13e616
*
Packit 13e616
*  port
Packit 13e616
*     [in] The port to look for
Packit 13e616
*
Packit 13e616
* RETURN VALUES
Packit 13e616
*	0 if successful otherwise 1
Packit 13e616
*
Packit 13e616
* SEE ALSO
Packit 13e616
* osm_db_neighbor_init, osm_db_neighbor_guids
Packit 13e616
* osm_db_neighbor_get, osm_db_neighbor_set
Packit 13e616
*********/
Packit 13e616
Packit 13e616
END_C_DECLS
Packit 13e616
#endif				/* _OSM_DB_PACK_H_ */