1
1

Merge pull request #5317 from jsquyres/pr/update-bind-to-cpulist-option

orterun: use consistent CLI option name for --bind-to
Этот коммит содержится в:
Jeff Squyres 2018-06-21 12:43:18 -04:00 коммит произвёл GitHub
родитель fb16d40775 4603852740
Коммит e305e80aff
Не найден ключ, соответствующий данной подписи
Идентификатор ключа GPG: 4AEE18F83AFDEB23
3 изменённых файлов: 23 добавлений и 14 удалений

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

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2011-2017 Cisco Systems, Inc. All rights reserved * Copyright (c) 2011-2018 Cisco Systems, Inc. All rights reserved
* Copyright (c) 2013-2018 Intel, Inc. All rights reserved. * Copyright (c) 2013-2018 Intel, Inc. All rights reserved.
* Copyright (c) 2016-2017 Research Organization for Information Science * Copyright (c) 2016-2017 Research Organization for Information Science
* and Technology (RIST). All rights reserved. * and Technology (RIST). All rights reserved.
@ -119,7 +119,7 @@ static int opal_hwloc_base_register(mca_base_register_flag_t flags)
opal_hwloc_base_binding_policy = NULL; opal_hwloc_base_binding_policy = NULL;
(void) mca_base_var_register("opal", "hwloc", "base", "binding_policy", (void) mca_base_var_register("opal", "hwloc", "base", "binding_policy",
"Policy for binding processes. Allowed values: none, hwthread, core, l1cache, l2cache, " "Policy for binding processes. Allowed values: none, hwthread, core, l1cache, l2cache, "
"l3cache, socket, numa, board, cpuset (\"none\" is the default when oversubscribed, \"core\" is " "l3cache, socket, numa, board, cpu-list (\"none\" is the default when oversubscribed, \"core\" is "
"the default when np<=2, and \"numa\" is the default when np>2). Allowed qualifiers: " "the default when np<=2, and \"numa\" is the default when np>2). Allowed qualifiers: "
"overload-allowed, if-supported, ordered", "overload-allowed, if-supported, ordered",
MCA_BASE_VAR_TYPE_STRING, NULL, 0, 0, OPAL_INFO_LVL_9, MCA_BASE_VAR_TYPE_STRING, NULL, 0, 0, OPAL_INFO_LVL_9,
@ -536,7 +536,11 @@ int opal_hwloc_base_set_binding_policy(opal_binding_policy_t *policy, char *spec
OPAL_SET_BINDING_POLICY(tmp, OPAL_BIND_TO_NUMA); OPAL_SET_BINDING_POLICY(tmp, OPAL_BIND_TO_NUMA);
} else if (0 == strcasecmp(tmpvals[0], "board")) { } else if (0 == strcasecmp(tmpvals[0], "board")) {
OPAL_SET_BINDING_POLICY(tmp, OPAL_BIND_TO_BOARD); OPAL_SET_BINDING_POLICY(tmp, OPAL_BIND_TO_BOARD);
} else if (0 == strcasecmp(tmpvals[0], "cpuset")) { } else if (0 == strcasecmp(tmpvals[0], "cpu-list") ||
0 == strcasecmp(tmpvals[0], "cpulist")) {
// Accept both "cpu-list" (which matches the
// "--cpu-list" CLI option) and "cpulist" (because
// people will be lazy)
OPAL_SET_BINDING_POLICY(tmp, OPAL_BIND_TO_CPUSET); OPAL_SET_BINDING_POLICY(tmp, OPAL_BIND_TO_CPUSET);
} else { } else {
opal_show_help("help-opal-hwloc-base.txt", "invalid binding_policy", true, "binding", spec); opal_show_help("help-opal-hwloc-base.txt", "invalid binding_policy", true, "binding", spec);

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

@ -11,7 +11,7 @@
* All rights reserved. * All rights reserved.
* Copyright (c) 2006-2017 Los Alamos National Security, LLC. * Copyright (c) 2006-2017 Los Alamos National Security, LLC.
* All rights reserved. * All rights reserved.
* Copyright (c) 2009-2016 Cisco Systems, Inc. All rights reserved. * Copyright (c) 2009-2018 Cisco Systems, Inc. All rights reserved
* Copyright (c) 2011-2017 Oak Ridge National Labs. All rights reserved. * Copyright (c) 2011-2017 Oak Ridge National Labs. All rights reserved.
* Copyright (c) 2017 UT-Battelle, LLC. All rights reserved. * Copyright (c) 2017 UT-Battelle, LLC. All rights reserved.
* Copyright (c) 2013-2018 Intel, Inc. All rights reserved. * Copyright (c) 2013-2018 Intel, Inc. All rights reserved.
@ -337,7 +337,7 @@ static opal_cmd_line_init_t cmd_line_init[] = {
/* Binding options */ /* Binding options */
{ "hwloc_base_binding_policy", '\0', NULL, "bind-to", 1, { "hwloc_base_binding_policy", '\0', NULL, "bind-to", 1,
&orte_cmd_options.binding_policy, OPAL_CMD_LINE_TYPE_STRING, &orte_cmd_options.binding_policy, OPAL_CMD_LINE_TYPE_STRING,
"Policy for binding processes. Allowed values: none, hwthread, core, l1cache, l2cache, l3cache, socket, numa, board, cpuset (\"none\" is the default when oversubscribed, \"core\" is the default when np<=2, and \"socket\" is the default when np>2). Allowed qualifiers: overload-allowed, if-supported, ordered", OPAL_CMD_LINE_OTYPE_BINDING }, "Policy for binding processes. Allowed values: none, hwthread, core, l1cache, l2cache, l3cache, socket, numa, board, cpu-list (\"none\" is the default when oversubscribed, \"core\" is the default when np<=2, and \"socket\" is the default when np>2). Allowed qualifiers: overload-allowed, if-supported, ordered", OPAL_CMD_LINE_OTYPE_BINDING },
/* backward compatiblity */ /* backward compatiblity */
{ "hwloc_base_bind_to_core", '\0', "bind-to-core", "bind-to-core", 0, { "hwloc_base_bind_to_core", '\0', "bind-to-core", "bind-to-core", 0,

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

@ -341,7 +341,10 @@ MPI_COMM_WORLD ranks in a round-robin, "by node" manner.
. .
.TP .TP
.B -cpu-list\fR,\fP --cpu-list \fR<cpus>\fP .B -cpu-list\fR,\fP --cpu-list \fR<cpus>\fP
List of processor IDs to bind processes to [default=NULL]. Comma-delimited list of processor IDs to which to bind processes
[default=NULL]. Processor IDs are interpreted as hwloc logical core
IDs. Run the hwloc \fIlstopo(1)\fR command to see a list of available
cores and their logical IDs.
. .
. .
. .
@ -366,7 +369,7 @@ For process binding:
.TP .TP
.B --bind-to \fR<foo>\fP .B --bind-to \fR<foo>\fP
Bind processes to the specified object, defaults to \fIcore\fP. Supported options Bind processes to the specified object, defaults to \fIcore\fP. Supported options
include slot, hwthread, core, l1cache, l2cache, l3cache, socket, numa, board, cpuset, and none. include slot, hwthread, core, l1cache, l2cache, l3cache, socket, numa, board, cpu-list, and none.
. .
.TP .TP
.B -cpus-per-proc\fR,\fP --cpus-per-proc \fR<#perproc>\fP .B -cpus-per-proc\fR,\fP --cpus-per-proc \fR<#perproc>\fP
@ -1149,13 +1152,15 @@ cause the process to be bound to the processors that share a single L3
cache within that socket. cache within that socket.
. .
.PP .PP
Alternatively, processes can be assigned to processors based on Alternatively, processes can be assigned to processors based on their
their local rank on a node using the \fI--bind-to cpuset:ordered\fP option local rank on a node using the \fI--bind-to cpu-list:ordered\fP option
with an associated \fI--cpu-list "0,2,5"\fP. This directs that the first with an associated \fI--cpu-list "0,2,5"\fP. In this example, the
rank on a node be bound to cpu0, the second rank on the node be bound first process on a node will be bound to cpu 0, the second process on
to cpu1, and the third rank on the node be bound to cpu5. Note that an the node will be bound to cpu 2, and the third process on the node
error will result if more processes are assigned to a node than cpus will be bound to cpu 5. \fI--bind-to\fP will also accept
are provided. \fIcpulist:ortered\fP as a synonym to \fIcpu-list:ordered\fP. Note
that an error will result if more processes are assigned to a node
than cpus are provided.
. .
.PP .PP
To help balance loads, the binding directive uses a round-robin method when binding to To help balance loads, the binding directive uses a round-robin method when binding to