2004-08-02 00:24:22 +00:00
|
|
|
/*
|
2005-11-05 19:57:48 +00:00
|
|
|
* Copyright (c) 2004-2005 The Trustees of Indiana University and Indiana
|
|
|
|
* University Research and Technology
|
|
|
|
* Corporation. All rights reserved.
|
|
|
|
* Copyright (c) 2004-2005 The University of Tennessee and The University
|
|
|
|
* of Tennessee Research Foundation. All rights
|
|
|
|
* reserved.
|
2004-11-28 20:09:25 +00:00
|
|
|
* Copyright (c) 2004-2005 High Performance Computing Center Stuttgart,
|
|
|
|
* University of Stuttgart. All rights reserved.
|
2005-03-24 12:43:37 +00:00
|
|
|
* Copyright (c) 2004-2005 The Regents of the University of California.
|
|
|
|
* All rights reserved.
|
2004-11-22 01:38:40 +00:00
|
|
|
* $COPYRIGHT$
|
|
|
|
*
|
|
|
|
* Additional copyrights may follow
|
|
|
|
*
|
2004-08-02 00:24:22 +00:00
|
|
|
* $HEADER$
|
|
|
|
*/
|
|
|
|
|
2006-02-12 01:33:29 +00:00
|
|
|
#include "opal_config.h"
|
2004-08-02 00:24:22 +00:00
|
|
|
|
|
|
|
#include <string.h>
|
|
|
|
|
2006-02-12 01:33:29 +00:00
|
|
|
#include "opal/mca/mca.h"
|
|
|
|
#include "opal/mca/base/base.h"
|
2004-08-02 00:24:22 +00:00
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Function for comparing two mca_base_component_priority_t structs so
|
|
|
|
* that we can build prioritized listss of them. This assumed that
|
|
|
|
* the types of the modules are the same. Sort first by priority,
|
|
|
|
* second by module name, third by module version.
|
|
|
|
*
|
|
|
|
* Note that we acutally want a *reverse* ordering here -- the al_*
|
|
|
|
* functions will put "smaller" items at the head, and "larger" items
|
|
|
|
* at the tail. Since we want the highest priority at the head, it
|
|
|
|
* may help the gentle reader to consider this an inverse comparison.
|
|
|
|
* :-)
|
|
|
|
*/
|
|
|
|
int
|
|
|
|
mca_base_component_compare_priority(mca_base_component_priority_list_item_t *a,
|
|
|
|
mca_base_component_priority_list_item_t *b)
|
|
|
|
{
|
|
|
|
/* First, compare the priorties */
|
|
|
|
|
|
|
|
if (a->cpli_priority > b->cpli_priority) {
|
|
|
|
return -1;
|
|
|
|
} else if (a->cpli_priority < b->cpli_priority) {
|
|
|
|
return 1;
|
|
|
|
} else {
|
2004-11-12 16:55:41 +00:00
|
|
|
return mca_base_component_compare(a->super.cli_component,
|
|
|
|
b->super.cli_component);
|
2004-08-02 00:24:22 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
int mca_base_component_compare(const mca_base_component_t* aa,
|
|
|
|
const mca_base_component_t* bb)
|
|
|
|
{
|
2007-08-16 16:51:41 +00:00
|
|
|
int val;
|
|
|
|
|
|
|
|
val = strncmp(aa->mca_type_name, bb->mca_type_name,
|
|
|
|
MCA_BASE_MAX_TYPE_NAME_LEN);
|
|
|
|
if (val != 0) {
|
|
|
|
return -val;
|
|
|
|
}
|
|
|
|
|
|
|
|
val = strncmp(aa->mca_component_name, bb->mca_component_name,
|
2004-08-02 00:24:22 +00:00
|
|
|
MCA_BASE_MAX_COMPONENT_NAME_LEN);
|
|
|
|
if (val != 0) {
|
|
|
|
return -val;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* The names were equal, so compare the versions */
|
|
|
|
|
|
|
|
if (aa->mca_component_major_version >
|
|
|
|
bb->mca_component_major_version) {
|
|
|
|
return -1;
|
|
|
|
} else if (aa->mca_component_major_version <
|
|
|
|
bb->mca_component_major_version) {
|
|
|
|
return 1;
|
|
|
|
} else if (aa->mca_component_minor_version >
|
|
|
|
bb->mca_component_minor_version) {
|
|
|
|
return -1;
|
|
|
|
} else if (aa->mca_component_minor_version <
|
|
|
|
bb->mca_component_minor_version) {
|
|
|
|
return 1;
|
|
|
|
} else if (aa->mca_component_release_version >
|
|
|
|
bb->mca_component_release_version) {
|
|
|
|
return -1;
|
|
|
|
} else if (aa->mca_component_release_version <
|
|
|
|
bb->mca_component_release_version) {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2007-08-16 16:51:41 +00:00
|
|
|
|
2004-10-14 20:50:06 +00:00
|
|
|
/**
|
|
|
|
* compare but exclude the release version - declare compatible
|
|
|
|
* if the major/minor version are the same.
|
|
|
|
*/
|
|
|
|
int mca_base_component_compatible(
|
|
|
|
const mca_base_component_t* aa,
|
|
|
|
const mca_base_component_t* bb)
|
|
|
|
{
|
2007-08-16 16:51:41 +00:00
|
|
|
int val;
|
|
|
|
|
|
|
|
val = strncmp(aa->mca_type_name, bb->mca_type_name,
|
|
|
|
MCA_BASE_MAX_TYPE_NAME_LEN);
|
|
|
|
if (val != 0) {
|
|
|
|
return -val;
|
|
|
|
}
|
|
|
|
|
|
|
|
val = strncmp(aa->mca_component_name, bb->mca_component_name,
|
|
|
|
MCA_BASE_MAX_COMPONENT_NAME_LEN);
|
2004-10-14 20:50:06 +00:00
|
|
|
if (val != 0) {
|
|
|
|
return -val;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* The names were equal, so compare the versions */
|
|
|
|
|
|
|
|
if (aa->mca_component_major_version >
|
|
|
|
bb->mca_component_major_version) {
|
|
|
|
return -1;
|
|
|
|
} else if (aa->mca_component_major_version <
|
|
|
|
bb->mca_component_major_version) {
|
|
|
|
return 1;
|
|
|
|
} else if (aa->mca_component_minor_version >
|
|
|
|
bb->mca_component_minor_version) {
|
|
|
|
return -1;
|
|
|
|
} else if (aa->mca_component_minor_version <
|
|
|
|
bb->mca_component_minor_version) {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2008-02-28 01:57:57 +00:00
|
|
|
/**
|
|
|
|
* Returns a string which represents the component name and version.
|
|
|
|
* Has the form: comp_type.comp_name.major_version.minor_version
|
|
|
|
*/
|
|
|
|
char * mca_base_component_to_string(const mca_base_component_t *a) {
|
|
|
|
char * str = NULL;
|
|
|
|
if(0 > asprintf(&str, "%s.%s.%d.%d", a->mca_type_name,
|
|
|
|
a->mca_component_name, a->mca_component_major_version,
|
|
|
|
a->mca_component_minor_version)) {
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
return str;
|
|
|
|
}
|
2004-10-14 20:50:06 +00:00
|
|
|
|