You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

Makefile 14 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472
  1. ###############################################################################
  2. # Copyright (c) 2025, The OpenBLAS Project
  3. # All rights reserved.
  4. # Redistribution and use in source and binary forms, with or without
  5. # modification, are permitted provided that the following conditions are
  6. # met:
  7. # 1. Redistributions of source code must retain the above copyright
  8. # notice, this list of conditions and the following disclaimer.
  9. # 2. Redistributions in binary form must reproduce the above copyright
  10. # notice, this list of conditions and the following disclaimer in
  11. # the documentation and/or other materials provided with the
  12. # distribution.
  13. # 3. Neither the name of the OpenBLAS project nor the names of
  14. # its contributors may be used to endorse or promote products
  15. # derived from this software without specific prior written permission.
  16. #
  17. # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
  18. # AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  19. # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  20. # ARE DISCLAIMED. IN NO EVENT SHALL THE OPENBLAS PROJECT OR CONTRIBUTORS BE
  21. # LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
  22. # CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
  23. # SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
  24. # INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
  25. # CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
  26. # ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
  27. # POSSIBILITY OF SUCH DAMAGE.
  28. ###############################################################################
  29. TOPDIR = ..
  30. include ../Makefile.system
  31. ifeq ($(F_COMPILER),GFORTRAN)
  32. ifneq (, $(filter $(CORE),LOONGSON3R3 LOONGSON3R4))
  33. override FFLAGS := $(filter_out(-O2 -O3,$(FFLAGS))) -O0
  34. endif
  35. override FFLAGS += -fno-tree-vectorize
  36. endif
  37. override CFLAGS += -std=c11 -Wall -Werror
  38. SUPPORT_GEMM3M = 0
  39. ifeq ($(ARCH), x86)
  40. SUPPORT_GEMM3M = 1
  41. endif
  42. ifeq ($(ARCH), x86_64)
  43. SUPPORT_GEMM3M = 1
  44. endif
  45. ifeq ($(ARCH), ia64)
  46. SUPPORT_GEMM3M = 1
  47. endif
  48. ifeq ($(ARCH), MIPS)
  49. SUPPORT_GEMM3M = 1
  50. endif
  51. ifeq ($(NOFORTRAN),1)
  52. all ::
  53. else
  54. all :: level1 level2 level3
  55. endif
  56. ifeq ($(BUILD_SINGLE),1)
  57. S1=sblat1
  58. endif
  59. ifeq ($(BUILD_DOUBLE),1)
  60. D1=dblat1
  61. endif
  62. ifeq ($(BUILD_COMPLEX),1)
  63. C1=cblat1
  64. endif
  65. ifeq ($(BUILD_COMPLEX16),1)
  66. Z1=zblat1
  67. endif
  68. level1: $(S1) $(D1) $(C1) $(Z1)
  69. ifneq ($(CROSS), 1)
  70. ifeq ($(BUILD_SINGLE),1)
  71. OPENBLAS_NUM_THREADS=1 OMP_NUM_THREADS=1 ./sblat1
  72. endif
  73. ifeq ($(BUILD_DOUBLE),1)
  74. OPENBLAS_NUM_THREADS=1 OMP_NUM_THREADS=1 ./dblat1
  75. endif
  76. ifeq ($(BUILD_COMPLEX),1)
  77. OPENBLAS_NUM_THREADS=1 OMP_NUM_THREADS=1 ./cblat1
  78. endif
  79. ifeq ($(BUILD_COMPLEX16),1)
  80. OPENBLAS_NUM_THREADS=1 OMP_NUM_THREADS=1 ./zblat1
  81. endif
  82. ifdef SMP
  83. ifeq ($(USE_OPENMP), 1)
  84. ifeq ($(BUILD_SINGLE),1)
  85. OMP_NUM_THREADS=2 ./sblat1
  86. endif
  87. ifeq ($(BUILD_DOUBLE),1)
  88. OMP_NUM_THREADS=2 ./dblat1
  89. endif
  90. ifeq ($(BUILD_COMPLEX),1)
  91. OMP_NUM_THREADS=2 ./cblat1
  92. endif
  93. ifeq ($(BUILD_COMPLEX16),1)
  94. OMP_NUM_THREADS=2 ./zblat1
  95. endif
  96. else
  97. ifeq ($(BUILD_SINGLE),1)
  98. OPENBLAS_NUM_THREADS=2 ./sblat1
  99. endif
  100. ifeq ($(BUILD_DOUBLE),1)
  101. OPENBLAS_NUM_THREADS=2 ./dblat1
  102. endif
  103. ifeq ($(BUILD_COMPLEX),1)
  104. OPENBLAS_NUM_THREADS=2 ./cblat1
  105. endif
  106. ifeq ($(BUILD_COMPLEX16),1)
  107. OPENBLAS_NUM_THREADS=2 ./zblat1
  108. endif
  109. endif
  110. endif
  111. endif
  112. ifeq ($(BUILD_BFLOAT16), 1)
  113. BB2 = test_bgemv
  114. B2 = test_sbgemv
  115. endif
  116. ifeq ($(BUILD_SINGLE),1)
  117. S2=sblat2
  118. endif
  119. ifeq ($(BUILD_DOUBLE),1)
  120. D2=dblat2
  121. endif
  122. ifeq ($(BUILD_COMPLEX),1)
  123. C2=cblat2
  124. endif
  125. ifeq ($(BUILD_COMPLEX16),1)
  126. Z2=zblat2
  127. endif
  128. level2: $(BB2) $(B2) $(S2) $(D2) $(C2) $(Z2)
  129. ifneq ($(CROSS), 1)
  130. rm -f ?BLAT2.SUMM
  131. ifeq ($(BUILD_BFLOAT16),1)
  132. OPENBLAS_NUM_THREADS=1 OMP_NUM_THREADS=1 ./test_bgemv > BBLAT2.SUMM
  133. @$(GREP) -q FATAL BBLAT2.SUMM && cat BBLAT2.SUMM || exit 0
  134. OPENBLAS_NUM_THREADS=1 OMP_NUM_THREADS=1 ./test_sbgemv > SBBLAT2.SUMM
  135. @$(GREP) -q FATAL SBBLAT2.SUMM && cat SBBLAT2.SUMM || exit 0
  136. endif
  137. ifeq ($(BUILD_SINGLE),1)
  138. OPENBLAS_NUM_THREADS=1 OMP_NUM_THREADS=1 ./sblat2 < ./sblat2.dat
  139. @$(GREP) -q FATAL SBLAT2.SUMM && cat SBLAT2.SUMM || exit 0
  140. endif
  141. ifeq ($(BUILD_DOUBLE),1)
  142. OPENBLAS_NUM_THREADS=1 OMP_NUM_THREADS=1 ./dblat2 < ./dblat2.dat
  143. @$(GREP) -q FATAL DBLAT2.SUMM && cat DBLAT2.SUMM || exit 0
  144. endif
  145. ifeq ($(BUILD_COMPLEX),1)
  146. OPENBLAS_NUM_THREADS=1 OMP_NUM_THREADS=1 ./cblat2 < ./cblat2.dat
  147. @$(GREP) -q FATAL CBLAT2.SUMM && cat CBLAT2.SUMM || exit 0
  148. endif
  149. ifeq ($(BUILD_COMPLEX16),1)
  150. OPENBLAS_NUM_THREADS=1 OMP_NUM_THREADS=1 ./zblat2 < ./zblat2.dat
  151. @$(GREP) -q FATAL ZBLAT2.SUMM && cat ZBLAT2.SUMM || exit 0
  152. endif
  153. ifdef SMP
  154. rm -f ?BLAT2.SUMM
  155. ifeq ($(USE_OPENMP), 1)
  156. ifeq ($(BUILD_BFLOAT16),1)
  157. OMP_NUM_THREADS=2 ./test_bgemv > BBLAT2.SUMM
  158. @$(GREP) -q FATAL BBLAT2.SUMM && cat BBLAT2.SUMM || exit 0
  159. OMP_NUM_THREADS=2 ./test_sbgemv > SBBLAT2.SUMM
  160. @$(GREP) -q FATAL SBBLAT2.SUMM && cat SBBLAT2.SUMM || exit 0
  161. endif
  162. ifeq ($(BUILD_SINGLE),1)
  163. OMP_NUM_THREADS=2 ./sblat2 < ./sblat2.dat
  164. @$(GREP) -q FATAL SBLAT2.SUMM && cat SBLAT2.SUMM || exit 0
  165. endif
  166. ifeq ($(BUILD_DOUBLE),1)
  167. OMP_NUM_THREADS=2 ./dblat2 < ./dblat2.dat
  168. @$(GREP) -q FATAL DBLAT2.SUMM && cat DBLAT2.SUMM || exit 0
  169. endif
  170. ifeq ($(BUILD_COMPLEX),1)
  171. OMP_NUM_THREADS=2 ./cblat2 < ./cblat2.dat
  172. @$(GREP) -q FATAL CBLAT2.SUMM && cat CBLAT2.SUMM || exit 0
  173. endif
  174. ifeq ($(BUILD_COMPLEX16),1)
  175. OMP_NUM_THREADS=2 ./zblat2 < ./zblat2.dat
  176. @$(GREP) -q FATAL ZBLAT2.SUMM && cat ZBLAT2.SUMM || exit 0
  177. endif
  178. else
  179. ifeq ($(BUILD_BFLOAT16),1)
  180. OMP_NUM_THREADS=2 ./test_bgemv > BBLAT2.SUMM
  181. @$(GREP) -q FATAL BBLAT2.SUMM && cat BBLAT2.SUMM || exit 0
  182. OMP_NUM_THREADS=2 ./test_sbgemv > SBBLAT2.SUMM
  183. @$(GREP) -q FATAL SBBLAT2.SUMM && cat SBBLAT2.SUMM || exit 0
  184. endif
  185. ifeq ($(BUILD_SINGLE),1)
  186. OPENBLAS_NUM_THREADS=2 ./sblat2 < ./sblat2.dat
  187. @$(GREP) -q FATAL SBLAT2.SUMM && cat SBLAT2.SUMM || exit 0
  188. endif
  189. ifeq ($(BUILD_DOUBLE),1)
  190. OPENBLAS_NUM_THREADS=2 ./dblat2 < ./dblat2.dat
  191. @$(GREP) -q FATAL DBLAT2.SUMM && cat DBLAT2.SUMM || exit 0
  192. endif
  193. ifeq ($(BUILD_COMPLEX),1)
  194. OPENBLAS_NUM_THREADS=2 ./cblat2 < ./cblat2.dat
  195. @$(GREP) -q FATAL CBLAT2.SUMM && cat CBLAT2.SUMM || exit 0
  196. endif
  197. ifeq ($(BUILD_COMPLEX16),1)
  198. OPENBLAS_NUM_THREADS=2 ./zblat2 < ./zblat2.dat
  199. @$(GREP) -q FATAL ZBLAT2.SUMM && cat ZBLAT2.SUMM || exit 0
  200. endif
  201. endif
  202. endif
  203. endif
  204. ifeq ($(BUILD_BFLOAT16),1)
  205. BF3= test_bgemm
  206. B3 = test_sbgemm
  207. endif
  208. ifeq ($(BUILD_SINGLE),1)
  209. S3=sblat3
  210. endif
  211. ifeq ($(BUILD_DOUBLE),1)
  212. D3=dblat3
  213. endif
  214. ifeq ($(BUILD_COMPLEX),1)
  215. ifeq ($(SUPPORT_GEMM3M),1)
  216. C3=cblat3 cblat3_3m
  217. else
  218. C3=cblat3
  219. endif
  220. endif
  221. ifeq ($(BUILD_COMPLEX16),1)
  222. ifeq ($(SUPPORT_GEMM3M),1)
  223. Z3=zblat3 zblat3_3m
  224. else
  225. Z3=zblat3
  226. endif
  227. endif
  228. ifeq ($(SUPPORT_GEMM3M),1)
  229. level3: $(B3) $(S3) $(D3) $(C3) $(Z3) level3_3m
  230. else
  231. level3: $(BF3) $(B3) $(S3) $(D3) $(C3) $(Z3)
  232. endif
  233. ifneq ($(CROSS), 1)
  234. rm -f ?BLAT3.SUMM
  235. ifeq ($(BUILD_BFLOAT16),1)
  236. OPENBLAS_NUM_THREADS=1 OMP_NUM_THREADS=1 ./test_sbgemm > SBBLAT3.SUMM
  237. @$(GREP) -q FATAL SBBLAT3.SUMM && cat SBBLAT3.SUMM || exit 0
  238. OPENBLAS_NUM_THREADS=1 OMP_NUM_THREADS=1 ./test_bgemm > BBLAT3.SUMM
  239. @$(GREP) -q FATAL BBLAT3.SUMM && cat BBLAT3.SUMM || exit 0
  240. endif
  241. ifeq ($(BUILD_SINGLE),1)
  242. OPENBLAS_NUM_THREADS=1 OMP_NUM_THREADS=1 ./sblat3 < ./sblat3.dat
  243. @$(GREP) -q FATAL SBLAT3.SUMM && cat SBLAT3.SUMM || exit 0
  244. endif
  245. ifeq ($(BUILD_DOUBLE),1)
  246. OPENBLAS_NUM_THREADS=1 OMP_NUM_THREADS=1 ./dblat3 < ./dblat3.dat
  247. @$(GREP) -q FATAL DBLAT3.SUMM && cat DBLAT3.SUMM || exit 0
  248. endif
  249. ifeq ($(BUILD_COMPLEX),1)
  250. OPENBLAS_NUM_THREADS=1 OMP_NUM_THREADS=1 ./cblat3 < ./cblat3.dat
  251. @$(GREP) -q FATAL CBLAT3.SUMM && cat CBLAT3.SUMM || exit 0
  252. endif
  253. ifeq ($(BUILD_COMPLEX16),1)
  254. OPENBLAS_NUM_THREADS=1 OMP_NUM_THREADS=1 ./zblat3 < ./zblat3.dat
  255. @$(GREP) -q FATAL ZBLAT3.SUMM && cat ZBLAT3.SUMM || exit 0
  256. endif
  257. ifdef SMP
  258. rm -f ?BLAT3.SUMM
  259. ifeq ($(USE_OPENMP), 1)
  260. ifeq ($(BUILD_BFLOAT16),1)
  261. OMP_NUM_THREADS=2 ./test_sbgemm > SBBLAT3.SUMM
  262. @$(GREP) -q FATAL SBBLAT3.SUMM && cat SBBLAT3.SUMM || exit 0
  263. OMP_NUM_THREADS=2 ./test_bgemm > BBLAT3.SUMM
  264. @$(GREP) -q FATAL BBLAT3.SUMM && cat BBLAT3.SUMM || exit 0
  265. endif
  266. ifeq ($(BUILD_SINGLE),1)
  267. OMP_NUM_THREADS=2 ./sblat3 < ./sblat3.dat
  268. @$(GREP) -q FATAL SBLAT3.SUMM && cat SBLAT3.SUMM || exit 0
  269. endif
  270. ifeq ($(BUILD_DOUBLE),1)
  271. OMP_NUM_THREADS=2 ./dblat3 < ./dblat3.dat
  272. @$(GREP) -q FATAL DBLAT3.SUMM && cat DBLAT3.SUMM || exit 0
  273. endif
  274. ifeq ($(BUILD_COMPLEX),1)
  275. OMP_NUM_THREADS=2 ./cblat3 < ./cblat3.dat
  276. @$(GREP) -q FATAL CBLAT3.SUMM && cat CBLAT3.SUMM || exit 0
  277. endif
  278. ifeq ($(BUILD_COMPLEX16),1)
  279. OMP_NUM_THREADS=2 ./zblat3 < ./zblat3.dat
  280. @$(GREP) -q FATAL ZBLAT3.SUMM && cat ZBLAT3.SUMM || exit 0
  281. endif
  282. else
  283. ifeq ($(BUILD_BFLOAT16),1)
  284. OPENBLAS_NUM_THREADS=2 ./test_sbgemm > SBBLAT3.SUMM
  285. @$(GREP) -q FATAL SBBLAT3.SUMM && cat SBBLAT3.SUMM || exit 0
  286. OPENBLAS_NUM_THREADS=2 ./test_bgemm > BBLAT3.SUMM
  287. @$(GREP) -q FATAL BBLAT3.SUMM && cat BBLAT3.SUMM || exit 0
  288. endif
  289. ifeq ($(BUILD_SINGLE),1)
  290. OPENBLAS_NUM_THREADS=2 ./sblat3 < ./sblat3.dat
  291. @$(GREP) -q FATAL SBLAT3.SUMM && cat SBLAT3.SUMM || exit 0
  292. endif
  293. ifeq ($(BUILD_DOUBLE),1)
  294. OPENBLAS_NUM_THREADS=2 ./dblat3 < ./dblat3.dat
  295. @$(GREP) -q FATAL DBLAT3.SUMM && cat DBLAT3.SUMM || exit 0
  296. endif
  297. ifeq ($(BUILD_COMPLEX),1)
  298. OPENBLAS_NUM_THREADS=2 ./cblat3 < ./cblat3.dat
  299. @$(GREP) -q FATAL CBLAT3.SUMM && cat CBLAT3.SUMM || exit 0
  300. endif
  301. ifeq ($(BUILD_COMPLEX16),1)
  302. OPENBLAS_NUM_THREADS=2 ./zblat3 < ./zblat3.dat
  303. @$(GREP) -q FATAL ZBLAT3.SUMM && cat ZBLAT3.SUMM || exit 0
  304. endif
  305. endif
  306. endif
  307. endif
  308. level3_3m: zblat3_3m cblat3_3m
  309. ifneq ($(CROSS), 1)
  310. rm -f ?BLAT3_3M.SUMM
  311. OPENBLAS_NUM_THREADS=1 OMP_NUM_THREADS=1 ./cblat3_3m < ./cblat3_3m.dat
  312. @$(GREP) -q FATAL CBLAT3_3M.SUMM && cat CBLAT3_3M.SUMM || exit 0
  313. OPENBLAS_NUM_THREADS=1 OMP_NUM_THREADS=1 ./zblat3_3m < ./zblat3_3m.dat
  314. @$(GREP) -q FATAL ZBLAT3_3M.SUMM && cat ZBLAT3_3M.SUMM || exit 0
  315. ifdef SMP
  316. rm -f ?BLAT3_3M.SUMM
  317. ifeq ($(USE_OPENMP), 1)
  318. OMP_NUM_THREADS=2 ./cblat3_3m < ./cblat3_3m.dat
  319. @$(GREP) -q FATAL CBLAT3_3M.SUMM && cat CBLAT3_3M.SUMM || exit 0
  320. OMP_NUM_THREADS=2 ./zblat3_3m < ./zblat3_3m.dat
  321. @$(GREP) -q FATAL ZBLAT3_3M.SUMM && cat ZBLAT3_3M.SUMM || exit 0
  322. else
  323. OPENBLAS_NUM_THREADS=2 ./cblat3_3m < ./cblat3_3m.dat
  324. @$(GREP) -q FATAL CBLAT3_3M.SUMM && cat CBLAT3_3M.SUMM || exit 0
  325. OPENBLAS_NUM_THREADS=2 ./zblat3_3m < ./zblat3_3m.dat
  326. @$(GREP) -q FATAL ZBLAT3_3M.SUMM && cat ZBLAT3_3M.SUMM || exit 0
  327. endif
  328. endif
  329. endif
  330. FLDFLAGS = $(FFLAGS:-fPIC=) $(LDFLAGS)
  331. CLDFLAGS = $(CFLAGS) $(LDFLAGS)
  332. ifeq ($(USE_OPENMP), 1)
  333. ifeq ($(F_COMPILER), GFORTRAN)
  334. ifeq ($(C_COMPILER), CLANG)
  335. EXTRALIB += -lomp
  336. endif
  337. endif
  338. ifeq ($(F_COMPILER), NAG)
  339. EXTRALIB = -lgomp
  340. endif
  341. ifeq ($(F_COMPILER), IBM)
  342. ifeq ($(C_COMPILER), GCC)
  343. EXTRALIB += -lgomp
  344. endif
  345. ifeq ($(C_COMPILER), CLANG)
  346. EXTRALIB += -lomp
  347. endif
  348. endif
  349. endif
  350. ifeq ($(BUILD_SINGLE),1)
  351. sblat1 : sblat1.$(SUFFIX) ../$(LIBNAME)
  352. $(FC) $(FLDFLAGS) -o sblat1 sblat1.$(SUFFIX) ../$(LIBNAME) $(EXTRALIB) $(CEXTRALIB)
  353. sblat2 : sblat2.$(SUFFIX) ../$(LIBNAME)
  354. $(FC) $(FLDFLAGS) -o sblat2 sblat2.$(SUFFIX) ../$(LIBNAME) $(EXTRALIB) $(CEXTRALIB)
  355. sblat3 : sblat3.$(SUFFIX) ../$(LIBNAME)
  356. $(FC) $(FLDFLAGS) -o sblat3 sblat3.$(SUFFIX) ../$(LIBNAME) $(EXTRALIB) $(CEXTRALIB)
  357. endif
  358. ifeq ($(BUILD_DOUBLE),1)
  359. dblat1 : dblat1.$(SUFFIX) ../$(LIBNAME)
  360. $(FC) $(FLDFLAGS) -o dblat1 dblat1.$(SUFFIX) ../$(LIBNAME) $(EXTRALIB) $(CEXTRALIB)
  361. dblat2 : dblat2.$(SUFFIX) ../$(LIBNAME)
  362. $(FC) $(FLDFLAGS) -o dblat2 dblat2.$(SUFFIX) ../$(LIBNAME) $(EXTRALIB) $(CEXTRALIB)
  363. dblat3 : dblat3.$(SUFFIX) ../$(LIBNAME)
  364. $(FC) $(FLDFLAGS) -o dblat3 dblat3.$(SUFFIX) ../$(LIBNAME) $(EXTRALIB) $(CEXTRALIB)
  365. else
  366. dblat2:
  367. dblat3:
  368. endif
  369. qblat1 : qblat1.$(SUFFIX) ../$(LIBNAME)
  370. $(FC) $(FLDFLAGS) -o qblat1 qblat1.$(SUFFIX) ../$(LIBNAME) $(EXTRALIB) $(CEXTRALIB)
  371. ifeq ($(BUILD_COMPLEX),1)
  372. cblat1 : cblat1.$(SUFFIX) ../$(LIBNAME)
  373. $(FC) $(FLDFLAGS) -o cblat1 cblat1.$(SUFFIX) ../$(LIBNAME) $(EXTRALIB) $(CEXTRALIB)
  374. cblat2 : cblat2.$(SUFFIX) ../$(LIBNAME)
  375. $(FC) $(FLDFLAGS) -o cblat2 cblat2.$(SUFFIX) ../$(LIBNAME) $(EXTRALIB) $(CEXTRALIB)
  376. cblat3 : cblat3.$(SUFFIX) ../$(LIBNAME)
  377. $(FC) $(FLDFLAGS) -o cblat3 cblat3.$(SUFFIX) ../$(LIBNAME) $(EXTRALIB) $(CEXTRALIB)
  378. endif
  379. ifeq ($(BUILD_COMPLEX16),1)
  380. zblat1 : zblat1.$(SUFFIX) ../$(LIBNAME)
  381. $(FC) $(FLDFLAGS) -o zblat1 zblat1.$(SUFFIX) ../$(LIBNAME) $(EXTRALIB) $(CEXTRALIB)
  382. zblat2 : zblat2.$(SUFFIX) ../$(LIBNAME)
  383. $(FC) $(FLDFLAGS) -o zblat2 zblat2.$(SUFFIX) ../$(LIBNAME) $(EXTRALIB) $(CEXTRALIB)
  384. zblat3 : zblat3.$(SUFFIX) ../$(LIBNAME)
  385. $(FC) $(FLDFLAGS) -o zblat3 zblat3.$(SUFFIX) ../$(LIBNAME) $(EXTRALIB) $(CEXTRALIB)
  386. endif
  387. ifeq ($(BUILD_BFLOAT16),1)
  388. test_bgemm : compare_sgemm_bgemm.c test_helpers.h ../$(LIBNAME)
  389. $(CC) $(CLDFLAGS) -DIBFLOAT16 -DOBFLOAT16 -o test_bgemm compare_sgemm_bgemm.c ../$(LIBNAME) $(EXTRALIB) $(CEXTRALIB)
  390. test_bgemv : compare_sgemv_bgemv.c ../$(LIBNAME)
  391. $(CC) $(CLDFLAGS) -DIBFLOAT16 -DOBFLOAT16 -o test_bgemv compare_sgemv_bgemv.c ../$(LIBNAME) $(EXTRALIB) $(CEXTRALIB)
  392. test_sbgemm : compare_sgemm_sbgemm.c test_helpers.h ../$(LIBNAME)
  393. $(CC) $(CLDFLAGS) -DIBFLOAT16 -o test_sbgemm compare_sgemm_sbgemm.c ../$(LIBNAME) $(EXTRALIB) $(CEXTRALIB)
  394. test_sbgemv : compare_sgemv_sbgemv.c ../$(LIBNAME)
  395. $(CC) $(CLDFLAGS) -DIBFLOAT16 -o test_sbgemv compare_sgemv_sbgemv.c ../$(LIBNAME) $(EXTRALIB) $(CEXTRALIB)
  396. endif
  397. ifeq ($(BUILD_COMPLEX),1)
  398. cblat3_3m : cblat3_3m.$(SUFFIX) ../$(LIBNAME)
  399. $(FC) $(FLDFLAGS) -o cblat3_3m cblat3_3m.$(SUFFIX) ../$(LIBNAME) $(EXTRALIB) $(CEXTRALIB)
  400. endif
  401. ifeq ($(BUILD_COMPLEX16),1)
  402. zblat3_3m : zblat3_3m.$(SUFFIX) ../$(LIBNAME)
  403. $(FC) $(FLDFLAGS) -o zblat3_3m zblat3_3m.$(SUFFIX) ../$(LIBNAME) $(EXTRALIB) $(CEXTRALIB)
  404. endif
  405. clean:
  406. @rm -f *.$(SUFFIX) *.$(PSUFFIX) gmon.$(SUFFIX)ut *.SUMM *.cxml *.exe *.pdb *.dwf \
  407. sblat1 dblat1 cblat1 zblat1 \
  408. sblat2 dblat2 cblat2 zblat2 \
  409. test_bgemm test_bgemv test_sbgemm test_sbgemv sblat3 dblat3 cblat3 zblat3 \
  410. sblat1p dblat1p cblat1p zblat1p \
  411. sblat2p dblat2p cblat2p zblat2p \
  412. sblat3p dblat3p cblat3p zblat3p \
  413. zblat3_3m zblat3_3mp \
  414. cblat3_3m cblat3_3mp \
  415. *.stackdump *.dll
  416. libs:
  417. prof:
  418. quick :
  419. $(MAKE) -C $(TOPDIR) libs
  420. # include ../Makefile.tail