Merge pull request #3613 from Rabenda/fix-riscv
[platform/upstream/openblas.git] / Makefile
1 TOPDIR  = .
2 include ./Makefile.system
3
4 BLASDIRS = interface driver/level2 driver/level3 driver/others
5
6 ifneq ($(DYNAMIC_ARCH), 1)
7 BLASDIRS += kernel
8 endif
9
10 ifdef SANITY_CHECK
11 BLASDIRS += reference
12 endif
13
14 SUBDIRS = $(BLASDIRS)
15 ifneq ($(NO_LAPACK), 1)
16 SUBDIRS += lapack
17 endif
18
19 RELA =
20 ifeq ($(BUILD_RELAPACK), 1)
21 RELA = re_lapack
22 endif
23
24 ifeq ($(NO_FORTRAN), 1)
25 define NOFORTRAN
26 1
27 endef
28 ifneq ($(NO_LAPACK), 1)
29 define C_LAPACK
30 1
31 endef
32 endif
33 export NOFORTRAN
34 export NO_LAPACK
35 export C_LAPACK
36 endif
37
38 LAPACK_NOOPT := $(filter-out -O0 -O1 -O2 -O3 -Ofast -O -Og -Os,$(LAPACK_FFLAGS))
39
40 SUBDIRS_ALL = $(SUBDIRS) test ctest utest exports benchmark ../laswp ../bench cpp_thread_test
41
42 .PHONY : all libs netlib $(RELA) test ctest shared install
43 .NOTPARALLEL : all libs $(RELA) prof lapack-test install blas-test
44
45 all :: libs netlib $(RELA) tests shared
46         @echo
47         @echo " OpenBLAS build complete. ($(LIB_COMPONENTS))"
48         @echo
49         @echo "  OS               ... $(OSNAME)             "
50         @echo "  Architecture     ... $(ARCH)               "
51 ifndef BINARY64
52         @echo "  BINARY           ... 32bit                 "
53 else
54         @echo "  BINARY           ... 64bit                 "
55 endif
56
57 ifdef INTERFACE64
58 ifneq ($(INTERFACE64), 0)
59         @echo "  Use 64 bits int    (equivalent to \"-i8\" in Fortran)      "
60 endif
61 endif
62         @$(CC) --version > /dev/null 2>&1;\
63         if [ $$? -eq 0 ]; then \
64            cverinfo=`$(CC) --version | sed -n '1p'`; \
65            if [ -z "$${cverinfo}" ]; then \
66            cverinfo=`$(CC) --version | sed -n '2p'`; \
67            fi; \
68            echo "  C compiler       ... $(C_COMPILER)  (cmd & version : $${cverinfo})";\
69         else  \
70            echo "  C compiler       ... $(C_COMPILER)  (command line : $(CC))";\
71         fi
72 ifeq ($(NOFORTRAN), $(filter 0,$(NOFORTRAN)))
73         @$(FC) --version > /dev/null 2>&1;\
74         if [ $$? -eq 0 ]; then \
75            fverinfo=`$(FC) --version | sed -n '1p'`; \
76            if [ -z "$${fverinfo}" ]; then \
77            fverinfo=`$(FC) --version | sed -n '2p'`; \
78            fi; \
79            echo "  Fortran compiler ... $(F_COMPILER)  (cmd & version : $${fverinfo})";\
80         else \
81            echo "  Fortran compiler ... $(F_COMPILER)  (command line : $(FC))";\
82         fi
83 endif
84 ifneq ($(OSNAME), AIX)
85         @echo -n "  Library Name     ... $(LIBNAME)"
86 else
87         @echo "  Library Name     ... $(LIBNAME)"
88 endif
89
90 ifndef SMP
91         @echo " (Single-threading)  "
92 else
93         @echo " (Multi-threading; Max num-threads is $(NUM_THREADS))"
94 endif
95
96 ifeq ($(DYNAMIC_ARCH), 1)
97         @echo "  Supporting multiple $(ARCH) cpu models with minimum requirement for the common code being $(CORE)"
98 endif
99
100 ifeq ($(USE_OPENMP), 1)
101         @echo
102         @echo " Use OpenMP in the multithreading. Because of ignoring OPENBLAS_NUM_THREADS and GOTO_NUM_THREADS flags, "
103         @echo " you should use OMP_NUM_THREADS environment variable to control the number of threads."
104         @echo
105 endif
106
107 ifeq ($(OSNAME), Darwin)
108         @echo "WARNING: If you plan to use the dynamic library $(LIBDYNNAME), you must run:"
109         @echo
110         @echo "\"make PREFIX=/your_installation_path/ install\"."
111         @echo
112         @echo "(or set PREFIX in Makefile.rule and run make install."
113         @echo "If you want to move the .dylib to a new location later, make sure you change"
114         @echo "the internal name of the dylib with:"
115         @echo
116         @echo "install_name_tool -id /new/absolute/path/to/$(LIBDYNNAME) $(LIBDYNNAME)"
117 endif
118         @echo
119         @echo "To install the library, you can run \"make PREFIX=/path/to/your/installation install\"."
120         @echo
121
122 shared :
123 ifneq ($(NO_SHARED), 1)
124 ifeq ($(OSNAME), $(filter $(OSNAME),Linux SunOS Android Haiku FreeBSD DragonFly))
125         @$(MAKE) -C exports so
126         @ln -fs $(LIBSONAME) $(LIBPREFIX).so
127         @ln -fs $(LIBSONAME) $(LIBPREFIX).so.$(MAJOR_VERSION)
128 endif
129 ifeq ($(OSNAME), $(filter $(OSNAME),OpenBSD NetBSD))
130         @$(MAKE) -C exports so
131         @ln -fs $(LIBSONAME) $(LIBPREFIX).so
132 endif
133 ifeq ($(OSNAME), Darwin)
134         @$(MAKE) -C exports dyn
135         @ln -fs $(LIBDYNNAME) $(LIBPREFIX).dylib
136         @ln -fs $(LIBDYNNAME) $(LIBPREFIX).$(MAJOR_VERSION).dylib
137 endif
138 ifeq ($(OSNAME), WINNT)
139         @$(MAKE) -C exports dll
140 endif
141 ifeq ($(OSNAME), CYGWIN_NT)
142         @$(MAKE) -C exports dll
143 endif
144 endif
145
146 tests :
147 ifeq ($(NOFORTRAN), $(filter 0,$(NOFORTRAN)))
148         touch $(LIBNAME)
149 ifndef NO_FBLAS
150         $(MAKE) -C test all
151 endif
152         $(MAKE) -C utest all
153 ifneq ($(NO_CBLAS), 1)
154         $(MAKE) -C ctest all
155 ifeq ($(CPP_THREAD_SAFETY_TEST), 1)
156         $(MAKE) -C cpp_thread_test all
157 endif
158 endif
159 endif
160
161 libs :
162 ifeq ($(CORE), UNKNOWN)
163         $(error OpenBLAS: Detecting CPU failed. Please set TARGET explicitly, e.g. make TARGET=your_cpu_target. Please read README for the detail.)
164 endif
165 ifeq ($(NOFORTRAN), 1)
166         $(info OpenBLAS: Detecting fortran compiler failed. Can only compile BLAS and f2c-converted LAPACK.)
167 endif
168 ifeq ($(NO_STATIC), 1)
169 ifeq ($(NO_SHARED), 1)
170         $(error OpenBLAS: neither static nor shared are enabled.)
171 endif
172 endif
173         @for d in $(SUBDIRS) ; \
174         do if test -d $$d; then \
175           $(MAKE) -C $$d $(@F) || exit 1 ; \
176         fi; \
177         done
178 #Save the config files for installation
179         @cp Makefile.conf Makefile.conf_last
180         @cp config.h config_last.h
181 ifdef QUAD_PRECISION
182         @echo "#define QUAD_PRECISION">> config_last.h
183 endif
184 ifeq ($(EXPRECISION), 1)
185         @echo "#define EXPRECISION">> config_last.h
186 endif
187 ##
188 ifeq ($(DYNAMIC_ARCH), 1)
189         @$(MAKE) -C kernel commonlibs || exit 1
190         @for d in $(DYNAMIC_CORE) ; \
191         do  $(MAKE) GOTOBLAS_MAKEFILE= -C kernel TARGET_CORE=$$d kernel || exit 1 ;\
192         done
193         @echo DYNAMIC_ARCH=1 >> Makefile.conf_last
194 ifeq ($(DYNAMIC_OLDER), 1)
195         @echo DYNAMIC_OLDER=1 >> Makefile.conf_last
196 endif   
197 endif
198 ifdef USE_THREAD
199         @echo USE_THREAD=$(USE_THREAD) >>  Makefile.conf_last
200 endif
201         @-ln -fs $(LIBNAME) $(LIBPREFIX).$(LIBSUFFIX)
202         @touch lib.grd
203
204 prof : prof_blas prof_lapack
205
206 prof_blas :
207         ln -fs $(LIBNAME_P) $(LIBPREFIX)_p.$(LIBSUFFIX)
208         for d in $(SUBDIRS) ; \
209         do if test -d $$d; then \
210           $(MAKE) -C $$d prof || exit 1 ; \
211         fi; \
212         done
213 ifeq ($(DYNAMIC_ARCH), 1)
214           $(MAKE) -C kernel commonprof || exit 1
215 endif
216
217 blas :
218         ln -fs $(LIBNAME) $(LIBPREFIX).$(LIBSUFFIX)
219         for d in $(BLASDIRS) ; \
220         do if test -d $$d; then \
221           $(MAKE) -C $$d libs || exit 1 ; \
222         fi; \
223         done
224
225 hpl :
226         ln -fs $(LIBNAME) $(LIBPREFIX).$(LIBSUFFIX)
227         for d in $(BLASDIRS) ../laswp exports ; \
228         do if test -d $$d; then \
229           $(MAKE) -C $$d $(@F) || exit 1 ; \
230         fi; \
231         done
232 ifeq ($(DYNAMIC_ARCH), 1)
233           $(MAKE) -C kernel commonlibs || exit 1
234         for d in $(DYNAMIC_CORE) ; \
235         do  $(MAKE) GOTOBLAS_MAKEFILE= -C kernel TARGET_CORE=$$d kernel || exit 1 ;\
236         done
237 endif
238
239 hpl_p :
240         ln -fs $(LIBNAME_P) $(LIBPREFIX)_p.$(LIBSUFFIX)
241         for d in $(SUBDIRS) ../laswp exports ; \
242         do if test -d $$d; then \
243           $(MAKE) -C $$d $(@F) || exit 1 ; \
244         fi; \
245         done
246
247 netlib : lapack_prebuild
248 ifneq ($(NO_LAPACK), 1)
249         @$(MAKE) -C $(NETLIB_LAPACK_DIR) lapacklib
250         @$(MAKE) -C $(NETLIB_LAPACK_DIR) tmglib
251 endif
252 ifneq ($(NO_LAPACKE), 1)
253         @$(MAKE) -C $(NETLIB_LAPACK_DIR) lapackelib
254 endif
255
256 ifeq ($(NO_LAPACK), 1)
257 re_lapack :
258
259 else
260 re_lapack :
261         @$(MAKE) -C relapack
262 endif
263
264 prof_lapack : lapack_prebuild
265         @$(MAKE) -C $(NETLIB_LAPACK_DIR) lapack_prof
266
267 lapack_prebuild :
268 ifeq ($(NO_LAPACK), $(filter 0,$(NO_LAPACK)))
269         -@echo "FC          = $(FC)" > $(NETLIB_LAPACK_DIR)/make.inc
270         -@echo "override FFLAGS      = $(LAPACK_FFLAGS)" >> $(NETLIB_LAPACK_DIR)/make.inc
271         -@echo "FFLAGS_DRV  = $(LAPACK_FFLAGS)" >> $(NETLIB_LAPACK_DIR)/make.inc
272         -@echo "POPTS       = $(LAPACK_FPFLAGS)" >> $(NETLIB_LAPACK_DIR)/make.inc
273         -@echo "FFLAGS_NOOPT       = -O0 $(LAPACK_NOOPT)" >> $(NETLIB_LAPACK_DIR)/make.inc
274         -@echo "PNOOPT      = $(LAPACK_FPFLAGS) -O0" >> $(NETLIB_LAPACK_DIR)/make.inc
275 ifeq ($(C_COMPILER)$(F_COMPILER)$(USE_OPENMP), CLANGGFORTRAN1)
276         -@echo "LDFLAGS     = $(FFLAGS) $(EXTRALIB) -lomp" >> $(NETLIB_LAPACK_DIR)/make.inc
277 else
278         -@echo "LDFLAGS     = $(FFLAGS) $(EXTRALIB)" >> $(NETLIB_LAPACK_DIR)/make.inc
279 endif
280         -@echo "CC          = $(CC)" >> $(NETLIB_LAPACK_DIR)/make.inc
281         -@echo "override CFLAGS      = $(LAPACK_CFLAGS)" >> $(NETLIB_LAPACK_DIR)/make.inc
282         -@echo "AR          = $(AR)" >> $(NETLIB_LAPACK_DIR)/make.inc
283         -@echo "ARFLAGS     = $(ARFLAGS) -ru" >> $(NETLIB_LAPACK_DIR)/make.inc
284         -@echo "RANLIB      = $(RANLIB)" >> $(NETLIB_LAPACK_DIR)/make.inc
285         -@echo "LAPACKLIB   = ../../$(LIBNAME)" >> $(NETLIB_LAPACK_DIR)/make.inc
286         -@echo "TMGLIB      = ../../../$(LIBNAME)" >> $(NETLIB_LAPACK_DIR)/make.inc
287         -@echo "BLASLIB     = ../../../$(LIBNAME)" >> $(NETLIB_LAPACK_DIR)/make.inc
288         -@echo "LAPACKELIB  = ../../../$(LIBNAME)" >> $(NETLIB_LAPACK_DIR)/make.inc
289         -@echo "LAPACKLIB_P = ../$(LIBNAME_P)" >> $(NETLIB_LAPACK_DIR)/make.inc
290         -@echo "SUFFIX      = $(SUFFIX)" >> $(NETLIB_LAPACK_DIR)/make.inc
291         -@echo "PSUFFIX     = $(PSUFFIX)" >> $(NETLIB_LAPACK_DIR)/make.inc
292         -@echo "CEXTRALIB   = $(EXTRALIB)" >> $(NETLIB_LAPACK_DIR)/make.inc
293 ifeq ($(F_COMPILER), GFORTRAN)
294         -@echo "TIMER       = INT_ETIME" >> $(NETLIB_LAPACK_DIR)/make.inc
295 ifdef SMP
296 ifeq ($(OSNAME), WINNT)
297         -@echo "LOADER      = $(FC)" >> $(NETLIB_LAPACK_DIR)/make.inc
298 else ifeq ($(OSNAME), Haiku)
299         -@echo "LOADER      = $(FC)" >> $(NETLIB_LAPACK_DIR)/make.inc
300 else
301         -@echo "LOADER      = $(FC) -pthread" >> $(NETLIB_LAPACK_DIR)/make.inc
302 endif
303 else
304         -@echo "LOADER      = $(FC)" >> $(NETLIB_LAPACK_DIR)/make.inc
305 endif
306 else
307         -@echo "TIMER       = NONE" >> $(NETLIB_LAPACK_DIR)/make.inc
308         -@echo "LOADER      = $(FC)" >> $(NETLIB_LAPACK_DIR)/make.inc
309 endif
310 ifeq ($(BUILD_LAPACK_DEPRECATED), 1)
311         -@echo "BUILD_DEPRECATED      = 1" >> $(NETLIB_LAPACK_DIR)/make.inc
312 endif
313 ifeq ($(BUILD_SINGLE), 1)
314         -@echo "BUILD_SINGLE      = 1" >> $(NETLIB_LAPACK_DIR)/make.inc
315 endif
316 ifeq ($(BUILD_DOUBLE), 1)
317         -@echo "BUILD_DOUBLE      = 1" >> $(NETLIB_LAPACK_DIR)/make.inc
318 endif
319 ifeq ($(BUILD_COMPLEX), 1)
320         -@echo "BUILD_COMPLEX      = 1" >> $(NETLIB_LAPACK_DIR)/make.inc
321 endif
322 ifeq ($(BUILD_COMPLEX16), 1)
323         -@echo "BUILD_COMPLEX16      = 1" >> $(NETLIB_LAPACK_DIR)/make.inc
324 endif
325         -@echo "LAPACKE_WITH_TMG      = 1" >> $(NETLIB_LAPACK_DIR)/make.inc
326         -@cat  make.inc >> $(NETLIB_LAPACK_DIR)/make.inc
327 endif
328
329 large.tgz :
330 ifeq ($(NOFORTRAN), $(filter 0,$(NOFORTRAN)))
331         if [ ! -a $< ]; then
332         -wget http://www.netlib.org/lapack/timing/large.tgz;
333         fi
334 endif
335
336 timing.tgz :
337 ifeq ($(NOFORTRAN), $(filter 0,$(NOFORTRAN)))
338         if [ ! -a $< ]; then
339         -wget http://www.netlib.org/lapack/timing/timing.tgz;
340         fi
341 endif
342
343 lapack-timing : large.tgz timing.tgz
344 ifeq ($(NOFORTRAN), $(filter 0,$(NOFORTRAN)))
345         (cd $(NETLIB_LAPACK_DIR); $(TAR) zxf ../timing.tgz TIMING)
346         (cd $(NETLIB_LAPACK_DIR)/TIMING; $(TAR) zxf ../../large.tgz )
347         $(MAKE) -C $(NETLIB_LAPACK_DIR)/TIMING
348 endif
349
350
351 lapack-test :
352         (cd $(NETLIB_LAPACK_DIR)/TESTING && rm -f x* *.out)
353         $(MAKE) -j 1 -C $(NETLIB_LAPACK_DIR)/TESTING/EIG xeigtstc  xeigtstd  xeigtsts  xeigtstz 
354         $(MAKE) -j 1 -C $(NETLIB_LAPACK_DIR)/TESTING/LIN xlintstc  xlintstd  xlintstds  xlintstrfd  xlintstrfz  xlintsts  xlintstz  xlintstzc xlintstrfs xlintstrfc
355 ifneq ($(CROSS), 1)
356         ( cd $(NETLIB_LAPACK_DIR)/INSTALL; $(MAKE) all; ./testlsame; ./testslamch; ./testdlamch; \
357         ./testsecond; ./testdsecnd; ./testieee; ./testversion )
358         (cd $(NETLIB_LAPACK_DIR); ./lapack_testing.py -r -b TESTING)
359 endif
360
361 lapack-runtest:
362         ( cd $(NETLIB_LAPACK_DIR)/INSTALL; ./testlsame; ./testslamch; ./testdlamch; \
363         ./testsecond; ./testdsecnd; ./testieee; ./testversion )
364         (cd $(NETLIB_LAPACK_DIR); ./lapack_testing.py -r )
365
366
367 blas-test:
368         (cd $(NETLIB_LAPACK_DIR)/BLAS/TESTING && rm -f x* *.out)
369         $(MAKE) -j 1 -C $(NETLIB_LAPACK_DIR) blas_testing
370         (cd $(NETLIB_LAPACK_DIR)/BLAS/TESTING && cat *.out)
371
372
373 dummy :
374
375 install :
376         $(MAKE) -f Makefile.install install
377
378 clean ::
379         @for d in $(SUBDIRS_ALL) ; \
380         do if test -d $$d; then \
381           $(MAKE) -C $$d $(@F) || exit 1 ; \
382         fi; \
383         done
384 #ifdef DYNAMIC_ARCH
385         @$(MAKE) -C kernel clean
386 #endif
387         @$(MAKE) -C reference clean
388         @rm -f *.$(LIBSUFFIX) *.so *~ *.exe getarch getarch_2nd *.dll *.lib *.$(SUFFIX) *.dwf $(LIBPREFIX).$(LIBSUFFIX) $(LIBPREFIX)_p.$(LIBSUFFIX) $(LIBPREFIX).so.$(MAJOR_VERSION) *.lnk myconfig.h *.so.renamed *.a.renamed *.so.0
389 ifeq ($(OSNAME), Darwin)
390         @rm -rf getarch.dSYM getarch_2nd.dSYM
391 endif
392         @rm -f Makefile.conf config.h Makefile_kernel.conf config_kernel.h st* *.dylib
393         @rm -f cblas.tmp cblas.tmp2
394         @touch $(NETLIB_LAPACK_DIR)/make.inc
395         @$(MAKE) -C $(NETLIB_LAPACK_DIR) clean
396         @rm -f $(NETLIB_LAPACK_DIR)/make.inc $(NETLIB_LAPACK_DIR)/lapacke/include/lapacke_mangling.h
397         @$(MAKE) -C relapack clean
398         @rm -f *.grd Makefile.conf_last config_last.h
399         @(cd $(NETLIB_LAPACK_DIR)/TESTING && rm -f x* *.out testing_results.txt)
400         @echo Done.