blob: 0c13c2f0a08d23f0f3527d03609253eef7c7622a [file] [log] [blame]
/*****************************************************************************\
* federation_info.c - functions dealing with Federations in the controller.
*****************************************************************************
* Copyright (C) SchedMD LLC.
*
* This file is part of Slurm, a resource management program.
* For details, see <https://slurm.schedmd.com/>.
* Please also read the included file: DISCLAIMER.
*
* Slurm is free software; you can redistribute it and/or modify it under
* the terms of the GNU General Public License as published by the Free
* Software Foundation; either version 2 of the License, or (at your option)
* any later version.
*
* In addition, as a special exception, the copyright holders give permission
* to link the code of portions of this program with the OpenSSL library under
* certain conditions as described in each individual source file, and
* distribute linked combinations including the two. You must obey the GNU
* General Public License in all respects for all of the code used other than
* OpenSSL. If you modify file(s) with this exception, you may extend this
* exception to your version of the file(s), but you are not obligated to do
* so. If you do not wish to do so, delete this exception statement from your
* version. If you delete this exception statement from all source files in
* the program, then also delete it here.
*
* Slurm is distributed in the hope that it will be useful, but WITHOUT ANY
* WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
* FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
* details.
*
* You should have received a copy of the GNU General Public License along
* with Slurm; if not, write to the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
\*****************************************************************************/
#include "slurm/slurm.h"
#include "slurm/slurmdb.h"
#include "slurm/slurm_errno.h"
#include "src/common/read_config.h"
#include "src/common/slurm_protocol_api.h"
#include "src/common/xstring.h"
#include "src/common/xmalloc.h"
/*
* slurm_load_federation - issue RPC to get federation status from controller
* IN/OUT fed_pptr - place to store returned federation information.
* slurmdb_federation_rec_t treated as a void pointer to since
* slurm.h doesn't have ties to slurmdb.h.
* RET 0 or -1 on error
*/
extern int slurm_load_federation(void **fed_pptr)
{
int rc;
slurm_msg_t resp_msg;
slurm_msg_t req_msg;
slurm_msg_t_init(&req_msg);
slurm_msg_t_init(&resp_msg);
req_msg.msg_type = REQUEST_FED_INFO;
req_msg.data = NULL;
if (slurm_send_recv_controller_msg(&req_msg, &resp_msg,
working_cluster_rec) < 0)
return SLURM_ERROR;
switch (resp_msg.msg_type) {
case RESPONSE_FED_INFO:
*fed_pptr = resp_msg.data;
break;
case RESPONSE_SLURM_RC:
rc = ((return_code_msg_t *) resp_msg.data)->return_code;
slurm_free_return_code_msg(resp_msg.data);
if (rc)
slurm_seterrno_ret(rc);
break;
default:
slurm_seterrno_ret(SLURM_UNEXPECTED_MSG_ERROR);
break;
}
return SLURM_SUCCESS;
}
int _sort_clusters_by_name(void *x, void *y)
{
slurmdb_cluster_rec_t *c1 = *(slurmdb_cluster_rec_t **)x;
slurmdb_cluster_rec_t *c2 = *(slurmdb_cluster_rec_t **)y;
return (xstrcmp(c1->name, c2->name));
}
/*
* slurm_print_federation - prints slurmdb_federation_rec_t (passed as void*
* since slurm.h doesn't know about slurmdb.h).
*/
extern void slurm_print_federation(void *ptr)
{
list_itr_t *itr;
slurmdb_cluster_rec_t *cluster;
int left_col_size;
char *cluster_name = NULL;
slurmdb_federation_rec_t *fed = (slurmdb_federation_rec_t *)ptr;
if (!fed || !fed->name)
return;
if (working_cluster_rec)
cluster_name = working_cluster_rec->name;
else
cluster_name = slurm_conf.cluster_name;
left_col_size = strlen("federation:");
printf("%-*s %s\n", left_col_size, "Federation:",
fed->name);
list_sort(fed->cluster_list, (ListCmpF)_sort_clusters_by_name);
itr = list_iterator_create(fed->cluster_list);
/* Display local Cluster */
while ((cluster = list_next(itr))) {
char *features, *tmp_str;
if (xstrcmp(cluster->name, cluster_name))
continue;
features = slurm_char_list_to_xstr( cluster->fed.feature_list);
tmp_str = slurmdb_cluster_fed_states_str( cluster->fed.state);
printf("%-*s %s:%s:%d ID:%d FedState:%s Features:%s\n",
left_col_size, "Self:", cluster->name,
cluster->control_host ? cluster->control_host : "",
cluster->control_port,
cluster->fed.id, (tmp_str ? tmp_str : ""),
features ? features : "");
xfree(features);
break;
}
/* Display siblings */
list_iterator_reset(itr);
while ((cluster = list_next(itr))) {
char *tmp_str = NULL;
char *features = NULL;
if (!xstrcmp(cluster->name, cluster_name))
continue;
features = slurm_char_list_to_xstr(cluster->fed.feature_list);
tmp_str = slurmdb_cluster_fed_states_str(cluster->fed.state);
printf("%-*s %s:%s:%d ID:%d FedState:%s Features:%s PersistConnSend/Recv:%s/%s Synced:%s\n",
left_col_size, "Sibling:", cluster->name,
cluster->control_host ? cluster->control_host : "",
cluster->control_port,
cluster->fed.id, (tmp_str ? tmp_str : ""),
features ? features : "",
cluster->fed.send ? "Yes" : "No",
cluster->fed.recv ? "Yes" : "No",
cluster->fed.sync_recvd ? "Yes" : "No");
xfree(features);
}
list_iterator_destroy(itr);
}
/*
* slurm_destroy_federation_rec - Release memory allocated by
* slurm_load_federation()
*/
extern void slurm_destroy_federation_rec(void *fed)
{
slurmdb_destroy_federation_rec(fed);
}