2024-05-02 23:23:15 +05:00
|
|
|
#include <iostream>
|
|
|
|
#include <stdexcept>
|
2024-05-03 20:31:16 +05:00
|
|
|
#include <filesystem>
|
2024-05-02 23:23:15 +05:00
|
|
|
|
|
|
|
#include "ng_mpi.hpp"
|
2024-05-03 20:31:16 +05:00
|
|
|
#include "ngstream.hpp"
|
2024-05-02 23:23:15 +05:00
|
|
|
#include "utils.hpp"
|
|
|
|
|
|
|
|
using std::cout;
|
|
|
|
using std::endl;
|
|
|
|
|
|
|
|
namespace ngcore {
|
|
|
|
|
|
|
|
static std::unique_ptr<SharedLibrary> mpi_lib, ng_mpi_lib;
|
|
|
|
|
2024-05-03 20:31:16 +05:00
|
|
|
void InitMPI(std::filesystem::path mpi_lib_path, std::filesystem::path ng_libs_dir) {
|
2024-05-02 23:23:15 +05:00
|
|
|
if (ng_mpi_lib) return;
|
2024-05-03 20:31:16 +05:00
|
|
|
cout << IM(3) << "InitMPI" << endl;
|
2024-05-02 23:23:15 +05:00
|
|
|
|
|
|
|
typedef void (*get_version_handle)(char *, int *);
|
|
|
|
typedef int (*init_handle)(int *, char ***);
|
|
|
|
typedef int (*mpi_initialized_handle)(int *);
|
|
|
|
typedef void (*ng_init_handle)();
|
|
|
|
|
|
|
|
init_handle mpi_init;
|
|
|
|
mpi_initialized_handle mpi_initialized;
|
|
|
|
get_version_handle get_version;
|
|
|
|
try {
|
|
|
|
mpi_init = GetSymbol<init_handle>("MPI_Init");
|
2024-05-03 20:31:16 +05:00
|
|
|
cout << IM(3) << "MPI already loaded " << mpi_init << endl;
|
2024-05-02 23:23:15 +05:00
|
|
|
mpi_initialized = GetSymbol<mpi_initialized_handle>("MPI_Initialized");
|
|
|
|
get_version = GetSymbol<get_version_handle>("MPI_Get_library_version");
|
|
|
|
} catch (std::runtime_error &e) {
|
2024-05-03 20:31:16 +05:00
|
|
|
cout << IM(3) << "MPI not loaded" << endl;
|
|
|
|
mpi_lib = std::make_unique<SharedLibrary>("/usr/lib/libmpi.so",
|
|
|
|
std::nullopt, true);
|
2024-05-02 23:23:15 +05:00
|
|
|
mpi_init = mpi_lib->GetSymbol<init_handle>("MPI_Init");
|
|
|
|
mpi_initialized =
|
|
|
|
mpi_lib->GetSymbol<mpi_initialized_handle>("MPI_Initialized");
|
|
|
|
get_version =
|
|
|
|
mpi_lib->GetSymbol<get_version_handle>("MPI_Get_library_version");
|
|
|
|
}
|
|
|
|
|
|
|
|
int flag = 0;
|
|
|
|
mpi_initialized(&flag);
|
|
|
|
if (!flag) {
|
2024-05-03 20:31:16 +05:00
|
|
|
cout << IM(3) << "Calling MPI_Init" << endl;
|
2024-05-02 23:23:15 +05:00
|
|
|
mpi_init(nullptr, nullptr);
|
|
|
|
}
|
|
|
|
|
|
|
|
char version_string[65536];
|
|
|
|
int resultlen = 0;
|
|
|
|
get_version(version_string, &resultlen);
|
|
|
|
mpi_library_version = version_string;
|
2024-05-03 20:31:16 +05:00
|
|
|
cout << IM(3) << "MPI version: " << version_string << endl;
|
2024-05-02 23:23:15 +05:00
|
|
|
|
|
|
|
std::string libname = "";
|
|
|
|
if (mpi_library_version.substr(0, 8) == "Open MPI") {
|
2024-05-03 20:31:16 +05:00
|
|
|
cout << IM(3) << "Have Open MPI" << endl;
|
2024-05-02 23:23:15 +05:00
|
|
|
libname = "/opt/netgen/lib/libng_openmpi.so";
|
|
|
|
} else if (mpi_library_version.substr(0, 5) == "MPICH") {
|
2024-05-03 20:31:16 +05:00
|
|
|
cout << IM(3) << "Have MPICH" << endl;
|
2024-05-02 23:23:15 +05:00
|
|
|
libname = "/opt/netgen/lib/libng_mpich.so";
|
|
|
|
} else
|
2024-05-03 20:31:16 +05:00
|
|
|
cout << IM(3) << "Unknown MPI" << endl;
|
2024-05-02 23:23:15 +05:00
|
|
|
|
|
|
|
if (libname.size()) {
|
2024-05-03 20:31:16 +05:00
|
|
|
cout << IM(3) << "loading " << libname << endl;
|
|
|
|
cout << IM(3) << "NG_MPI_INT before " << NG_MPI_INT.value << endl;
|
2024-05-02 23:23:15 +05:00
|
|
|
ng_mpi_lib = std::make_unique<SharedLibrary>(libname);
|
|
|
|
auto ng_init = ng_mpi_lib->GetSymbol<ng_init_handle>("ng_init_mpi");
|
2024-05-03 20:31:16 +05:00
|
|
|
cout << IM(3) << "have ng_init " << ng_init << endl;
|
2024-05-02 23:23:15 +05:00
|
|
|
ng_init();
|
2024-05-03 20:31:16 +05:00
|
|
|
cout << IM(3) << "NG_MPI_INT after " << NG_MPI_INT.value << endl;
|
|
|
|
|
|
|
|
int size, rank;
|
|
|
|
NG_MPI_Comm_size(NG_MPI_COMM_WORLD, &size);
|
|
|
|
NG_MPI_Comm_rank(NG_MPI_COMM_WORLD, &rank);
|
|
|
|
cout << IM(3) << "Hello from " << rank << " of " << size << endl;
|
2024-05-02 23:23:15 +05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static std::runtime_error no_mpi() {
|
|
|
|
return std::runtime_error("MPI not enabled");
|
|
|
|
}
|
|
|
|
|
|
|
|
std::string mpi_library_version = "";
|
|
|
|
|
|
|
|
#include "ng_mpi_generated_dummy_init.hpp"
|
|
|
|
|
|
|
|
} // namespace ngcore
|