Correctly handle list of cores specified in the rankfile - i.e., a rankfile entry such as:
rank 0=foo slot=0:0-1;1:0,1 cmr:v1.7.3:reviewer=jsquyres This commit was SVN r29152.
This commit is contained in:
parent
c9f05a2664
commit
46ed907003
@ -1073,9 +1073,9 @@ static int socket_core_to_cpu_set(char *socket_core_list,
|
||||
hwloc_topology_t topo,
|
||||
hwloc_bitmap_t cpumask)
|
||||
{
|
||||
int rc=OPAL_SUCCESS, i;
|
||||
int rc=OPAL_SUCCESS, i, j;
|
||||
char **socket_core, *corestr;
|
||||
char **range;
|
||||
char **range, **list;
|
||||
int range_cnt;
|
||||
int lower_range, upper_range;
|
||||
int socket_id, core_id;
|
||||
@ -1121,18 +1121,22 @@ static int socket_core_to_cpu_set(char *socket_core_list,
|
||||
range_cnt = opal_argv_count(range);
|
||||
/* see if a range was set or not */
|
||||
switch (range_cnt) {
|
||||
case 1: /* only one core specified */
|
||||
core_id = atoi(range[0]);
|
||||
/* get that object */
|
||||
idx = 0;
|
||||
if (NULL == (core = df_search(topo, socket, obj_type, 0,
|
||||
core_id, OPAL_HWLOC_AVAILABLE,
|
||||
&idx, NULL))) {
|
||||
return OPAL_ERR_NOT_FOUND;
|
||||
case 1: /* only one core, or a list of cores, specified */
|
||||
list = opal_argv_split(range[0], ',');
|
||||
for (j=0; NULL != list[j]; j++) {
|
||||
core_id = atoi(list[j]);
|
||||
/* get that object */
|
||||
idx = 0;
|
||||
if (NULL == (core = df_search(topo, socket, obj_type, 0,
|
||||
core_id, OPAL_HWLOC_AVAILABLE,
|
||||
&idx, NULL))) {
|
||||
return OPAL_ERR_NOT_FOUND;
|
||||
}
|
||||
/* get the cpus */
|
||||
res = opal_hwloc_base_get_available_cpus(topo, core);
|
||||
hwloc_bitmap_or(cpumask, cpumask, res);
|
||||
}
|
||||
/* get the cpus */
|
||||
res = opal_hwloc_base_get_available_cpus(topo, core);
|
||||
hwloc_bitmap_or(cpumask, cpumask, res);
|
||||
opal_argv_free(list);
|
||||
break;
|
||||
|
||||
case 2: /* range of core id's was given */
|
||||
@ -1174,10 +1178,10 @@ int opal_hwloc_base_slot_list_parse(const char *slot_str,
|
||||
hwloc_cpuset_t cpumask)
|
||||
{
|
||||
char **item;
|
||||
int rc, i;
|
||||
int rc, i, j;
|
||||
hwloc_obj_t pu;
|
||||
hwloc_cpuset_t pucpus;
|
||||
char **range;
|
||||
char **range, **list;
|
||||
size_t range_cnt;
|
||||
int core_id, lower_range, upper_range;
|
||||
|
||||
@ -1243,18 +1247,22 @@ int opal_hwloc_base_slot_list_parse(const char *slot_str,
|
||||
range_cnt = opal_argv_count(range);
|
||||
/* see if a range was set or not */
|
||||
switch (range_cnt) {
|
||||
case 1: /* only one core specified */
|
||||
core_id = atoi(range[0]);
|
||||
/* find the specified logical available cpu */
|
||||
if (NULL == (pu = get_pu(topo, core_id))) {
|
||||
opal_argv_free(range);
|
||||
opal_argv_free(item);
|
||||
return OPAL_ERROR;
|
||||
case 1: /* only one core, or a list of cores, specified */
|
||||
list = opal_argv_split(range[0], ',');
|
||||
for (j=0; NULL != list[j]; j++) {
|
||||
core_id = atoi(list[j]);
|
||||
/* find the specified logical available cpu */
|
||||
if (NULL == (pu = get_pu(topo, core_id))) {
|
||||
opal_argv_free(range);
|
||||
opal_argv_free(item);
|
||||
return OPAL_ERROR;
|
||||
}
|
||||
/* get the available cpus for that object */
|
||||
pucpus = opal_hwloc_base_get_available_cpus(topo, pu);
|
||||
/* set that in the mask */
|
||||
hwloc_bitmap_or(cpumask, cpumask, pucpus);
|
||||
}
|
||||
/* get the available cpus for that object */
|
||||
pucpus = opal_hwloc_base_get_available_cpus(topo, pu);
|
||||
/* set that in the mask */
|
||||
hwloc_bitmap_or(cpumask, cpumask, pucpus);
|
||||
opal_argv_free(list);
|
||||
break;
|
||||
|
||||
case 2: /* range of core id's was given */
|
||||
|
Loading…
Reference in New Issue
Block a user