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

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

14
int init_malleability(int myId, int numP, int root, MPI_Comm comm, char *name_exec, char *nodelist, int num_cpus, int num_nodes);
15
void free_malleability();
16
void indicate_ending_malleability(int new_outside_state);
17
18
int malleability_checkpoint(int *mam_state, int wait_completed);
void MAM_Commit(int *mam_state);
19
20
void set_benchmark_grp(int grp);

21
void set_malleability_configuration(int spawn_method, int spawn_strategies, int spawn_dist, int red_method, int red_strategies);
22
void set_children_number(int numC); // TODO TO BE DEPRECATED
23
void get_malleability_user_comm(MPI_Comm *comm);
24

25
void malleability_add_data(void *data, size_t total_qty, int type, int is_replicated, int is_constant);
26
void malleability_modify_data(void *data, size_t index, size_t total_qty, int type, int is_replicated, int is_constant);
27
void malleability_get_entries(size_t *entries, int is_replicated, int is_constant);
28
void malleability_get_data(void **data, size_t index, int is_replicated, int is_constant);
29
30
31

void set_benchmark_configuration(configuration *config_file);
void get_benchmark_configuration(configuration **config_file);
32
void malleability_retrieve_times(double *sp_time, double *sy_time, double *asy_time, double *mall_time);
33
34

#endif