Makefile.am 33.3 KB
Newer Older
1
## Process this file with automake to produce Makefile.in
2

3
ACLOCAL_AMFLAGS = ${ACLOCAL_FLAGS} -I m4
4

Lorenz Huedepohl's avatar
Lorenz Huedepohl committed
5
AM_FCFLAGS = $(SCALAPACK_FCFLAGS) $(FC_MODINC)modules
6
AM_LDFLAGS = $(SCALAPACK_LDFLAGS)
7

Lorenz Huedepohl's avatar
Lorenz Huedepohl committed
8
9
FCLD = @ACTUAL_FC@

10
# libelpa
11
12
13
14
lib_LTLIBRARIES = libelpa@SUFFIX@.la
libelpa@SUFFIX@_la_LINK = $(FCLINK) $(AM_LDFLAGS) -version-info $(ELPA_SO_VERSION)
libelpa@SUFFIX@_la_LIBADD = libelpa@SUFFIX@_public.la libelpa@SUFFIX@_private.la
libelpa@SUFFIX@_la_SOURCES =
15

16
17
# parts with public interface
noinst_LTLIBRARIES = libelpa@SUFFIX@_public.la
Lorenz Huedepohl's avatar
Lorenz Huedepohl committed
18
libelpa@SUFFIX@_public_la_FCFLAGS = $(AM_FCFLAGS) $(FC_MODOUT)modules $(FC_MODINC)private_modules
19
libelpa@SUFFIX@_public_la_SOURCES = \
20
21
  src/elpa.F90 \
  src/elpa_api.F90 \
22
  src/elpa_constants.F90
23

24
25
# internal parts
noinst_LTLIBRARIES += libelpa@SUFFIX@_private.la
Lorenz Huedepohl's avatar
Lorenz Huedepohl committed
26
libelpa@SUFFIX@_private_la_FCFLAGS = $(AM_FCFLAGS) $(FC_MODOUT)private_modules $(FC_MODINC)private_modules
27
libelpa@SUFFIX@_private_la_SOURCES = \
28
  src/elpa_impl.F90 \
29
  src/elpa_autotune_impl.F90 \
30
  src/elpa_abstract_impl.F90 \
31
  src/helpers/mod_precision.F90 \
32
  src/helpers/mod_blas_interfaces.F90 \
33
  src/helpers/mod_scalapack_interfaces.F90 \
34
35
  src/helpers/mod_mpi.F90 \
  src/helpers/mod_mpi_stubs.F90 \
36
  src/helpers/mod_omp.F90 \
37
38
39
40
41
42
  src/elpa_generated_fortran_interfaces.F90 \
  src/elpa2/mod_redist_band.F90 \
  src/elpa2/mod_pack_unpack_cpu.F90 \
  src/elpa2/mod_compute_hh_trafo.F90 \
  src/helpers/aligned_mem.F90 \
  src/elpa1/elpa1_compute_private.F90 \
43
  src/elpa1/elpa1_auxiliary.F90 \
44
45
46
47
  src/elpa2/elpa2_determine_workload.F90 \
  src/elpa2/elpa2_compute.F90 \
  src/elpa2/kernels/mod_single_hh_trafo_real.F90 \
  src/GPU/check_for_gpu.F90 \
48
  src/GPU/mod_vendor_agnostic_layer.F90 \
49
  src/GPU/CUDA/mod_cuda.F90 \
50
  src/GPU/INTEL/mod_mkl_offload.F90 \
51
  src/GPU/ROCm/mod_hip.F90 \
Andreas Marek's avatar
Andreas Marek committed
52
53
54
  src/elpa2/GPU/interface_c_gpu_kernel.F90 \
  src/elpa2/GPU/CUDA/interface_c_cuda_kernel.F90 \
  src/elpa2/GPU/ROCm/interface_c_hip_kernel.F90 \
55
56
57
58
59
60
61
  src/elpa2/mod_pack_unpack_gpu.F90 \
  src/elpa2/qr/qr_utils.F90 \
  src/elpa2/qr/elpa_qrkernels.F90 \
  src/elpa2/qr/elpa_pdlarfb.F90 \
  src/elpa2/qr/elpa_pdgeqrf.F90 \
  src/elpa1/elpa1.F90 \
  src/elpa2/elpa2.F90 \
62
  src/elpa_generalized/cannon.c \
63
  src/helpers/matrix_plot.F90 \
Andreas Marek's avatar
Andreas Marek committed
64
  src/general/mod_elpa_skewsymmetric_blas.F90 \
65
  src/solve_tridi/mod_global_product.F90 \
Andreas Marek's avatar
Andreas Marek committed
66
  src/solve_tridi/mod_global_gather.F90 \
Andreas Marek's avatar
Andreas Marek committed
67
  src/solve_tridi/mod_resort_ev.F90 \
68
69
70
71
72
73
74
75
76
  src/solve_tridi/mod_transform_columns.F90 \
  src/solve_tridi/mod_check_monotony.F90 \
  src/solve_tridi/mod_add_tmp.F90 \
  src/solve_tridi/mod_merge_systems.F90 \
  src/solve_tridi/mod_merge_recursive.F90 \
  src/solve_tridi/mod_solve_tridi.F90 \
  src/elpa1/mod_distribute_global_column.F90 \
  src/elpa1/mod_v_add_s.F90 \
  src/elpa1/mod_solve_secular_equation.F90 \
77
78
  src/helpers/mod_thread_affinity.F90 \
  src/helpers/check_thread_affinity.c \
79
80
  src/elpa_index.c

81
libelpa@SUFFIX@_private_la_SOURCES += src/elpa_c_interface.c
Andreas Marek's avatar
Andreas Marek committed
82
83


84
85
libelpa@SUFFIX@_private_la_SOURCES += \
  src/general/elpa_utilities.F90
86

87
EXTRA_libelpa@SUFFIX@_private_la_DEPENDENCIES = \
88
89
  src/elpa1/elpa_reduce_add_vectors.F90 \
  src/elpa1/elpa_transpose_vectors.F90 \
Andreas Marek's avatar
Andreas Marek committed
90
  src/elpa_api_math_template.F90 \
Andreas Marek's avatar
Andreas Marek committed
91
92
  src/elpa_impl_math_template.F90 \
  src/elpa_impl_generalized_transform_template.F90 \
93
94
95
  src/elpa1/elpa1_compute_template.F90 \
  src/elpa2/elpa2_compute_real_template.F90 \
  src/elpa2/elpa2_compute_complex_template.F90 \
Andreas Marek's avatar
Andreas Marek committed
96
  src/helpers/elpa_redistribute_template.F90 \
