1
1
openmpi/orte/util/hostfile/hostfile_lex.l
Ralph Castain 1dc12046f1 Modify the OMPI paffinity and mapping system to support socket-level mapping and binding. Mostly refactors existing code, with modifications to the odls_default module to support the new capabilities.
Adds several new mpirun options:

* -bysocket - assign ranks on a node by socket. Effectively load balances the procs assigned to a node across the available sockets. Note that ranks can still be bound to a specific core within the socket, or to the entire socket - the mapping is independent of the binding.

* -bind-to-socket - bind each rank to all the cores on the socket to which they are assigned.

* -bind-to-core - currently the default behavior (maintained from prior default)

* -npersocket N - launch N procs for every socket on a node. Note that this implies we know how many sockets are on a node. Mpirun will determine its local values. These can be overridden by provided values, either via MCA param or in a hostfile

Similar features/options are provided at the board level for multi-board nodes.

Documentation to follow...

This commit was SVN r21791.
2009-08-11 02:51:27 +00:00

185 строки
6.9 KiB
C

%{ /* -*- C -*- */
/*
* Copyright (c) 2004-2005 The Trustees of Indiana University and Indiana
* University Research and Technology
* Corporation. All rights reserved.
* Copyright (c) 2004-2006 The University of Tennessee and The University
* of Tennessee Research Foundation. All rights
* reserved.
* Copyright (c) 2004-2005 High Performance Computing Center Stuttgart,
* University of Stuttgart. All rights reserved.
* Copyright (c) 2004-2005 The Regents of the University of California.
* All rights reserved.
* $COPYRIGHT$
*
* Additional copyrights may follow
*
* $HEADER$
*/
#include "orte_config.h"
#include <stdio.h>
#ifdef HAVE_UNISTD_H
#include <unistd.h>
#endif
#include "orte/util/hostfile/hostfile_lex.h"
/*
* local functions
*/
#if defined(c_plusplus) || defined(__cplusplus)
extern "C" {
#endif /* defined(c_plusplus) || defined(__cplusplus) */
int orte_util_hostfile_wrap(void);
#if defined(c_plusplus) || defined(__cplusplus)
}
#endif /* defined(c_plusplus) || defined(__cplusplus) */
int orte_util_hostfile_wrap(void)
{
orte_util_hostfile_done = true;
return 1;
}
/*
* global variables
*/
int orte_util_hostfile_line=1;
orte_hostfile_value_t orte_util_hostfile_value;
bool orte_util_hostfile_done = false;
%}
WHITE [\f\t\v ]
%x comment
%%
{WHITE}*\n { orte_util_hostfile_line++;
return ORTE_HOSTFILE_NEWLINE; }
#.*\n { orte_util_hostfile_line++;
return ORTE_HOSTFILE_NEWLINE; }
"//".*\n { orte_util_hostfile_line++;
return ORTE_HOSTFILE_NEWLINE; }
"/*" { BEGIN(comment);
return ORTE_HOSTFILE_NEWLINE; }
<comment>[^*\n]* ; /* Eat up non '*'s */
<comment>"*"+[^*/\n]* ; /* Eat '*'s not followed by a '/' */
<comment>\n { orte_util_hostfile_line++;
return ORTE_HOSTFILE_NEWLINE; }
<comment>"*"+"/" { BEGIN(INITIAL); /* Done with Block Comment */
return ORTE_HOSTFILE_NEWLINE; }
\"[^\"]*\" { orte_util_hostfile_value.sval = yytext;
return ORTE_HOSTFILE_QUOTED_STRING; }
{WHITE}+ ; /* whitespace */
"=" { return ORTE_HOSTFILE_EQUAL; }
cpu { orte_util_hostfile_value.sval = yytext;
return ORTE_HOSTFILE_CPU; }
count { orte_util_hostfile_value.sval = yytext;
return ORTE_HOSTFILE_COUNT; }
slots { orte_util_hostfile_value.sval = yytext;
return ORTE_HOSTFILE_SLOTS; }
"slots-max" { orte_util_hostfile_value.sval = yytext;
return ORTE_HOSTFILE_SLOTS_MAX; }
slots_max { orte_util_hostfile_value.sval = yytext;
return ORTE_HOSTFILE_SLOTS_MAX; }
"max-slots" { orte_util_hostfile_value.sval = yytext;
return ORTE_HOSTFILE_SLOTS_MAX; }
max_slots { orte_util_hostfile_value.sval = yytext;
return ORTE_HOSTFILE_SLOTS_MAX; }
"cpu-max" { orte_util_hostfile_value.sval = yytext;
return ORTE_HOSTFILE_SLOTS_MAX; }
cpu_max { orte_util_hostfile_value.sval = yytext;
return ORTE_HOSTFILE_SLOTS_MAX; }
"max-cpu" { orte_util_hostfile_value.sval = yytext;
return ORTE_HOSTFILE_SLOTS_MAX; }
max_cpu { orte_util_hostfile_value.sval = yytext;
return ORTE_HOSTFILE_SLOTS_MAX; }
"count-max" { orte_util_hostfile_value.sval = yytext;
return ORTE_HOSTFILE_SLOTS_MAX; }
count_max { orte_util_hostfile_value.sval = yytext;
return ORTE_HOSTFILE_SLOTS_MAX; }
"max-count" { orte_util_hostfile_value.sval = yytext;
return ORTE_HOSTFILE_SLOTS_MAX; }
max_count { orte_util_hostfile_value.sval = yytext;
return ORTE_HOSTFILE_SLOTS_MAX; }
username { orte_util_hostfile_value.sval = yytext;
return ORTE_HOSTFILE_USERNAME; }
"user-name" { orte_util_hostfile_value.sval = yytext;
return ORTE_HOSTFILE_USERNAME; }
"user_name" { orte_util_hostfile_value.sval = yytext;
return ORTE_HOSTFILE_USERNAME; }
boards { orte_util_hostfile_value.sval = yytext;
return ORTE_HOSTFILE_BOARDS; }
sockets { orte_util_hostfile_value.sval = yytext;
return ORTE_HOSTFILE_SOCKETS_PER_BOARD; }
sockets_per_board { orte_util_hostfile_value.sval = yytext;
return ORTE_HOSTFILE_SOCKETS_PER_BOARD; }
"sockets-per-board" { orte_util_hostfile_value.sval = yytext;
return ORTE_HOSTFILE_SOCKETS_PER_BOARD; }
cores { orte_util_hostfile_value.sval = yytext;
return ORTE_HOSTFILE_CORES_PER_SOCKET; }
cores_per_socket { orte_util_hostfile_value.sval = yytext;
return ORTE_HOSTFILE_CORES_PER_SOCKET; }
"cores-per-socket" { orte_util_hostfile_value.sval = yytext;
return ORTE_HOSTFILE_CORES_PER_SOCKET; }
cpu_set { orte_util_hostfile_value.sval = yytext;
return ORTE_HOSTFILE_CPU_SET; }
"cpu-set" { orte_util_hostfile_value.sval = yytext;
return ORTE_HOSTFILE_CPU_SET; }
\+n[0-9]+ { orte_util_hostfile_value.sval = yytext;
return ORTE_HOSTFILE_RELATIVE; }
\+[eE][\:][0-9]+ { orte_util_hostfile_value.sval = yytext;
return ORTE_HOSTFILE_RELATIVE; }
\+[eE] { orte_util_hostfile_value.sval = yytext;
return ORTE_HOSTFILE_RELATIVE; }
[0-9]+ { orte_util_hostfile_value.ival = atol(yytext);
return ORTE_HOSTFILE_INT; }
%{ /* First detect hosts as standard Strings (but without ".")
* then username@IPv4 or IPV4, then username@IPv6 or IPv6,
* followed by username@hostname or hostname
*/
%}
[A-za-z0-9_\-,:*@]* { orte_util_hostfile_value.sval = yytext;
return ORTE_HOSTFILE_STRING; }
([A-Za-z0-9][A-Za-z0-9_\-]*"@")?([0-9]{1,3}"."){3}[0-9]{1,3} {
orte_util_hostfile_value.sval = yytext;
return ORTE_HOSTFILE_IPV4; }
([A-Za-z0-9][A-Za-z0-9_\-]*"@")?([A-Fa-f0-9]{0,4}":")+[":"]*([A-Fa-f0-9]{0,4}":")+[A-Fa-f0-9]{1,4} {
orte_util_hostfile_value.sval = yytext;
return ORTE_HOSTFILE_IPV6; }
(\^?[A-Za-z0-9][A-Za-z0-9_\-]*"@")?[A-Za-z][A-Za-z0-9_\-\.]* {
orte_util_hostfile_value.sval = yytext;
return ORTE_HOSTFILE_HOSTNAME; }
. { orte_util_hostfile_value.sval = yytext;
return ORTE_HOSTFILE_ERROR; }
%%