2013-04-22 17:01:07 +00:00
|
|
|
/* -*- Mode: C; c-basic-offset:4 ; indent-tabs-mode:nil -*- */
|
|
|
|
/*
|
|
|
|
* Copyright (c) 2010 Cisco Systems, Inc. All rights reserved.
|
|
|
|
* Copyright (c) 2010 Oracle and/or its affiliates. All rights reserved.
|
|
|
|
* Copyright (c) 2012-2013 Los Alamos National Security, LLC.
|
2015-01-06 16:36:55 -08:00
|
|
|
* All rights reserved
|
|
|
|
* Copyright (c) 2015 Intel, Inc. All rights reserved.
|
2016-10-03 16:47:26 +09:00
|
|
|
* Copyright (c) 2017 Research Organization for Information Science
|
|
|
|
* and Technology (RIST). All rights reserved.
|
2017-06-29 21:18:46 -04:00
|
|
|
* Copyright (c) 2017 IBM Corporation. All rights reserved.
|
2016-10-03 16:47:26 +09:00
|
|
|
* $COPYRIGHT$
|
|
|
|
*
|
|
|
|
* Additional copyrights may follow
|
2013-04-22 17:01:07 +00:00
|
|
|
*/
|
|
|
|
#include "opal_config.h"
|
|
|
|
#include "opal/constants.h"
|
|
|
|
|
|
|
|
/* protect common defines */
|
|
|
|
#undef PACKAGE_BUGREPORT
|
|
|
|
#undef PACKAGE_NAME
|
|
|
|
#undef PACKAGE_STRING
|
|
|
|
#undef PACKAGE_TARNAME
|
|
|
|
#undef PACKAGE_VERSION
|
|
|
|
|
|
|
|
#include "libevent/config.h"
|
|
|
|
|
|
|
|
|
|
|
|
#ifdef HAVE_SYS_TYPES_H
|
|
|
|
#include <sys/types.h>
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
#ifdef WIN32
|
|
|
|
#define WIN32_LEAN_AND_MEAN
|
|
|
|
#include <windows.h>
|
|
|
|
#undef WIN32_LEAN_AND_MEAN
|
|
|
|
#endif
|
|
|
|
#ifdef HAVE_SYS_TIME_H
|
|
|
|
#include <sys/time.h>
|
|
|
|
#endif
|
|
|
|
#include <sys/queue.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#ifndef WIN32
|
|
|
|
#ifdef HAVE_UNISTD_H
|
|
|
|
#include <unistd.h>
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
#include <errno.h>
|
|
|
|
#include <signal.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <assert.h>
|
|
|
|
#include <time.h>
|
|
|
|
|
|
|
|
#include "opal/class/opal_object.h"
|
|
|
|
#include "opal/threads/mutex.h"
|
|
|
|
#include "opal/threads/threads.h"
|
|
|
|
#include "opal/util/output.h"
|
|
|
|
#include "opal/util/argv.h"
|
|
|
|
#include "opal/util/fd.h"
|
|
|
|
|
2015-01-06 16:36:55 -08:00
|
|
|
#include "libevent2022.h"
|
2013-04-22 17:01:07 +00:00
|
|
|
#include "opal/mca/event/base/base.h"
|
|
|
|
|
|
|
|
#include "libevent/event.h"
|
|
|
|
#include "libevent/event-internal.h"
|
|
|
|
|
|
|
|
#include "opal/mca/event/event.h"
|
|
|
|
|
|
|
|
static struct event_config *config=NULL;
|
2017-06-29 21:18:46 -04:00
|
|
|
extern char *ompi_event_module_include;
|
|
|
|
extern const struct eventop *ompi_eventops[];
|
2013-04-22 17:01:07 +00:00
|
|
|
|
|
|
|
opal_event_base_t* opal_event_base_create(void)
|
|
|
|
{
|
|
|
|
opal_event_base_t *base;
|
|
|
|
|
|
|
|
base = event_base_new_with_config(config);
|
|
|
|
if (NULL == base) {
|
|
|
|
/* there is no backend method that does what we want */
|
|
|
|
opal_output(0, "No event method available");
|
|
|
|
}
|
|
|
|
return base;
|
|
|
|
}
|
|
|
|
|
|
|
|
int opal_event_init(void)
|
|
|
|
{
|
|
|
|
char **includes=NULL;
|
|
|
|
bool dumpit=false;
|
|
|
|
int i, j;
|
|
|
|
|
|
|
|
if (opal_output_get_verbosity(opal_event_base_framework.framework_output) > 4) {
|
|
|
|
event_enable_debug_mode();
|
|
|
|
dumpit = true;
|
|
|
|
}
|
|
|
|
|
2017-06-29 21:18:46 -04:00
|
|
|
if (NULL == ompi_event_module_include) {
|
2013-04-22 17:01:07 +00:00
|
|
|
/* Shouldn't happen, but... */
|
2017-06-29 21:18:46 -04:00
|
|
|
ompi_event_module_include = strdup("select");
|
2013-04-22 17:01:07 +00:00
|
|
|
}
|
2017-06-29 21:18:46 -04:00
|
|
|
includes = opal_argv_split(ompi_event_module_include,',');
|
2013-04-22 17:01:07 +00:00
|
|
|
|
|
|
|
/* get a configuration object */
|
|
|
|
config = event_config_new();
|
|
|
|
/* cycle thru the available subsystems */
|
2017-06-29 21:18:46 -04:00
|
|
|
for (i = 0 ; NULL != ompi_eventops[i] ; ++i) {
|
2013-04-22 17:01:07 +00:00
|
|
|
/* if this module isn't included in the given ones,
|
|
|
|
* then exclude it
|
|
|
|
*/
|
|
|
|
dumpit = true;
|
|
|
|
for (j=0; NULL != includes[j]; j++) {
|
|
|
|
if (0 == strcmp("all", includes[j]) ||
|
2017-06-29 21:18:46 -04:00
|
|
|
0 == strcmp(ompi_eventops[i]->name, includes[j])) {
|
2013-04-22 17:01:07 +00:00
|
|
|
dumpit = false;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (dumpit) {
|
2017-06-29 21:18:46 -04:00
|
|
|
event_config_avoid_method(config, ompi_eventops[i]->name);
|
2013-04-22 17:01:07 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
opal_argv_free(includes);
|
|
|
|
|
|
|
|
return OPAL_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2016-10-03 16:47:26 +09:00
|
|
|
int opal_event_finalize(void)
|
|
|
|
{
|
|
|
|
event_config_free(config);
|
|
|
|
return OPAL_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2013-04-22 17:01:07 +00:00
|
|
|
opal_event_t* opal_event_alloc(void)
|
|
|
|
{
|
|
|
|
opal_event_t *ev;
|
|
|
|
|
|
|
|
ev = (opal_event_t*)malloc(sizeof(opal_event_t));
|
|
|
|
return ev;
|
|
|
|
}
|