Print out the memlock limit when we can't allocate memory
This commit was SVN r13372.
Этот коммит содержится в:
родитель
061ba05439
Коммит
ee753694e0
@ -40,6 +40,16 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <math.h>
|
#include <math.h>
|
||||||
#include <inttypes.h>
|
#include <inttypes.h>
|
||||||
|
#ifdef HAVE_SYS_TYPES_H
|
||||||
|
#include <sys/types.h>
|
||||||
|
#endif
|
||||||
|
#ifdef HAVE_SYS_TIME_H
|
||||||
|
#include <sys/time.h>
|
||||||
|
#endif
|
||||||
|
#ifdef HAVE_SYS_RESOURCE_H
|
||||||
|
#include <sys/resource.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
mca_btl_openib_module_t mca_btl_openib_module = {
|
mca_btl_openib_module_t mca_btl_openib_module = {
|
||||||
{
|
{
|
||||||
@ -78,9 +88,24 @@ static void show_init_error(const char *file, int line,
|
|||||||
const char *func, const char *dev)
|
const char *func, const char *dev)
|
||||||
{
|
{
|
||||||
if (ENOMEM == errno) {
|
if (ENOMEM == errno) {
|
||||||
|
int ret;
|
||||||
|
struct rlimit limit;
|
||||||
|
char *str_limit = NULL;
|
||||||
|
|
||||||
|
ret = getrlimit(RLIMIT_MEMLOCK, &limit);
|
||||||
|
if (0 != ret) {
|
||||||
|
asprintf(&str_limit, "Unknown");
|
||||||
|
} else if (limit.rlim_cur == RLIM_INFINITY) {
|
||||||
|
asprintf(&str_limit, "unlimited");
|
||||||
|
} else {
|
||||||
|
asprintf(&str_limit, "%d", limit.rlim_cur);
|
||||||
|
}
|
||||||
|
|
||||||
opal_show_help("help-mpi-btl-openib.txt", "init-fail-no-mem",
|
opal_show_help("help-mpi-btl-openib.txt", "init-fail-no-mem",
|
||||||
true, orte_system_info.nodename,
|
true, orte_system_info.nodename,
|
||||||
file, line, func, dev);
|
file, line, func, dev, str_limit);
|
||||||
|
|
||||||
|
if (NULL != str_limit) free(str_limit);
|
||||||
} else {
|
} else {
|
||||||
opal_show_help("help-mpi-btl-openib.txt", "init-fail-create-q",
|
opal_show_help("help-mpi-btl-openib.txt", "init-fail-create-q",
|
||||||
true, orte_system_info.nodename,
|
true, orte_system_info.nodename,
|
||||||
|
@ -98,10 +98,11 @@ locked memory. This typically can indicate that the memlock limits
|
|||||||
are set too low. For most HPC installations, the memlock limits
|
are set too low. For most HPC installations, the memlock limits
|
||||||
should be set to "unlimited". The failure occured here:
|
should be set to "unlimited". The failure occured here:
|
||||||
|
|
||||||
Host: %s
|
Host: %s
|
||||||
OMPI source: %s:%d
|
OMPI source: %s:%d
|
||||||
Function: %s()
|
Function: %s()
|
||||||
Device: %s
|
Device: %s
|
||||||
|
Memlock limit: %s
|
||||||
|
|
||||||
You may need to consult with your system administrator to get this
|
You may need to consult with your system administrator to get this
|
||||||
problem fixed. This FAQ entry on the Open MPI web site may also be
|
problem fixed. This FAQ entry on the Open MPI web site may also be
|
||||||
|
Загрузка…
x
Ссылка в новой задаче
Block a user