97
98
99
100
101
102
103
104
105
106
107
108
109
110
  src/elpa1/elpa1_template.F90 \
  src/elpa2/elpa2_template.F90 \
  src/elpa2/qr/qr_utils_template.F90 \
  src/elpa2/qr/elpa_pdlarfb_template.F90 \
  src/elpa2/qr/elpa_pdgeqrf_template.F90 \
  src/elpa2/elpa2_bandred_template.F90 \
  src/elpa2/elpa2_symm_matrix_allreduce_real_template.F90 \
  src/elpa2/elpa2_trans_ev_band_to_full_template.F90 \
  src/elpa2/elpa2_tridiag_band_template.F90 \
  src/elpa2/elpa2_trans_ev_tridi_to_band_template.F90 \
  src/elpa2/elpa2_herm_matrix_allreduce_complex_template.F90 \
  src/elpa2/kernels/real_template.F90 \
  src/elpa2/kernels/complex_template.F90 \
  src/elpa2/kernels/simple_template.F90 \
Andreas Marek's avatar
Andreas Marek committed
111
  src/elpa2/kernels/simple_block4_template.F90 \
112
  src/elpa2/kernels/simple_block6_template.F90 \
113
114
115
116
117
  src/elpa2/pack_unpack_cpu.F90 \
  src/elpa2/pack_unpack_gpu.F90 \
  src/elpa2/compute_hh_trafo.F90 \
  src/elpa2/redist_band.F90 \
  src/general/sanity.F90 \
118
  src/general/error_checking.inc \
119
120
121
122
  src/elpa1/elpa_cholesky_template.F90 \
  src/elpa1/elpa_invert_trm.F90 \
  src/elpa1/elpa_multiply_a_b.F90 \
  src/elpa1/elpa_solve_tridi_impl_public.F90 \
Andreas Marek's avatar
Andreas Marek committed
123
124
  src/general/elpa_ssr2_template.F90 \
  src/general/elpa_ssmv_template.F90 \
125
  src/general/precision_macros.h \
126
  src/general/precision_typedefs.h \
127
  src/general/precision_kinds.F90
128

129
if HAVE_DETAILED_TIMINGS
130
131
132
133
134
135
136
137
138
libelpa@SUFFIX@_private_la_SOURCES += \
  src/ftimings/ftimings.F90 \
  src/ftimings/ftimings_type.F90 \
  src/ftimings/ftimings_value.F90 \
  src/ftimings/highwater_mark.c \
  src/ftimings/resident_set_size.c \
  src/ftimings/time.c \
  src/ftimings/virtual_memory.c \
  src/ftimings/papi.c
139

140
else
141
142
libelpa@SUFFIX@_private_la_SOURCES += \
  src/helpers/timer_dummy.F90
143
144
endif

145
if WITH_NVIDIA_GPU_VERSION
146
  libelpa@SUFFIX@_private_la_SOURCES += src/GPU/CUDA/elpa_index_nvidia_gpu.cu src/GPU/CUDA/cudaFunctions.cu src/GPU/CUDA/cuUtils.cu src/elpa2/GPU/CUDA/ev_tridi_band_nvidia_gpu_real.cu src/elpa2/GPU/CUDA/ev_tridi_band_nvidia_gpu_complex.cu
147
148
endif

149
150
151
152
if WITH_INTEL_GPU_VERSION
  libelpa@SUFFIX@_private_la_SOURCES += src/GPU/INTEL/mkl_offload.cpp
endif

153
if WITH_AMD_GPU_VERSION
154
  libelpa@SUFFIX@_private_la_SOURCES += src/GPU/ROCm/elpa_index_amd_gpu.cpp src/GPU/ROCm/rocmFunctions.cpp src/GPU/ROCm/hipUtils.cpp src/elpa2/GPU/ROCm/ev_tridi_band_amd_gpu_real.cpp src/elpa2/GPU/ROCm/ev_tridi_band_amd_gpu_complex.cpp
155
156
endif

157
if !WITH_MPI
158
  libelpa@SUFFIX@_private_la_SOURCES += src/helpers/mod_time_c.F90
159
if !HAVE_DETAILED_TIMINGS
160
  libelpa@SUFFIX@_private_la_SOURCES += src/ftimings/time.c
161
162
163
endif
endif

Andreas Marek's avatar
Andreas Marek committed
164
165
166
167
168

if HAVE_HETEROGENOUS_CLUSTER_SUPPORT
  libelpa@SUFFIX@_private_la_SOURCES +=  src/helpers/get_cpuid_set.c src/helpers/mod_simd_kernel.F90
endif

Andreas Marek's avatar
Andreas Marek committed
169
if WITH_REAL_GENERIC_KERNEL
Andreas Marek's avatar
Andreas Marek committed
170
  libelpa@SUFFIX@_private_la_SOURCES +=  src/elpa2/kernels/real.F90
171
172
endif

Andreas Marek's avatar
Andreas Marek committed
173
if WITH_COMPLEX_GENERIC_KERNEL
Andreas Marek's avatar
Andreas Marek committed
174
  libelpa@SUFFIX@_private_la_SOURCES +=  src/elpa2/kernels/complex.F90
175
176
endif

Andreas Marek's avatar
Andreas Marek committed
177
if WITH_REAL_GENERIC_SIMPLE_KERNEL
Andreas Marek's avatar
Andreas Marek committed
178
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_simple.F90
179
180
endif

Andreas Marek's avatar
Andreas Marek committed
181
if WITH_COMPLEX_GENERIC_SIMPLE_KERNEL
Andreas Marek's avatar
Andreas Marek committed
182
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_simple.F90
183
184
endif

Andreas Marek's avatar
Andreas Marek committed
185
186
187
188
if WITH_REAL_GENERIC_SIMPLE_BLOCK4_KERNEL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_simple_block4.F90
endif

189
190
191
192
if WITH_REAL_GENERIC_SIMPLE_BLOCK6_KERNEL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_simple_block6.F90
endif

Andreas Marek's avatar
Andreas Marek committed
193
if WITH_REAL_BGP_KERNEL
Andreas Marek's avatar
Andreas Marek committed
194
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_bgp.f90
195
196
endif

Andreas Marek's avatar
Andreas Marek committed
197
if WITH_REAL_BGQ_KERNEL
Andreas Marek's avatar
Andreas Marek committed
198
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_bgq.f90
199
200
endif

201
if WITH_REAL_SSE_ASSEMBLY_KERNEL
Andreas Marek's avatar
Andreas Marek committed
202
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/asm_x86_64_double_precision.s
203
if WANT_SINGLE_PRECISION_REAL
Andreas Marek's avatar
Andreas Marek committed
204
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/asm_x86_64_single_precision.s
205
endif
206

