Merge branch release-2016 into release-2018
[alexxy/gromacs.git] / admin / builds / pre-submit-matrix.txt
1 # Comment line(s) preceding each configuration document the main
2 # intent behind that configuration, so that we can correctly judge
3 # whether to preserve that during maintenance decisions.
4 #
5 # Other configurations might coincidentally test such configurations
6 # (e.g. because they are the current default), but it is appropriate
7 # to intend to teach each feature (or a feature combination) exactly
8 # once, and for the intent to be reflected precisely in the
9 # configuration syntax, so that the configurations are stable even
10 # if the defaults change in future.
11 #
12 # The phrase "at time of release" refers to either the initial
13 # GROMACS release from that branch, or the next expected release
14 # from that branch. (We will tend not to retroactively support
15 # newer infrastructure in CI, unless it's either easy or of
16 # high impact.)
17
18 # Test older gcc
19 # Test oldest supported CUDA
20 # Test oldest supported Ubuntu
21 # Test MPI with CUDA
22 # Test MPMD PME with library MPI
23 # Test cmake FindCUDA functionality introduced in 3.8
24 gcc-4.8 gpu cuda-6.5 cmake-3.8.1 mpi npme=1 nranks=2 openmp
25
26 # Test newest gcc supported by newest CUDA at time of release
27 # Test thread-MPI with CUDA
28 # Test cmake version from before new FindCUDA support (in 3.8)
29 # Test SIMD implementation of pair search for GPU code-path
30 gcc-5 gpu cuda-8.0 thread-mpi openmp cmake-3.6.1 release-with-assert simd=avx2_256
31
32 # Test newest cmake at time of release
33 # Test with ThreadSanitizer (compiled without OpenMP, even though
34 #   this gcc was configured with --disable-linux-futex, because
35 #   Redmine #1850 is unresolved, which causes more suspected
36 #   false positives than races detected)
37 # Test fftpack fallback
38 gcc-7 tsan no-openmp fftpack cmake-3.10.0
39
40 # Test newest gcc at time of release
41 # Test gcc in double precision
42 # Test 128-bit SIMD in double precision (to cover SimdInt32 support better)
43 gcc-7 double mpi simd=avx_128_fma
44
45 # Test on MacOS (because gcc-6 is only available there)
46 # Test X11 build
47 gcc-6 x11
48
49 # Test oldest supported cmake
50 # Test older clang
51 # Test clang in double precision
52 # Test without OpenMP
53 # Test thread-MPI
54 # Test AVX_128_FMA SIMD + Double (Important for Simd4N=Simd4 and sizeof(SimdInt32)!=4*GMX_SIMD_REAL_WIDTH)
55 clang-3.4 double simd=avx_128_fma thread-mpi no-openmp fftpack cmake-3.4.3
56
57 # Test newest clang at time of release
58 # Test with AddressSanitizer (without OpenMP, see below)
59 clang-5 no-openmp asan
60
61 # Test oldest supported MSVC on Windows
62 # Test newest supported MSVC on Windows
63 msvc-2015 openmp release-with-assert
64
65 # Test newest icc at the time of release
66 # Test icc without SIMD in double precision in release mode
67 # Test MKL
68 # Test without any MPI
69 # Test on CentOS (because cmake-3.9.6 is available there)
70 icc-18 no-thread-mpi double openmp mkl cmake-3.9.6 simd=none release
71
72 # Test NVIDIA OpenCL
73 # Test MPI + OpenCL
74 # Test AVX2_256 SIMD
75 # Test icc with SIMD in mixed precision in release mode
76 icc-18 openmp opencl cuda-7.5 mpi release simd=avx2_256
77
78 # Test AMD OpenCL
79 # Test AVX_128_FMA SIMD
80 gcc-5 openmp simd=avx_128_fma opencl amdappsdk-3.0
81
82 # TODO
83 # Add support for CUDA 9.0
84 # Add OpenMP support to ASAN build (but libomp.so in clang-4 reports leaks, so might need a suitable build or suppression)
85 # Test hwloc support
86 # Test newest supported LTS Ubuntu
87 # Update gpu testing specifiers per https://redmine.gromacs.org/issues/2161
88 # Resolve Redmine #1850 so that ThreadSanitizer can test our OpenMP code
89 # Support icc 17
90 # Test AVX-512 when hardware is available