File: base.h

package info (click to toggle)
openmpi 1.6.5-9.1%2Bdeb8u1
  • links: PTS, VCS
  • area: main
  • in suites: jessie
  • size: 91,628 kB
  • ctags: 44,305
  • sloc: ansic: 408,966; cpp: 44,454; sh: 27,828; makefile: 10,486; asm: 3,882; python: 1,239; lex: 805; perl: 549; csh: 253; fortran: 232; f90: 126; tcl: 12
file content (166 lines) | stat: -rw-r--r-- 5,358 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
/*
 * 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 (c) 2011 Cisco Systems, Inc.  All rights reserved.
 * $COPYRIGHT$
 * 
 * Additional copyrights may follow
 * 
 * $HEADER$
 *
 */

#ifndef OPAL_MAFFINITY_BASE_H
#define OPAL_MAFFINITY_BASE_H

#include "opal_config.h"

#include "opal/mca/maffinity/maffinity.h"


/*
 * Global functions for MCA overall maffinity open and close
 */

BEGIN_C_DECLS

/**
 * Initialize the maffinity MCA framework
 *
 * @retval OPAL_SUCCESS Upon success
 * @retval OPAL_ERROR Upon failure
 *
 * This must be the first function invoked in the maffinity MCA
 * framework.  It initializes the maffinity MCA framework, finds
 * and opens maffinity components, etc.
 *
 * This function fills in the internal global variable
 * opal_maffinity_base_components_opened, which is a list of all
 * maffinity components that were successfully opened.  This
 * variable should \em only be used by other maffinity base
 * functions -- it is not considered a public interface member --
 * and is only mentioned here for completeness.
 */
OPAL_DECLSPEC int opal_maffinity_base_open(void);
    
/**
 * Select an available component.
 *
 * @return OPAL_SUCCESS Upon success.
 * @return OPAL_NOT_FOUND If no component can be selected.
 * @return OPAL_ERROR Upon other failure.
 *
 * This function invokes the selection process for maffinity
 * components, which works as follows:
 *
 * - If the \em maffinity MCA parameter is not specified, the
 *   selection set is all available maffinity components.
 * - If the \em maffinity MCA parameter is specified, the
 *   selection set is just that component.
 * - All components in the selection set are queried to see if
 *   they want to run.  All components that want to run are ranked
 *   by their priority and the highest priority component is
 *   selected.  All non-selected components have their "close"
 *   function invoked to let them know that they were not selected.
 * - The selected component will have its "init" function invoked to
 *   let it know that it was selected.
 *
 * If we fall through this entire process and no component is
 * selected, then return OPAL_NOT_FOUND (this is not a fatal
 * error).
 *
 * At the end of this process, we'll either have a single
 * component that is selected and initialized, or no component was
 * selected.  If no component was selected, subsequent invocation
 * of the maffinity wrapper functions will return an error.
 */
OPAL_DECLSPEC int opal_maffinity_base_select(void);

/**
 * Set memory affinity.
 *
 * @param segments Array describing segments and what process they
 * belong to
 * @param num_segments Length of the segments array
 * @param am_allocator True if this process created the shared
 * memory block
 *
 * @retval OPAL_SUCCESS upon success
 * @retval OPAL_NOT_FOUND if no maffinity components are available.
 * @retval OPAL_ERROR upon other error.
 *
 * Set the affinity of the memory segments described in the \em
 * segments array.
 *
 * If no maffinity components were available, or if the
 * opal_maffinity_base_select() was never invoked, OPAL_NOT_FOUND
 * is returned.
 */
OPAL_DECLSPEC int opal_maffinity_base_set(opal_maffinity_base_segment_t *segments, size_t num_segments);

OPAL_DECLSPEC int opal_maffinity_base_node_name_to_id(char *, int *);
OPAL_DECLSPEC int opal_maffinity_base_bind(opal_maffinity_base_segment_t *, size_t, int);

/**
 * Shut down the maffinity MCA framework.
 *
 * @retval OPAL_SUCCESS Always
 *
 * This function shuts down everything in the maffinity MCA
 * framework.
 *
 * It must be the last function invoked on the maffinity MCA
 * framework.
 */
OPAL_DECLSPEC int opal_maffinity_base_close(void);

/**
 * Indication of whether a component was successfully selected or
 * not
 */
extern bool opal_maffinity_base_selected;

/**
 * Global component struct for the selected component
 */
OPAL_DECLSPEC extern const opal_maffinity_base_component_2_0_0_t 
*opal_maffinity_base_component;
/**
 * Global module struct for the selected module
 */
OPAL_DECLSPEC extern const opal_maffinity_base_module_1_0_0_t 
*opal_maffinity_base_module;

/**
 * Indicator as to whether the list of opened maffinity components
 * is valid or not.
 */
extern bool opal_maffinity_base_components_opened_valid;
/**
 * List of all opened components; created when the maffinity
 * framework is initialized and destroyed when we reduce the list
 * to all available maffinity components.
 */
OPAL_DECLSPEC extern opal_list_t opal_maffinity_base_components_opened;

/**
 * Debugging output stream
 */
extern int opal_maffinity_base_output;

/**
 * Flag to indicate whether or not maffinity was setup
 */
OPAL_DECLSPEC extern bool opal_maffinity_setup;

END_C_DECLS
    
#endif /* OPAL_MAFFINITY_BASE_H */