Andreas Marek's avatar
Andreas Marek committed
207
else
208
if WITH_COMPLEX_SSE_ASSEMBLY_KERNEL
Andreas Marek's avatar
Andreas Marek committed
209
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/asm_x86_64_double_precision.s
210
if WANT_SINGLE_PRECISION_COMPLEX
Andreas Marek's avatar
Andreas Marek committed
211
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/asm_x86_64_single_precision.s
212
endif
213
214
endif
endif
Andreas Marek's avatar
Andreas Marek committed
215

216
217
if WITH_REAL_SPARC64_BLOCK2_KERNEL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_sparc64_2hv_double_precision.c
Andreas Marek's avatar
Andreas Marek committed
218
219
220
#if WANT_SINGLE_PRECISION_REAL
#  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_sparc64_2hv_single_precision.c
#endif
221
222
endif

223
224
225
226
227
228
229
if WITH_REAL_NEON_ARCH64_BLOCK2_KERNEL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_neon_arch64_2hv_double_precision.c
if WANT_SINGLE_PRECISION_REAL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_neon_arch64_2hv_single_precision.c
endif
endif

230
231
if WITH_REAL_VSX_BLOCK2_KERNEL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_vsx_2hv_double_precision.c
232
233
234
if WANT_SINGLE_PRECISION_REAL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_vsx_2hv_single_precision.c
endif
235
236
endif

237
if WITH_REAL_SSE_BLOCK2_KERNEL
Andreas Marek's avatar
Andreas Marek committed
238
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_sse_2hv_double_precision.c
239
if WANT_SINGLE_PRECISION_REAL
Andreas Marek's avatar
Andreas Marek committed
240
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_sse_2hv_single_precision.c
241
endif
242
243
endif

Andreas Marek's avatar
Andreas Marek committed
244
if WITH_REAL_AVX_BLOCK2_KERNEL
Andreas Marek's avatar
Andreas Marek committed
245
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_avx_2hv_double_precision.c
246
if WANT_SINGLE_PRECISION_REAL
Andreas Marek's avatar
Andreas Marek committed
247
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_avx_2hv_single_precision.c
248
endif
Andreas Marek's avatar
Andreas Marek committed
249
250
endif

251
if WITH_REAL_AVX2_BLOCK2_KERNEL
Andreas Marek's avatar
Andreas Marek committed
252
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_avx2_2hv_double_precision.c
253
if WANT_SINGLE_PRECISION_REAL
Andreas Marek's avatar
Andreas Marek committed
254
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_avx2_2hv_single_precision.c
255
endif
256
257
endif

258
if WITH_REAL_AVX512_BLOCK2_KERNEL
Andreas Marek's avatar
Andreas Marek committed
259
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_avx512_2hv_double_precision.c
260
if WANT_SINGLE_PRECISION_REAL
Andreas Marek's avatar
Andreas Marek committed
261
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_avx512_2hv_single_precision.c
262
endif
263
264
endif

265
266
267
268
269
270
271
272
273
274
275
276
277
278
if WITH_REAL_SVE128_BLOCK2_KERNEL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_sve128_2hv_double_precision.c
if WANT_SINGLE_PRECISION_REAL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_sve128_2hv_single_precision.c
endif
endif

if WITH_REAL_SVE256_BLOCK2_KERNEL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_sve256_2hv_double_precision.c
if WANT_SINGLE_PRECISION_REAL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_sve256_2hv_single_precision.c
endif
endif

Andreas Marek's avatar
Andreas Marek committed
279
280
281
282
283
284
285
if WITH_REAL_SVE512_BLOCK2_KERNEL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_sve512_2hv_double_precision.c
if WANT_SINGLE_PRECISION_REAL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_sve512_2hv_single_precision.c
endif
endif

286
287
if WITH_REAL_SPARC64_BLOCK4_KERNEL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_sparc64_4hv_double_precision.c
288
289
290
#if WANT_SINGLE_PRECISION_REAL
#  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_sparc64_4hv_single_precision.c
#endif
291
endif
292

293
294
295
296
297
298
299
if WITH_REAL_NEON_ARCH64_BLOCK4_KERNEL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_neon_arch64_4hv_double_precision.c
if WANT_SINGLE_PRECISION_REAL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_neon_arch64_4hv_single_precision.c
endif
endif

300
301
302
303
304
305
if WITH_REAL_VSX_BLOCK4_KERNEL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_vsx_4hv_double_precision.c
if WANT_SINGLE_PRECISION_REAL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_vsx_4hv_single_precision.c
endif
endif
306

307
if WITH_REAL_SSE_BLOCK4_KERNEL
Andreas Marek's avatar
Andreas Marek committed
308
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_sse_4hv_double_precision.c
309
if WANT_SINGLE_PRECISION_REAL
Andreas Marek's avatar
Andreas Marek committed
310
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_sse_4hv_single_precision.c
311
endif
312
313
endif

Andreas Marek's avatar
Andreas Marek committed
314
if WITH_REAL_AVX_BLOCK4_KERNEL
Andreas Marek's avatar
Andreas Marek committed
315
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_avx_4hv_double_precision.c
316
if WANT_SINGLE_PRECISION_REAL
Andreas Marek's avatar
Andreas Marek committed
317
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_avx_4hv_single_precision.c
318
endif
Andreas Marek's avatar
Andreas Marek committed
319
320
endif

321
if WITH_REAL_AVX2_BLOCK4_KERNEL
Andreas Marek's avatar
Andreas Marek committed
322
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_avx2_4hv_double_precision.c
323
if WANT_SINGLE_PRECISION_REAL
Andreas Marek's avatar
Andreas Marek committed
324
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_avx2_4hv_single_precision.c
325
endif
326
327
endif

328
if WITH_REAL_AVX512_BLOCK4_KERNEL
Andreas Marek's avatar
Andreas Marek committed
329
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_avx512_4hv_double_precision.c
330
if WANT_SINGLE_PRECISION_REAL
Andreas Marek's avatar
Andreas Marek committed
331
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_avx512_4hv_single_precision.c
332
endif
333
334
endif

335
336
337
338
339
340
341
342
343
344
345
346
347
348
if WITH_REAL_SVE128_BLOCK4_KERNEL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_sve128_4hv_double_precision.c
if WANT_SINGLE_PRECISION_REAL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_sve128_4hv_single_precision.c
endif
endif

if WITH_REAL_SVE256_BLOCK4_KERNEL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_sve256_4hv_double_precision.c
if WANT_SINGLE_PRECISION_REAL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_sve256_4hv_single_precision.c
endif
endif

