-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmainmpi.c
61 lines (54 loc) · 1.68 KB
/
mainmpi.c
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
#include "solver.h"
#include "solvermpi.h"
#include <mpi.h>
#include <stdio.h>
#include <stdlib.h>
void init_multi(char **argv, int processID) {
uint64_t mem = (uint64_t)atoi(argv[3]) << 30;
if (processID == 0) {
/* Manager node. */
solve_mpi_manager(atoi(argv[1]), atoi(argv[2]), mem);
} else {
/* Worker node. */
solve_mpi_worker(mem, false);
}
}
void init_single(char **argv) {
uint8_t nPiecesMax = atoi(argv[1]);
uint64_t nthread = atoi(argv[2]);
uint64_t mem = ((uint64_t)atoi(argv[3])) << 30;
printf("main: solving %d pieces on a single node with "
"%zd thread(s) and %zd bytes of memory.\n",
nPiecesMax, nthread, mem);
solve_local_remaining_pieces(nPiecesMax, nthread, mem, false);
}
int main(int argc, char **argv) {
if (argc != 4) {
printf("Usage: %s <n-pieces> <n-threads> <memory-in-GiB>\n",
argv[0]);
return 1;
}
/* Initialize the MPI environment. All code between MPI_Init
and MPI_Finalize gets run by all nodes. */
int provided;
MPI_Init_thread(&argc, &argv, MPI_THREAD_FUNNELED, &provided);
if (provided != MPI_THREAD_FUNNELED) {
printf("Requested MPI_THREAD_FUNNELED, provided %d\n", provided);
return 1;
}
int processID, clusterSize;
MPI_Comm_size(MPI_COMM_WORLD, &clusterSize);
MPI_Comm_rank(MPI_COMM_WORLD, &processID);
if (clusterSize < 1) {
printf("main: (fatal) clusterSize is less than 1.\n");
MPI_Finalize();
return 1;
} else if (clusterSize == 1) {
init_single(argv);
} else {
init_multi(argv, processID);
}
/* Terminates MPI execution environment. */
MPI_Finalize();
return 0;
}