1
1

83 строки
2.3 KiB
C
Исходник Обычный вид История

2015-01-25 20:16:45 -08:00
/*
* Copyright (c) 2015-2016 Intel, Inc. All rights reserved.
2015-01-25 20:16:45 -08:00
* $COPYRIGHT$
2015-06-23 20:59:57 -07:00
*
2015-01-25 20:16:45 -08:00
* Additional copyrights may follow
2015-06-23 20:59:57 -07:00
*
2015-01-25 20:16:45 -08:00
* $HEADER$
*/
/** @file:
* schizo framework base functionality.
2015-01-25 20:16:45 -08:00
*/
#ifndef ORTE_MCA_SCHIZO_BASE_H
#define ORTE_MCA_SCHIZO_BASE_H
2015-01-25 20:16:45 -08:00
/*
* includes
*/
#include "orte_config.h"
#include "orte/types.h"
#include "opal/class/opal_list.h"
#include "orte/mca/mca.h"
2015-01-25 20:16:45 -08:00
#include "orte/runtime/orte_globals.h"
#include "orte/mca/schizo/schizo.h"
2015-01-25 20:16:45 -08:00
BEGIN_C_DECLS
/*
* MCA Framework
*/
ORTE_DECLSPEC extern mca_base_framework_t orte_schizo_base_framework;
/* select all components */
ORTE_DECLSPEC int orte_schizo_base_select(void);
2015-01-25 20:16:45 -08:00
/**
* Struct to hold data global to the schizo framework
2015-01-25 20:16:45 -08:00
*/
typedef struct {
/* list of active modules */
opal_list_t active_modules;
char **personalities;
} orte_schizo_base_t;
2015-01-25 20:16:45 -08:00
/**
* Global instance of schizo-wide framework data
2015-01-25 20:16:45 -08:00
*/
ORTE_DECLSPEC extern orte_schizo_base_t orte_schizo_base;
2015-01-25 20:16:45 -08:00
/**
* Active schizo component / module
2015-01-25 20:16:45 -08:00
*/
typedef struct {
opal_list_item_t super;
int pri;
orte_schizo_base_module_t *module;
2015-01-25 20:16:45 -08:00
mca_base_component_t *component;
} orte_schizo_base_active_module_t;
OBJ_CLASS_DECLARATION(orte_schizo_base_active_module_t);
/* the base stub functions */
ORTE_DECLSPEC const char* orte_schizo_base_print_env(orte_schizo_launch_environ_t env);
ORTE_DECLSPEC int orte_schizo_base_define_cli(opal_cmd_line_t *cli);
ORTE_DECLSPEC int orte_schizo_base_parse_cli(int argc, int start, char **argv);
ORTE_DECLSPEC int orte_schizo_base_parse_env(char *path,
opal_cmd_line_t *cmd_line,
char **srcenv,
char ***dstenv);
ORTE_DECLSPEC int orte_schizo_base_setup_app(orte_app_context_t *app);
ORTE_DECLSPEC int orte_schizo_base_setup_fork(orte_job_t *jdata,
orte_app_context_t *context);
ORTE_DECLSPEC int orte_schizo_base_setup_child(orte_job_t *jobdat,
orte_proc_t *child,
orte_app_context_t *app);
ORTE_DECLSPEC orte_schizo_launch_environ_t orte_schizo_base_check_launch_environment(void);
ORTE_DECLSPEC void orte_schizo_base_finalize(void);
2015-01-25 20:16:45 -08:00
END_C_DECLS
#endif