Andreas Marek's avatar
Andreas Marek committed
349
350
351
352
353
354
355
if WITH_REAL_SVE512_BLOCK4_KERNEL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_sve512_4hv_double_precision.c
if WANT_SINGLE_PRECISION_REAL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_sve512_4hv_single_precision.c
endif
endif

356
357
if WITH_REAL_SPARC64_BLOCK6_KERNEL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_sparc64_6hv_double_precision.c
358
359
360
#if WANT_SINGLE_PRECISION_REAL
#  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_sparc64_6hv_single_precision.c
#endif
361
endif
362

363
364
365
366
367
368
369
if WITH_REAL_NEON_ARCH64_BLOCK6_KERNEL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_neon_arch64_6hv_double_precision.c
if WANT_SINGLE_PRECISION_REAL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_neon_arch64_6hv_single_precision.c
endif
endif

370
371
372
373
374
375
if WITH_REAL_VSX_BLOCK6_KERNEL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_vsx_6hv_double_precision.c
if WANT_SINGLE_PRECISION_REAL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_vsx_6hv_single_precision.c
endif
endif
376

377
if WITH_REAL_SSE_BLOCK6_KERNEL
Andreas Marek's avatar
Andreas Marek committed
378
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_sse_6hv_double_precision.c
379
if WANT_SINGLE_PRECISION_REAL
Andreas Marek's avatar
Andreas Marek committed
380
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_sse_6hv_single_precision.c
381
endif
382
383
endif

Andreas Marek's avatar
Andreas Marek committed
384
if WITH_REAL_AVX_BLOCK6_KERNEL
Andreas Marek's avatar
Andreas Marek committed
385
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_avx_6hv_double_precision.c
386
if WANT_SINGLE_PRECISION_REAL
Andreas Marek's avatar
Andreas Marek committed
387
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_avx_6hv_single_precision.c
388
endif
Andreas Marek's avatar
Andreas Marek committed
389
390
endif

391
if WITH_REAL_AVX2_BLOCK6_KERNEL
Andreas Marek's avatar
Andreas Marek committed
392
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_avx2_6hv_double_precision.c
393
if WANT_SINGLE_PRECISION_REAL
Andreas Marek's avatar
Andreas Marek committed
394
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_avx2_6hv_single_precision.c
395
endif
396
397
endif

398
if WITH_REAL_AVX512_BLOCK6_KERNEL
Andreas Marek's avatar
Andreas Marek committed
399
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_avx512_6hv_double_precision.c
400
if WANT_SINGLE_PRECISION_REAL
Andreas Marek's avatar
Andreas Marek committed
401
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_avx512_6hv_single_precision.c
402
endif
403
404
endif

405
406
407
408
409
410
411
412
413
414
415
416
417
418
if WITH_REAL_SVE128_BLOCK6_KERNEL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_sve128_6hv_double_precision.c
if WANT_SINGLE_PRECISION_REAL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_sve128_6hv_single_precision.c
endif
endif

if WITH_REAL_SVE256_BLOCK6_KERNEL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_sve256_6hv_double_precision.c
if WANT_SINGLE_PRECISION_REAL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_sve256_6hv_single_precision.c
endif
endif

Andreas Marek's avatar
Andreas Marek committed
419
420
421
422
423
424
425
if WITH_REAL_SVE512_BLOCK6_KERNEL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_sve512_6hv_double_precision.c
if WANT_SINGLE_PRECISION_REAL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/real_sve512_6hv_single_precision.c
endif
endif

426
427
428
429
430
431
432
433
434
435
436
437
438
#if WITH_COMPLEX_SPARC64_BLOCK1_KERNEL
#  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_sparc64_1hv_double_precision.c
#if WANT_SINGLE_PRECISION_COMPLEX
#  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_sparc64_1hv_single_precision.c
#endif
#endif
#
#if WITH_COMPLEX_VSX_BLOCK1_KERNEL
#  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_vsx_1hv_double_precision.c
#if WANT_SINGLE_PRECISION_COMPLEX
#  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_vsx_1hv_single_precision.c
#endif
#endif
439

440
if WITH_COMPLEX_SSE_BLOCK1_KERNEL
Andreas Marek's avatar
Andreas Marek committed
441
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_sse_1hv_double_precision.c
442
if WANT_SINGLE_PRECISION_COMPLEX
Andreas Marek's avatar
Andreas Marek committed
443
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_sse_1hv_single_precision.c
444
endif
445
446
endif

447
448
449
450
451
452
453
if WITH_COMPLEX_NEON_ARCH64_BLOCK1_KERNEL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_neon_arch64_1hv_double_precision.c
if WANT_SINGLE_PRECISION_COMPLEX
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_neon_arch64_1hv_single_precision.c
endif
endif

Andreas Marek's avatar
Andreas Marek committed
454
if WITH_COMPLEX_AVX_BLOCK1_KERNEL
Andreas Marek's avatar
Andreas Marek committed
455
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_avx_1hv_double_precision.c
456
if WANT_SINGLE_PRECISION_COMPLEX
Andreas Marek's avatar
Andreas Marek committed
457
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_avx_1hv_single_precision.c
458
endif
Andreas Marek's avatar
Andreas Marek committed
459
460
endif

461
if WITH_COMPLEX_AVX2_BLOCK1_KERNEL
Andreas Marek's avatar
Andreas Marek committed
462
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_avx2_1hv_double_precision.c
463
if WANT_SINGLE_PRECISION_COMPLEX
Andreas Marek's avatar
Andreas Marek committed
464
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_avx2_1hv_single_precision.c
465
endif
466
467
endif

468
if WITH_COMPLEX_AVX512_BLOCK1_KERNEL
Andreas Marek's avatar
Andreas Marek committed
469
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_avx512_1hv_double_precision.c
470
if WANT_SINGLE_PRECISION_COMPLEX
Andreas Marek's avatar
Andreas Marek committed
471
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_avx512_1hv_single_precision.c
472
endif
473
474
endif

475
476
477
478
479
480
481
482
483
484
485
486
487
488
if WITH_COMPLEX_SVE128_BLOCK1_KERNEL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_sve128_1hv_double_precision.c
if WANT_SINGLE_PRECISION_COMPLEX
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_sve128_1hv_single_precision.c
endif
endif

if WITH_COMPLEX_SVE256_BLOCK1_KERNEL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_sve256_1hv_double_precision.c
if WANT_SINGLE_PRECISION_COMPLEX
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_sve256_1hv_single_precision.c
endif
endif

