6 def set_env(env, prereq_dir, version):
7 env.set('OPENMPIDIR', prereq_dir)
8 env.set('OPAL_PREFIX', prereq_dir) # be able to move openmpi install (packages)
9 env.set('MPI_ROOT_DIR', prereq_dir) # update for cmake
10 env.set('MPI_ROOT', prereq_dir)
11 env.set('MPI_INCLUDE_DIR', os.path.join(prereq_dir, 'include'))
12 env.set('MPI_C_COMPILER', os.path.join(prereq_dir, 'bin', 'mpicc'))
13 env.set('MPI_CXX_COMPILER', os.path.join(prereq_dir, 'bin', 'mpicxx'))
14 env.set('MPI_Fortran_COMPILER', os.path.join(prereq_dir, 'bin', 'mpifort'))
15 env.set('MPIEXEC_EXECUTABLE', os.path.join(prereq_dir, 'bin', 'mpiexec'))
16 env.set('MPI_C_FOUND', os.path.join(prereq_dir,'lib','libmpi.so'))
17 env.prepend('PATH', os.path.join(prereq_dir, 'bin'))
18 env.prepend('PATH', os.path.join(prereq_dir, 'include'))
19 env.prepend('LD_LIBRARY_PATH', os.path.join(prereq_dir, 'lib'))
20 env.prepend('C_INCLUDE_PATH', os.path.join(prereq_dir, 'include')) # needed for parallel h5py
22 def set_nativ_env(env):
25 prereq_inc='/usr/include/openmpi'
28 if any(distribution in distro.name().lower() for distribution in ["rocky", "centos", "fedora"]) :
29 prereq_dir='/usr/lib64/openmpi'
30 prereq_bin='/usr/lib64/openmpi/bin'
31 prereq_inc='/usr/include/openmpi-x86_64'
32 elif any(distribution in distro.name().lower() for distribution in ["debian", "ubuntu"]) :
33 prereq_dir='/usr/lib/x86_64-linux-gnu/openmpi'
34 prereq_inc= '/usr/lib/x86_64-linux-gnu/openmpi/include'
37 if any(distribution in platform.linux_distribution()[0].lower() for distribution in ["rocky", "centos", "fedora"]) :
38 prereq_dir='/usr/lib64/openmpi'
39 prereq_bin='/usr/lib64/openmpi/bin'
40 prereq_inc='/usr/include/openmpi-x86_64'
42 env.set('MPI_ROOT_DIR', prereq_dir)
43 env.set('OPENMPIDIR', prereq_dir)
44 env.set('MPI_ROOT', prereq_dir)
45 env.set('MPI_C_COMPILER', os.path.join(prereq_bin,'mpicc'))
46 env.set('MPI_CXX_COMPILER', os.path.join(prereq_bin,'mpicxx'))
47 env.set('MPI_C_FOUND', os.path.join(prereq_dir,'lib','libmpi.so'))
48 env.set('MPI_INCLUDE_DIR', prereq_inc)
49 env.prepend('PATH', prereq_bin)
50 env.prepend('LD_LIBRARY_PATH', os.path.join(prereq_dir,'lib'))