1
1

Merge pull request #3006 from rhc54/topic/lid

Support -host launch_id
Этот коммит содержится в:
Mark Santcroos 2017-02-18 09:46:24 +01:00 коммит произвёл GitHub
родитель 95bfc7b7c6 bf0f274f06
Коммит 7762c21c23

Просмотреть файл

@ -58,7 +58,7 @@ int orte_util_add_dash_host_nodes(opal_list_t *nodes,
bool found; bool found;
int slots=0; int slots=0;
bool slots_given; bool slots_given;
char *cptr; char *cptr, *ptr;
OPAL_OUTPUT_VERBOSE((1, orte_ras_base_framework.framework_output, OPAL_OUTPUT_VERBOSE((1, orte_ras_base_framework.framework_output,
"%s dashhost: parsing args %s", "%s dashhost: parsing args %s",
@ -213,12 +213,14 @@ int orte_util_add_dash_host_nodes(opal_list_t *nodes,
// Strip off the FQDN if present, ignore IP addresses // Strip off the FQDN if present, ignore IP addresses
if( !orte_keep_fqdn_hostnames && !opal_net_isaddr(ndname) ) { if( !orte_keep_fqdn_hostnames && !opal_net_isaddr(ndname) ) {
char *ptr;
if (NULL != (ptr = strchr(ndname, '.'))) { if (NULL != (ptr = strchr(ndname, '.'))) {
*ptr = '\0'; *ptr = '\0';
} }
} }
/* remove any modifier */
if (NULL != (ptr = strchr(ndname, ':'))) {
*ptr = '\0';
}
/* see if the node is already on the list */ /* see if the node is already on the list */
found = false; found = false;
OPAL_LIST_FOREACH(node, &adds, orte_node_t) { OPAL_LIST_FOREACH(node, &adds, orte_node_t) {
@ -422,13 +424,14 @@ int orte_util_filter_dash_host_nodes(opal_list_t *nodes,
opal_list_item_t* item; opal_list_item_t* item;
opal_list_item_t *next; opal_list_item_t *next;
orte_std_cntr_t i, j, len_mapped_node=0; orte_std_cntr_t i, j, len_mapped_node=0;
int rc; int rc, test;
char **mapped_nodes = NULL; char **mapped_nodes = NULL;
orte_node_t *node; orte_node_t *node;
int num_empty=0; int num_empty=0;
opal_list_t keep; opal_list_t keep;
bool want_all_empty=false; bool want_all_empty=false;
char *cptr; char *cptr;
size_t lst, lmn;
/* if the incoming node list is empty, then there /* if the incoming node list is empty, then there
* is nothing to filter! * is nothing to filter!
@ -505,19 +508,36 @@ int orte_util_filter_dash_host_nodes(opal_list_t *nodes,
item = next; item = next;
} }
} else { } else {
/* we are looking for a specific node on the list. The
* parser will have substituted our local name for any
* alias, so we only have to do a strcmp here */
item = opal_list_get_first(nodes);
while (item != opal_list_get_end(nodes)) {
next = opal_list_get_next(item); /* save this position */
node = (orte_node_t*)item;
/* remove any modifier */ /* remove any modifier */
if (NULL != (cptr = strchr(mapped_nodes[i], ':'))) { if (NULL != (cptr = strchr(mapped_nodes[i], ':'))) {
*cptr = '\0'; *cptr = '\0';
} }
/* we are looking for a specific node on the list. The
* parser will have substituted our local name for any
* alias, so we only have to do a strcmp here. */
lmn = strtol(mapped_nodes[i], &cptr, 10);
if (orte_managed_allocation && NULL != cptr) {
/* if we are only given a number, then we only test the
* number of matching characters starting from the rear
* of the mapped_nodes entry. This allows support for
* launch_id-based environments. For example, a hostname
* of "nid0015" can be referenced by "--host 15" */
lmn = strlen(mapped_nodes[i]);
} else {
lmn = 0;
}
item = opal_list_get_first(nodes);
while (item != opal_list_get_end(nodes)) {
next = opal_list_get_next(item); /* save this position */
node = (orte_node_t*)item;
/* search -host list to see if this one is found */ /* search -host list to see if this one is found */
if (0 == strcmp(node->name, mapped_nodes[i])) { if (0 < lmn) {
lst = strlen(node->name);
test = strncmp(node->name + lst - lmn, mapped_nodes[i], lmn);
} else {
test = strcmp(node->name, mapped_nodes[i]);
}
if (0 == test) {
if (remove) { if (remove) {
/* remove item from list */ /* remove item from list */
opal_list_remove_item(nodes, item); opal_list_remove_item(nodes, item);