Andreas Marek's avatar
Andreas Marek committed
489
490
491
492
493
494
495
if WITH_COMPLEX_SVE512_BLOCK1_KERNEL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_sve512_1hv_double_precision.c
if WANT_SINGLE_PRECISION_COMPLEX
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_sve512_1hv_single_precision.c
endif
endif

496
497
498
499
500
501
502
503
504
505
506
507
508
#if WITH_COMPLEX_SPARC64_BLOCK2_KERNEL
#  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_sparc64_2hv_double_precision.c
#if WANT_SINGLE_PRECISION_COMPLEX
#  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_sparc64_2hv_single_precision.c
#endif
#endif
#
#if WITH_COMPLEX_VSX_BLOCK2_KERNEL
#  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_vsx_2hv_double_precision.c
#if WANT_SINGLE_PRECISION_COMPLEX
#  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_vsx_2hv_single_precision.c
#endif
#endif
509

510
if WITH_COMPLEX_SSE_BLOCK2_KERNEL
Andreas Marek's avatar
Andreas Marek committed
511
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_sse_2hv_double_precision.c
512
if WANT_SINGLE_PRECISION_COMPLEX
Andreas Marek's avatar
Andreas Marek committed
513
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_sse_2hv_single_precision.c
514
endif
515
516
endif

517
518
519
520
521
522
523
if WITH_COMPLEX_NEON_ARCH64_BLOCK2_KERNEL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_neon_arch64_2hv_double_precision.c
if WANT_SINGLE_PRECISION_COMPLEX
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_neon_arch64_2hv_single_precision.c
endif
endif

Andreas Marek's avatar
Andreas Marek committed
524
if WITH_COMPLEX_AVX_BLOCK2_KERNEL
Andreas Marek's avatar
Andreas Marek committed
525
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_avx_2hv_double_precision.c
526
if WANT_SINGLE_PRECISION_COMPLEX
Andreas Marek's avatar
Andreas Marek committed
527
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_avx_2hv_single_precision.c
528
endif
Andreas Marek's avatar
Andreas Marek committed
529
530
endif

531
if WITH_COMPLEX_AVX2_BLOCK2_KERNEL
Andreas Marek's avatar
Andreas Marek committed
532
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_avx2_2hv_double_precision.c
533
if WANT_SINGLE_PRECISION_COMPLEX
Andreas Marek's avatar
Andreas Marek committed
534
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_avx2_2hv_single_precision.c
535
endif
536
537
endif

538
if WITH_COMPLEX_AVX512_BLOCK2_KERNEL
Andreas Marek's avatar
Andreas Marek committed
539
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_avx512_2hv_double_precision.c
540
if WANT_SINGLE_PRECISION_COMPLEX
Andreas Marek's avatar
Andreas Marek committed
541
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_avx512_2hv_single_precision.c
542
endif
543
544
endif

545
546
547
548
549
550
551
552
553
554
555
556
557
558
if WITH_COMPLEX_SVE128_BLOCK2_KERNEL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_sve128_2hv_double_precision.c
if WANT_SINGLE_PRECISION_COMPLEX
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_sve128_2hv_single_precision.c
endif
endif

if WITH_COMPLEX_SVE256_BLOCK2_KERNEL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_sve256_2hv_double_precision.c
if WANT_SINGLE_PRECISION_COMPLEX
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_sve256_2hv_single_precision.c
endif
endif

Andreas Marek's avatar
Andreas Marek committed
559
560
561
562
563
564
565
if WITH_COMPLEX_SVE512_BLOCK2_KERNEL
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_sve512_2hv_double_precision.c
if WANT_SINGLE_PRECISION_COMPLEX
  libelpa@SUFFIX@_private_la_SOURCES += src/elpa2/kernels/complex_sve512_2hv_single_precision.c
endif
endif

566
567
568
569
570

if STORE_BUILD_CONFIG
  libelpa@SUFFIX@_private_la_SOURCES += src/helpers/print_build_config.c
endif

571
# rule for ROCm files
572

573
# Cuda files
574
.cu.lo:
575
	NVCC="$(NVCC)" libtool --mode=compile --tag=CC $(top_srcdir)/nvcc_wrap $(NVCCFLAGS) $(LDFLAGS) -I$(top_builddir)/ -I$(top_srcdir)/  -c $< -o $@
Andreas Marek's avatar
Andreas Marek committed
576

577
578
579
580
581
# Assembly files
LTCCASCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \
	$(LIBTOOLFLAGS) --mode=compile $(CCAS) $(AM_CCASFLAGS) \
	$(CCASFLAGS)

582
583
584
include generated_headers.am
BUILT_SOURCES = $(generated_headers)

