/* * Copyright (c) 2004-2008 The Trustees of Indiana University and Indiana * University Research and Technology * Corporation. All rights reserved. * Copyright (c) 2004-2005 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$ */ /** @file: * * The Open RTE Resource MAPping Subsystem (RMAPS) * * The resource mapping subsystem is responsible for mapping processes * to specific nodes/cpus within a given job. In many systems, this * functionality will not be supported - the system will map processes * wherever it chooses and does not allow the user to specify the * mapping. RMAPS components, therefore, provide services for those * systems that do permit such mappings. * * RMAPS checks the MCA parameters to see if a mapping algorithm has * been specified. If the user selected a mapping algorithm, the * indicated RMAPS component will take information from the registry * to determine the number of applications/processes to be run, and * the identified resources that have been allocated to this job. The * selected RMAP component will then assign processes to resources * according to its algorithm, with the results stored on the * appropriate job segment - the assigned nodename for each process is * stored in that respective process' container on the segment. * */ #ifndef ORTE_MCA_RMAPS_H #define ORTE_MCA_RMAPS_H #include "orte_config.h" #include "orte/types.h" #include "opal/mca/mca.h" #include "orte/runtime/orte_globals.h" #include "orte/mca/rmaps/rmaps_types.h" BEGIN_C_DECLS /* * rmaps module functions */ /** * Public API */ typedef int (*orte_rmaps_base_API_map_fn_t)(orte_job_t *jdata); typedef orte_job_map_t* (*orte_rmaps_base_API_get_job_map_fn_t)(orte_jobid_t job); /* global structure for accessing RMAPS API's */ typedef struct { orte_rmaps_base_API_map_fn_t map_job; orte_rmaps_base_API_get_job_map_fn_t get_job_map; } orte_rmaps_t; ORTE_DECLSPEC extern orte_rmaps_t orte_rmaps; /** * RMAPS module functions - these are not accessible to the outside world, * but are defined here by convention */ typedef int (*orte_rmaps_base_module_map_fn_t)(orte_job_t *jdata); /* * rmaps module version 1.3.0 */ struct orte_rmaps_base_module_1_3_0_t { /** Mapping function pointer */ orte_rmaps_base_module_map_fn_t map_job; }; /** Convenience typedef */ typedef struct orte_rmaps_base_module_1_3_0_t orte_rmaps_base_module_1_3_0_t; /** Convenience typedef */ typedef orte_rmaps_base_module_1_3_0_t orte_rmaps_base_module_t; /* * rmaps component */ /** * rmaps component version 1.3.0 */ struct orte_rmaps_base_component_1_3_0_t { /** Base MCA structure */ mca_base_component_t base_version; /** Base MCA data */ mca_base_component_data_1_0_0_t base_data; }; /** Convenience typedef */ typedef struct orte_rmaps_base_component_1_3_0_t orte_rmaps_base_component_1_3_0_t; /** Convenience typedef */ typedef orte_rmaps_base_component_1_3_0_t orte_rmaps_base_component_t; /** * Macro for use in components that are of type rmaps v1.0.0 */ #define ORTE_RMAPS_BASE_VERSION_1_3_0 \ /* rmaps v1.3 is chained to MCA v1.0 */ \ MCA_BASE_VERSION_1_0_0, \ /* rmaps v1.3 */ \ "rmaps", 1, 3, 0 END_C_DECLS #endif