|
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_ */
|