585
# install public headers and Fortran modules files in the include/ dir
586
elpa_includedir = $(includedir)/elpa@SUFFIX@-@PACKAGE_VERSION@
587
588
nobase_elpa_include_HEADERS = \
  $(wildcard modules/*) \
589
590
  src/helpers/lapack_interfaces.h \
  src/helpers/scalapack_interfaces.h \
Andreas Marek's avatar
Andreas Marek committed
591
  elpa/elpa_simd_constants.h \
592
  elpa/elpa.h \
Andreas Marek's avatar
Andreas Marek committed
593
  elpa/elpa_generic.h
594
595

nobase_nodist_elpa_include_HEADERS = \
596
  elpa/elpa_version.h \
597
598
  elpa/elpa_constants.h \
  elpa/elpa_generated.h \
Andreas Marek's avatar
Andreas Marek committed
599
  elpa/elpa_generated_c_api.h
600

Lorenz Huedepohl's avatar
Lorenz Huedepohl committed
601
dist_man_MANS = \
Andreas Marek's avatar
Andreas Marek committed
602
  man/elpa2_print_kernels.1 \
Andreas Marek's avatar
Andreas Marek committed
603
  man/elpa_init.3 \
Andreas Marek's avatar
Andreas Marek committed
604
  man/elpa_allocate.3 \
Andreas Marek's avatar
Andreas Marek committed
605
  man/elpa_set.3 \
Andreas Marek's avatar
Andreas Marek committed
606
  man/elpa_setup.3 \
607
  man/elpa_eigenvalues.3 \
608
  man/elpa_eigenvectors.3 \
609
610
  man/elpa_skew_eigenvalues.3 \
  man/elpa_skew_eigenvectors.3 \
611
  man/elpa_generalized_eigenvectors.3 \
612
  man/elpa_generalized_eigenvalues.3 \
613
  man/elpa_cholesky.3 \
614
  man/elpa_invert_triangular.3 \
615
  man/elpa_solve_tridiagonal.3 \
616
  man/elpa_hermitian_multiply.3 \
Andreas Marek's avatar
Andreas Marek committed
617
  man/elpa_deallocate.3 \
618
619
  man/elpa_load_settings.3 \
  man/elpa_store_settings.3 \
Andreas Marek's avatar
Andreas Marek committed
620
621
622
623
  man/elpa_print_settings.3 \
  man/elpa_autotune_save_state.3 \
  man/elpa_autotune_load_state.3 \
  man/elpa_autotune_print_state.3 \
624
625
626
627
  man/elpa_autotune_setup.3 \
  man/elpa_autotune_step.3 \
  man/elpa_autotune_set_best.3 \
  man/elpa_autotune_deallocate.3 \
Andreas Marek's avatar
Andreas Marek committed
628
  man/elpa_uninit.3
629

630
dist_doc_DATA = README.md USERS_GUIDE.md USERS_GUIDE_DEPRECATED_LEGACY_API.md CONTRIBUTING.md LICENSE Changelog COPYING/COPYING COPYING/gpl.txt COPYING/lgpl.txt documentation/*
631

632
633
# pkg-config stuff
pkgconfigdir = $(libdir)/pkgconfig
634
pkgconfig_DATA = @PKG_CONFIG_FILE@
635

636
637
# programs
bin_PROGRAMS = \
638
  elpa2_print_kernels@SUFFIX@
639

640
641
noinst_PROGRAMS =
check_SCRIPTS =
642

643
644
test_program_ldadd = libelpatest@SUFFIX@.la libelpa@SUFFIX@.la
test_program_fcflags = $(AM_FCFLAGS) $(FC_MODOUT)test_modules $(FC_MODINC)test_modules $(FC_MODINC)modules $(FC_MODINC)private_modules
645
646
647

# library with shared sources for the test files
noinst_LTLIBRARIES += libelpatest@SUFFIX@.la
648
libelpatest@SUFFIX@_la_FCFLAGS = $(test_program_fcflags)
649
libelpatest@SUFFIX@_la_SOURCES = \
650
  test/shared/tests_variable_definitions.F90 \
Andreas Marek's avatar
Andreas Marek committed
651
652
  test/shared/mod_tests_scalapack_interfaces.F90 \
  test/shared/mod_tests_blas_interfaces.F90 \
653
654
655
656
657
658
  test/shared/test_util.F90 \
  test/shared/test_read_input_parameters.F90 \
  test/shared/test_check_correctness.F90 \
  test/shared/test_setup_mpi.F90 \
  test/shared/test_blacs_infrastructure.F90 \
  test/shared/test_prepare_matrix.F90 \
659
  test/shared/test_analytic.F90 \
660
  test/shared/test_output_type.F90
Andreas Marek's avatar
Andreas Marek committed
661

662
663
664
665
666
if WITH_SCALAPACK_TESTS
libelpatest@SUFFIX@_la_SOURCES += \
  test/shared/test_scalapack.F90
endif

667
if HAVE_REDIRECT
668
libelpatest@SUFFIX@_la_SOURCES += \
669
670
  test/shared/test_redir.c \
  test/shared/test_redirect.F90
671
672
673
674
endif


elpa2_print_kernels@SUFFIX@_SOURCES = src/elpa2/elpa2_print_kernels.F90
675
elpa2_print_kernels@SUFFIX@_LDADD = libelpa@SUFFIX@.la
676
elpa2_print_kernels@SUFFIX@_FCFLAGS = $(AM_FCFLAGS) $(FC_MODINC)modules
677

678
include test_programs.am
679

680
681
#include test_programs_manual.am

682
683
684
685
noinst_PROGRAMS += validate_double_instance@SUFFIX@
check_SCRIPTS += validate_double_instance@SUFFIX@_default.sh
validate_double_instance@SUFFIX@_SOURCES = test/Fortran/elpa2/double_instance.F90
validate_double_instance@SUFFIX@_LDADD = $(test_program_ldadd)
686
validate_double_instance@SUFFIX@_FCFLAGS = $(AM_FCFLAGS) $(FC_MODINC)test_modules $(FC_MODINC)modules $(FC_MODINC)private_modules
687
688
689
690
691

noinst_PROGRAMS += validate_real_2stage_banded@SUFFIX@
check_SCRIPTS += validate_real_2stage_banded@SUFFIX@_default.sh
validate_real_2stage_banded@SUFFIX@_SOURCES = test/Fortran/elpa2/real_2stage_banded.F90 
validate_real_2stage_banded@SUFFIX@_LDADD = $(test_program_ldadd)
692
validate_real_2stage_banded@SUFFIX@_FCFLAGS = $(AM_FCFLAGS) $(FC_MODINC)test_modules $(FC_MODINC)modules $(FC_MODINC)private_modules
693
694
695
696
697

noinst_PROGRAMS += validate_complex_2stage_banded@SUFFIX@
check_SCRIPTS += validate_complex_2stage_banded@SUFFIX@_default.sh
validate_complex_2stage_banded@SUFFIX@_SOURCES = test/Fortran/elpa2/complex_2stage_banded.F90
validate_complex_2stage_banded@SUFFIX@_LDADD = $(test_program_ldadd)
698
validate_complex_2stage_banded@SUFFIX@_FCFLAGS = $(AM_FCFLAGS) $(FC_MODINC)test_modules $(FC_MODINC)modules $(FC_MODINC)private_modules
699
700

if WANT_SINGLE_PRECISION_REAL
701
702
703
704
noinst_PROGRAMS += validate_single_real_2stage_banded@SUFFIX@
check_SCRIPTS += validate_single_real_2stage_banded@SUFFIX@_default.sh
validate_single_real_2stage_banded@SUFFIX@_SOURCES = test/Fortran/elpa2/single_real_2stage_banded.F90
validate_single_real_2stage_banded@SUFFIX@_LDADD = $(test_program_ldadd)
705
validate_single_real_2stage_banded@SUFFIX@_FCFLAGS = $(AM_FCFLAGS) $(FC_MODINC)test_modules $(FC_MODINC)modules $(FC_MODINC)private_modules
706
707
708
endif

if WANT_SINGLE_PRECISION_COMPLEX
709
710
711
712
noinst_PROGRAMS += validate_single_complex_2stage_banded@SUFFIX@
check_SCRIPTS += validate_single_complex_2stage_banded@SUFFIX@_default.sh
validate_single_complex_2stage_banded@SUFFIX@_SOURCES = test/Fortran/elpa2/single_complex_2stage_banded.F90
validate_single_complex_2stage_banded@SUFFIX@_LDADD = $(test_program_ldadd)
713
validate_single_complex_2stage_banded@SUFFIX@_FCFLAGS = $(AM_FCFLAGS) $(FC_MODINC)test_modules $(FC_MODINC)modules $(FC_MODINC)private_modules
714
715
endif

716
717
# python wrapper
pyelpadir = $(pythondir)/pyelpa
718
if WITH_PYTHON
719
pyelpa_PYTHON = python/pyelpa/__init__.py python/pyelpa/distributedmatrix.py
720
pyelpa_LTLIBRARIES = wrapper.la
721
722
723
724
else
pyelpa_PYTHON =
pyelpa_LTLIBRARIES =
endif
725
nodist_wrapper_la_SOURCES = python/pyelpa/wrapper.c
726
727
wrapper_la_LDFLAGS = -module -avoid-version -shared $(AM_LDFLAGS)
wrapper_la_LIBADD = libelpa@SUFFIX@.la
728
wrapper_la_CFLAGS = $(PYTHON_INCLUDE) $(NUMPY_INCLUDE) $(AM_CFLAGS)
729

730
python/pyelpa/wrapper.c: python/pyelpa/wrapper.pyx
731
	cython $< -o $@
732
# test scripts
733
TASKS ?= 2
734
if WITH_MPI
735
  wrapper=$(MPI_BINARY) -n $${TASKS:-$(TASKS)}
736
else
737
  wrapper=
738
endif
739
TESTS = $(check_SCRIPTS)
740
741
742
743
744
745
%_extended.sh: %
	@echo "#!/bin/bash" > $@
	@echo 'if [ "$$CHECK_LEVEL" = "extended" ] ; then $(wrapper) ./$^ $$TEST_FLAGS ; else exit 77; fi' >> $@
	@chmod +x $@

%_default.sh: %
746
	@echo "#!/bin/bash" > $@
747
	@echo '$(wrapper)' ./$^ '$$TEST_FLAGS' >> $@
748
	@chmod +x $@
749

750
751
752
753
754
755
if WITH_PYTHON_TESTS
check_SCRIPTS += test_python.sh
endif

test_python.sh:
	@echo '#!/bin/bash' > $@
756
# this is kind of hacky... is there a better way to get wrapper.so?
757
758
759
760
	@echo 'export PYTHONPATH=./python-copy:$$PYTHONPATH' >> $@
	@echo 'cp -r $(abs_top_srcdir)/python python-copy || exit 1' >> $@
	@echo 'chmod u+rwX -R python-copy || exit 1' >> $@
	@echo 'cp .libs/wrapper.so python-copy/pyelpa/ || exit 1' >> $@
761
# the dlopen flags are needed for MKL to work properly...
762
# only in os from python 3.3 on
763
	@echo "$(wrapper) $(PYTHON) -c 'import sys, os; sys.setdlopenflags(os.RTLD_NOW | os.RTLD_GLOBAL); import pytest; sys.exit(pytest.main([\"./python-copy\", \"-p\", \"no:cacheprovider\"]))'" >> $@
Sebastian Ohlmann's avatar
Sebastian Ohlmann committed
764
	@echo 'exit_code=$$?' >> $@
765
	@echo 'rm -rf python-copy || exit 1' >> $@
Sebastian Ohlmann's avatar
Sebastian Ohlmann committed
766
	@echo 'exit $$exit_code' >> $@
767
768
	@chmod +x $@

769
770
include doxygen.am

771
CLEANFILES = \
Andreas Marek's avatar
Andreas Marek committed
772
773
  elpa_generated.h \
  elpa_generated_c_api.h \
Andreas Marek's avatar
Andreas Marek committed
774
  elpa1_test* \
775
  elpa2_test*\
Andreas Marek's avatar
Andreas Marek committed
776
777
  elpa2_real* \
  elpa1_real* \
778
  elpa*.sh \
779
  test*.sh \
Andreas Marek's avatar
Andreas Marek committed
780
781
782
783
  single_real* \
  single_complex* \
  real* \
  complex* \
784
  double_instance* \
785
  *.i \
Sebastian Ohlmann's avatar
Sebastian Ohlmann committed
786
787
  python/pyelpa/wrapper.c \
  check_python.sh
788
789

clean-local:
790
	-rm -rf modules/* private_modules/* test_modules/* .fortran_dependencies/*
791
	-rm -rf validate_*.sh
792
	-rm -rf test_*.sh
Andreas Marek's avatar
Andreas Marek committed
793
794
795
796
797
	-rm -rf real_2stage*.sh
	-rm -rf complex_2stage*.sh
	-rm -rf single_complex_2stage*.sh
	-rm -rf single_real_2stage*.sh
	-rm -rf double_instance_onenode*.sh
798
	-rm -rf test_*.sh
799
	-rm -rf $(generated_headers)
Lorenz Huedepohl's avatar
Lorenz Huedepohl committed
800
801

distclean-local:
Andreas Marek's avatar
Andreas Marek committed
802
803
804
805
	-rm -rf ./m4
	-rm -rf ./src
	-rm -rf ./test
	-rm -rf ./modules
Andreas Marek's avatar
Andreas Marek committed
806
807
808
	-rm -rf ./private_modules
	-rm -rf ./test_modules
	-rm -rf ./.fortran-dependencies
Andreas Marek's avatar
Andreas Marek committed
809
	-rm -rf .fortran_dependencies
Lorenz Huedepohl's avatar
Lorenz Huedepohl committed
810
	-rm config-f90.h
811
	-rm -rf ./test/.deps
Andreas Marek's avatar
Andreas Marek committed
812
	-rm -rf elpa/elpa_generated_c_api.h
813

814
EXTRA_DIST = \
815
  elpa.spec \
816
  elpa/elpa.h \
817
  elpa/elpa_generic.h \
818
  fdep/fortran_dependencies.mk \
819
  fdep/fortran_dependencies.pl \
820
  manual_cpp \
821
  nvcc_wrap \
Andreas Marek's avatar
Andreas Marek committed
822
  remove_xcompiler \
Andreas Marek's avatar
Andreas Marek committed
823
824
  src/helpers/fortran_blas_interfaces.F90 \
  src/helpers/fortran_scalapack_interfaces.F90 \
825
  src/GPU/CUDA/cuUtils_template.cu \
826
  src/GPU/ROCm/hipUtils_template.cpp \
Andreas Marek's avatar
Andreas Marek committed
827
  src/elpa_api_math_template.F90 \
Andreas Marek's avatar
Andreas Marek committed
828
  src/elpa_impl_math_template.F90 \
Andreas Marek's avatar
Andreas Marek committed
829
  src/helpers/elpa_redistribute_template.F90 \
Andreas Marek's avatar
Andreas Marek committed
830
  src/elpa_impl_generalized_transform_template.F90 \
831
  src/elpa1/elpa1_compute_template.F90 \
832
  src/solve_tridi/global_product_template.F90 \
Andreas Marek's avatar
Andreas Marek committed
833
  src/solve_tridi/global_gather_template.F90 \
Andreas Marek's avatar
Andreas Marek committed
834
  src/solve_tridi/resort_ev_template.F90 \
835
836
837
838
839
840
841
842
843
  src/solve_tridi/transform_columns_template.F90 \
  src/solve_tridi/check_monotony_template.F90 \
  src/solve_tridi/add_tmp_template.F90 \
  src/elpa1/v_add_s_template.F90 \
  src/elpa1/solve_secular_equation_template.F90 \
  src/elpa1/distribute_global_column_template.F90 \
  src/solve_tridi/merge_systems_template.F90 \
  src/solve_tridi/merge_recursive_template.F90 \
  src/solve_tridi/solve_tridi_template.F90 \
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
  src/elpa1/elpa1_template.F90 \
  src/elpa1/elpa1_tools_template.F90 \
  src/elpa1/elpa1_trans_ev_template.F90 \
  src/elpa1/elpa1_tridiag_template.F90 \
  src/elpa1/elpa_cholesky_template.F90 \
  src/elpa1/elpa_invert_trm.F90 \
  src/elpa1/elpa_multiply_a_b.F90 \
  src/elpa1/elpa_reduce_add_vectors.F90 \
  src/elpa1/elpa_solve_tridi_impl_public.F90 \
  src/elpa1/elpa_transpose_vectors.F90 \
  src/elpa2/compute_hh_trafo.F90 \
  src/elpa2/elpa2_bandred_template.F90 \
  src/elpa2/elpa2_compute_complex_template.F90 \
  src/elpa2/elpa2_compute_real_template.F90 \
  src/elpa2/elpa2_herm_matrix_allreduce_complex_template.F90 \
  src/elpa2/elpa2_symm_matrix_allreduce_real_template.F90 \
  src/elpa2/elpa2_template.F90 \
  src/elpa2/elpa2_trans_ev_band_to_full_template.F90 \
  src/elpa2/elpa2_trans_ev_tridi_to_band_template.F90 \
  src/elpa2/elpa2_tridiag_band_template.F90 \
864
  src/elpa2/kernels/complex_128bit_256bit_512bit_BLOCK_template.c \
865
  src/elpa2/kernels/complex_template.F90 \
Andreas Marek's avatar
Andreas Marek committed
866
  src/elpa2/kernels/real_128bit_256bit_512bit_BLOCK_template.c \
867
868
  src/elpa2/kernels/real_template.F90 \
  src/elpa2/kernels/simple_template.F90 \
Andreas Marek's avatar
Andreas Marek committed
869
  src/elpa2/kernels/simple_block4_template.F90 \
870
  src/elpa2/kernels/simple_block6_template.F90 \
871
872
873
874
875
876
877
  src/elpa2/pack_unpack_cpu.F90 \
  src/elpa2/pack_unpack_gpu.F90 \
  src/elpa2/qr/elpa_pdgeqrf_template.F90 \
  src/elpa2/qr/elpa_pdlarfb_template.F90 \
  src/elpa2/qr/elpa_qrkernels_template.F90 \
  src/elpa2/qr/qr_utils_template.F90 \
  src/elpa2/redist_band.F90 \
878
  src/elpa_generalized/cannon_forw_template.c \
879
  src/elpa_generalized/cannon_back_template.c \
880
  src/elpa_index.h \
881
  src/fortran_constants.h \
882
883
  src/general/map_global_to_local.F90 \
  src/general/precision_macros.h \
884
  src/general/precision_typedefs.h \
885
  src/general/precision_kinds.F90 \
886
  test/shared/test_precision_kinds.F90 \
887
888
  src/general/prow_pcol.F90 \
  src/general/sanity.F90 \
889
  src/general/error_checking.inc \
890
891
  src/general/elpa_ssr2_template.F90 \
  src/general/elpa_ssmv_template.F90 \
892
893
894
895
  test/Fortran/assert.h \
  test/Fortran/elpa_print_headers.F90 \
  test/shared/test_check_correctness_template.F90 \
  test/shared/test_prepare_matrix_template.F90 \
Pavel Kus's avatar
Pavel Kus committed
896
  test/shared/test_analytic_template.F90 \
897
  test/shared/test_scalapack_template.F90 \
Andreas Marek's avatar
Andreas Marek committed
898
899
900
901
902
903
  test_project_1stage/Makefile.am \
  test_project_1stage/autogen.sh \
  test_project_1stage/configure.ac \
  test_project_1stage/fdep \
  test_project_1stage/m4 \
  test_project_1stage/src/test_real.F90 \
904
905
906
907
908
  test_project_2stage/Makefile.am \
  test_project_2stage/autogen.sh \
  test_project_2stage/configure.ac \
  test_project_2stage/fdep \
  test_project_2stage/m4 \
Pavel Kus's avatar
Pavel Kus committed
909
910
911
912
913
914
915
  test_project_2stage/src/test_real2.F90 \
  test_project_C/Makefile.am \
  test_project_C/autogen.sh \
  test_project_C/configure.ac \
  test_project_C/fdep \
  test_project_C/m4 \
  test_project_C/src/test_real.c \
Andreas Marek's avatar
Andreas Marek committed
916
  test_project_C/src/test_blacs_infrastructure.F90
917

Pavel Kus's avatar
Pavel Kus committed
918
919
920
921
922
if WITH_SCALAPACK_TESTS
EXTRA_DIST += \
  test/shared/test_scalapack_template.F90
endif

923
# python wrapper files
924
925
EXTRA_DIST += python/pyelpa/__init__.py \
	      python/pyelpa/distributedmatrix.py \
926
927
928
929
930
	      python/pyelpa/wrapper.pyx \
	      python/tests/test_elpa_import.py \
	      python/tests/test_mpi4py.py \
	      python/tests/test_numroc.py \
	      python/tests/test_with_mpi.py
931

932
933
934
LIBTOOL_DEPS = @LIBTOOL_DEPS@
libtool: $(LIBTOOL_DEPS)
	$(SHELL) ./config.status libtool
935

936

937
@FORTRAN_MODULE_DEPS@
938
939
940
941
942

# Fortran module dependencies only work within each target,
# specify that the test programs need a finished library before
# one can compile them

943
# $1  Object name
944
define require_elpa_lib
945
$1: libelpa@SUFFIX@.la
946
947

endef
948
$(foreach p,$(bin_PROGRAMS) $(noinst_PROGRAMS),$(foreach o,$($p_OBJECTS),$(eval $(call require_elpa_lib,$o))))