-
Notifications
You must be signed in to change notification settings - Fork 57
UsingMSYS2
This summarizes our experience of using MSYS2 on Windows. The main motivation (in comparison with MinGW) is that it has built-in package manager, allowing automatic handling of many dependences. It can be helpful for automatic builds in GitHub Actions (example. It is also convenient by being completely isolated from the rest of the Windows (by default), hence can be used in parallel to any other toolchains. But it has some drawbacks, so it is not yet the default development platform for Windows.
First, install MSYS2 following the guidelines at https://www.msys2.org. They include installation of basic development toolchain
pacman -S --needed base-devel mingw-w64-x86_64-toolchain
and running special terminal "MSYS MinGW 64-bit" from Start menu (it will set the environment).
Second, position yourself into ADDA /src/
folder and run
pacman -S mingw-w64-x86_64-fftw
make seq
pacman -S mingw-w64-x86_64-msmpi
make mpi
pacman -S mingw-w64-x86_64-opencl-icd mingw-w64-x86_64-opencl-headers
make ocl OPTIONS=CLFFT_APPLE
Package installations need to be performed only once (each line is necessary for the specific ADDA version, but FFTW one is needed for all of them). Moreover, these installations require confirmations (just press Enter). The latter can be avoided by adding --noconfirm
but that is not recommended, since pacman
is not considered fully robust.
MS-MPI package can be omitted, but if used it replaces the separate installation of msmpisdk.msi
. Still, any of these options require separate installation of runtime libraries (see instructions).
clFFT package is not yet available inside MSYS2, but can be installed the same as when using MinGW. The same applies to clBLAS. Thus, only the fallback Apple clFFT can be fully automated. GPU drivers supporting OpenCL are also required (see instructions).
The above receipt produces executables that can be run immediately from this terminal, with exception of MPI version, since mpiexec
(can probably be manually added to PATH
variable internal to MSYS2). To run them in any other Windows terminal, one needs to provide a number of libraries from ...\msys64\mingw64\bin\
(...\msys64
is the installation path of MSYS2). Either add this path to the system PATH
or copy the following files to the folder with ADDA binaries (suitable for distribution):
libfftw3-3.dll
libgcc_s_seh-1.dll
libgfortran-5.dll
libquadmath-0.dll
libwinpthread-1.dll
libOpenCL.dll
libstdc++-6.dll
The last one is required only for Apple clFFT.
If additionally ...\msys64\mingw64\bin\
is added to the system PATH
, then compilation can also be performed from any terminal and, hence, makes the MSYS2 toolchain useable from any IDE.
- Produced executables are slower (by about 10%) than MinGW ones - tested for version d7e6169 with
adda -grid 128 -size 10
. Specifically, 88s for MinGW, 95-97s using only MSYS2, 92s using MSYS2 binaries with MinGW DLLs (apart fromlibgfortran-5.dll
that was still from MSYS2). So it is partly related to some MSYS2 libraries, that are, in turn, related to that of Cygwin. However, the MinGW+GCC toolchains were also different in these tests. This requires further study. - The choice of toolchains affects the list of DLLs that need to be distributed with ADDA binaries. Current MinGW compilation does not require any additional MinGW-specific DLLs (see win64/). It is not clear, whether the same can be accomplished with MSYS2. In particular, currently MSYS2 leads to dependence on
libgfortran-5.dll
and, through it, onlibgcc_s_seh-1.dll
,libquadmath-0.dll
andlibwinpthread-1.dll
. - clFFT and clBLAS are not available as packages. It is not expected to be fixed soon, since MSYS2 packages are based on GCC (MinGW) toolchain (link), while clFFT and clBLAS have Windows makefiles only for Visual Studio (link).
- Dependence on
libOpenCL.dll
seems to be redundant, since usingOpenCL.dll
(available with GPU drivers on Windows) should be sufficient. In particular, we tested renaming the systemOpenCL.dll
intolibOpenCL.dll
and placing it near the binary. - A known problem with MSYS2 terminal (
mintty
) - it buffers (hides) ADDA output till the end of simulation. Can be circumvented by-so_buf line
.
Home (Getting started)
Frequently asked questions
Features
Tutorial
Comparison with other codes
Largest simulations
Compiling ADDA
Installing FFTW3
Installing MPI
Using OpenCL
Installing clFFT
Installing clBLAS
Using sparse mode
Installing MinGW
Using MSYS2
Papers that use ADDA
Awards
References
Links
Acknowledgements
Instruction for committers
Code design & structure
Style guide
Using VS Code
Using Eclipse
Early development history
Adding new ...