malleabilityManager.h 1.43 KB
Newer Older
1
2
3
#ifndef MALLEABILITY_MANAGER_H
#define MALLEABILITY_MANAGER_H

4
5
6
7
8
9
10
11
#include <stdio.h>
#include <stdlib.h>
#include <mpi.h>
#include <fcntl.h>
#include <sys/stat.h>
#include <mpi.h>
#include "malleabilityStates.h"

12
13
14
15
16
17
18
typedef struct {
  int numS, numT;
  int rank_state;
  MPI_Comm comm;
} mam_user_reconf_t;

int MAM_Init(int root, MPI_Comm *comm, char *name_exec, char *nodelist, int num_cpus, int num_nodes, void (*user_function)(void *), void *user_args);
19
void MAM_Finalize();
20
int MAM_Checkpoint(int *mam_state, int wait_completed, void (*user_function)(void *), void *user_args);
21
22
void MAM_Resume_redistribution(int *mam_state);

23

24
int MAM_Get_Reconf_Info(mam_user_reconf_t *reconf_info);
25
void MAM_Set_configuration(int spawn_method, int spawn_strategies, int spawn_dist, int red_method, int red_strategies);
26
void MAM_Set_key_configuration(char *key, int required, int *provided);
27
void MAM_Set_target_number(int numC); // TODO TO BE DEPRECATED
28

29
30
void malleability_add_data(void *data, size_t total_qty, MPI_Datatype type, int is_replicated, int is_constant);
void malleability_modify_data(void *data, size_t index, size_t total_qty, MPI_Datatype type, int is_replicated, int is_constant);
31
void malleability_get_entries(size_t *entries, int is_replicated, int is_constant);
32
void malleability_get_data(void **data, size_t index, int is_replicated, int is_constant);
33

34
void MAM_Retrieve_times(double *sp_time, double *sy_time, double *asy_time, double *mall_time);
35
36

#endif