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 9.8 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363
  1. TOPDIR = ..
  2. include ../Makefile.system
  3. ifeq ($(F_COMPILER),GFORTRAN)
  4. override FFLAGS += -fno-tree-vectorize
  5. endif
  6. ifeq ($(NOFORTRAN),1)
  7. all ::
  8. else
  9. all :: level1 level2 level3
  10. endif
  11. ifeq ($(BUILD_SINGLE),1)
  12. S1=sblat1
  13. endif
  14. ifeq ($(BUILD_DOUBLE),1)
  15. D1=dblat1
  16. endif
  17. ifeq ($(BUILD_COMPLEX),1)
  18. C1=cblat1
  19. endif
  20. ifeq ($(BUILD_COMPLEX16),1)
  21. Z1=zblat1
  22. endif
  23. level1: $(S1) $(D1) $(C1) $(Z1)
  24. ifneq ($(CROSS), 1)
  25. ifeq ($(BUILD_SINGLE),1)
  26. OPENBLAS_NUM_THREADS=1 OMP_NUM_THREADS=1 ./sblat1
  27. endif
  28. ifeq ($(BUILD_DOUBLE),1)
  29. OPENBLAS_NUM_THREADS=1 OMP_NUM_THREADS=1 ./dblat1
  30. endif
  31. ifeq ($(BUILD_COMPLEX),1)
  32. OPENBLAS_NUM_THREADS=1 OMP_NUM_THREADS=1 ./cblat1
  33. endif
  34. ifeq ($(BUILD_COMPLEX16),1)
  35. OPENBLAS_NUM_THREADS=1 OMP_NUM_THREADS=1 ./zblat1
  36. endif
  37. ifdef SMP
  38. ifeq ($(USE_OPENMP), 1)
  39. ifeq ($(BUILD_SINGLE),1)
  40. OMP_NUM_THREADS=2 ./sblat1
  41. endif
  42. ifeq ($(BUILD_DOUBLE),1)
  43. OMP_NUM_THREADS=2 ./dblat1
  44. endif
  45. ifeq ($(BUILD_COMPLEX),1)
  46. OMP_NUM_THREADS=2 ./cblat1
  47. endif
  48. ifeq ($(BUILD_COMPLEX16),1)
  49. OMP_NUM_THREADS=2 ./zblat1
  50. endif
  51. else
  52. ifeq ($(BUILD_SINGLE),1)
  53. OPENBLAS_NUM_THREADS=2 ./sblat1
  54. endif
  55. ifeq ($(BUILD_DOUBLE),1)
  56. OPENBLAS_NUM_THREADS=2 ./dblat1
  57. endif
  58. ifeq ($(BUILD_COMPLEX),1)
  59. OPENBLAS_NUM_THREADS=2 ./cblat1
  60. endif
  61. ifeq ($(BUILD_COMPLEX16),1)
  62. OPENBLAS_NUM_THREADS=2 ./zblat1
  63. endif
  64. endif
  65. endif
  66. endif
  67. ifeq ($(BUILD_SINGLE),1)
  68. S2=sblat2
  69. endif
  70. ifeq ($(BUILD_DOUBLE),1)
  71. D2=dblat2
  72. endif
  73. ifeq ($(BUILD_COMPLEX),1)
  74. C2=cblat2
  75. endif
  76. ifeq ($(BUILD_COMPLEX16),1)
  77. Z2=zblat2
  78. endif
  79. level2: $(S2) $(D2) $(C2) $(Z2)
  80. ifneq ($(CROSS), 1)
  81. rm -f ?BLAT2.SUMM
  82. ifeq ($(BUILD_SINGLE),1)
  83. OPENBLAS_NUM_THREADS=1 OMP_NUM_THREADS=1 ./sblat2 < ./sblat2.dat
  84. @$(GREP) -q FATAL SBLAT2.SUMM && cat SBLAT2.SUMM || exit 0
  85. endif
  86. ifeq ($(BUILD_DOUBLE),1)
  87. OPENBLAS_NUM_THREADS=1 OMP_NUM_THREADS=1 ./dblat2 < ./dblat2.dat
  88. @$(GREP) -q FATAL DBLAT2.SUMM && cat DBLAT2.SUMM || exit 0
  89. endif
  90. ifeq ($(BUILD_COMPLEX),1)
  91. OPENBLAS_NUM_THREADS=1 OMP_NUM_THREADS=1 ./cblat2 < ./cblat2.dat
  92. @$(GREP) -q FATAL CBLAT2.SUMM && cat CBLAT2.SUMM || exit 0
  93. endif
  94. ifeq ($(BUILD_COMPLEX16),1)
  95. OPENBLAS_NUM_THREADS=1 OMP_NUM_THREADS=1 ./zblat2 < ./zblat2.dat
  96. @$(GREP) -q FATAL ZBLAT2.SUMM && cat ZBLAT2.SUMM || exit 0
  97. endif
  98. ifdef SMP
  99. rm -f ?BLAT2.SUMM
  100. ifeq ($(USE_OPENMP), 1)
  101. ifeq ($(BUILD_SINGLE),1)
  102. OMP_NUM_THREADS=2 ./sblat2 < ./sblat2.dat
  103. @$(GREP) -q FATAL SBLAT2.SUMM && cat SBLAT2.SUMM || exit 0
  104. endif
  105. ifeq ($(BUILD_DOUBLE),1)
  106. OMP_NUM_THREADS=2 ./dblat2 < ./dblat2.dat
  107. @$(GREP) -q FATAL DBLAT2.SUMM && cat DBLAT2.SUMM || exit 0
  108. endif
  109. ifeq ($(BUILD_COMPLEX),1)
  110. OMP_NUM_THREADS=2 ./cblat2 < ./cblat2.dat
  111. @$(GREP) -q FATAL CBLAT2.SUMM && cat CBLAT2.SUMM || exit 0
  112. endif
  113. ifeq ($(BUILD_COMPLEX16),1)
  114. OMP_NUM_THREADS=2 ./zblat2 < ./zblat2.dat
  115. @$(GREP) -q FATAL ZBLAT2.SUMM && cat ZBLAT2.SUMM || exit 0
  116. endif
  117. else
  118. ifeq ($(BUILD_SINGLE),1)
  119. OPENBLAS_NUM_THREADS=2 ./sblat2 < ./sblat2.dat
  120. @$(GREP) -q FATAL SBLAT2.SUMM && cat SBLAT2.SUMM || exit 0
  121. endif
  122. ifeq ($(BUILD_DOUBLE),1)
  123. OPENBLAS_NUM_THREADS=2 ./dblat2 < ./dblat2.dat
  124. @$(GREP) -q FATAL DBLAT2.SUMM && cat DBLAT2.SUMM || exit 0
  125. endif
  126. ifeq ($(BUILD_COMPLEX),1)
  127. OPENBLAS_NUM_THREADS=2 ./cblat2 < ./cblat2.dat
  128. @$(GREP) -q FATAL CBLAT2.SUMM && cat CBLAT2.SUMM || exit 0
  129. endif
  130. ifeq ($(BUILD_COMPLEX16),1)
  131. OPENBLAS_NUM_THREADS=2 ./zblat2 < ./zblat2.dat
  132. @$(GREP) -q FATAL ZBLAT2.SUMM && cat ZBLAT2.SUMM || exit 0
  133. endif
  134. endif
  135. endif
  136. endif
  137. ifeq ($(BUILD_BFLOAT16),1)
  138. B3= test_sbgemm
  139. endif
  140. ifeq ($(BUILD_SINGLE),1)
  141. S3=sblat3
  142. endif
  143. ifeq ($(BUILD_DOUBLE),1)
  144. D3=dblat3
  145. endif
  146. ifeq ($(BUILD_COMPLEX),1)
  147. C3=cblat3
  148. endif
  149. ifeq ($(BUILD_COMPLEX16),1)
  150. Z3=zblat3
  151. endif
  152. level3: $(B3) $(S3) $(D3) $(C3) $(Z3)
  153. ifneq ($(CROSS), 1)
  154. rm -f ?BLAT3.SUMM
  155. ifeq ($(BUILD_BFLOAT16),1)
  156. OPENBLAS_NUM_THREADS=1 OMP_NUM_THREADS=1 ./test_sbgemm > SBBLAT3.SUMM
  157. @$(GREP) -q FATAL SBBLAT3.SUMM && cat SBBLAT3.SUMM || exit 0
  158. endif
  159. ifeq ($(BUILD_SINGLE),1)
  160. OPENBLAS_NUM_THREADS=1 OMP_NUM_THREADS=1 ./sblat3 < ./sblat3.dat
  161. @$(GREP) -q FATAL SBLAT3.SUMM && cat SBLAT3.SUMM || exit 0
  162. endif
  163. ifeq ($(BUILD_DOUBLE),1)
  164. OPENBLAS_NUM_THREADS=1 OMP_NUM_THREADS=1 ./dblat3 < ./dblat3.dat
  165. @$(GREP) -q FATAL DBLAT3.SUMM && cat DBLAT3.SUMM || exit 0
  166. endif
  167. ifeq ($(BUILD_COMPLEX),1)
  168. OPENBLAS_NUM_THREADS=1 OMP_NUM_THREADS=1 ./cblat3 < ./cblat3.dat
  169. @$(GREP) -q FATAL CBLAT3.SUMM && cat CBLAT3.SUMM || exit 0
  170. endif
  171. ifeq ($(BUILD_COMPLEX16),1)
  172. OPENBLAS_NUM_THREADS=1 OMP_NUM_THREADS=1 ./zblat3 < ./zblat3.dat
  173. @$(GREP) -q FATAL ZBLAT3.SUMM && cat ZBLAT3.SUMM || exit 0
  174. endif
  175. ifdef SMP
  176. rm -f ?BLAT3.SUMM
  177. ifeq ($(USE_OPENMP), 1)
  178. ifeq ($(BUILD_BFLOAT16),1)
  179. OMP_NUM_THREADS=2 ./test_sbgemm > SBBLAT3.SUMM
  180. @$(GREP) -q FATAL SBBLAT3.SUMM && cat SBBLAT3.SUMM || exit 0
  181. endif
  182. ifeq ($(BUILD_SINGLE),1)
  183. OMP_NUM_THREADS=2 ./sblat3 < ./sblat3.dat
  184. @$(GREP) -q FATAL SBLAT3.SUMM && cat SBLAT3.SUMM || exit 0
  185. endif
  186. ifeq ($(BUILD_DOUBLE),1)
  187. OMP_NUM_THREADS=2 ./dblat3 < ./dblat3.dat
  188. @$(GREP) -q FATAL DBLAT3.SUMM && cat DBLAT3.SUMM || exit 0
  189. endif
  190. ifeq ($(BUILD_COMPLEX),1)
  191. OMP_NUM_THREADS=2 ./cblat3 < ./cblat3.dat
  192. @$(GREP) -q FATAL CBLAT3.SUMM && cat CBLAT3.SUMM || exit 0
  193. endif
  194. ifeq ($(BUILD_COMPLEX16),1)
  195. OMP_NUM_THREADS=2 ./zblat3 < ./zblat3.dat
  196. @$(GREP) -q FATAL ZBLAT3.SUMM && cat ZBLAT3.SUMM || exit 0
  197. endif
  198. else
  199. ifeq ($(BUILD_BFLOAT16),1)
  200. OPENBLAS_NUM_THREADS=2 ./test_sbgemm > SBBLAT3.SUMM
  201. @$(GREP) -q FATAL SBBLAT3.SUMM && cat SBBLAT3.SUMM || exit 0
  202. endif
  203. ifeq ($(BUILD_SINGLE),1)
  204. OPENBLAS_NUM_THREADS=2 ./sblat3 < ./sblat3.dat
  205. @$(GREP) -q FATAL SBLAT3.SUMM && cat SBLAT3.SUMM || exit 0
  206. endif
  207. ifeq ($(BUILD_DOUBLE),1)
  208. OPENBLAS_NUM_THREADS=2 ./dblat3 < ./dblat3.dat
  209. @$(GREP) -q FATAL DBLAT3.SUMM && cat DBLAT3.SUMM || exit 0
  210. endif
  211. ifeq ($(BUILD_COMPLEX),1)
  212. OPENBLAS_NUM_THREADS=2 ./cblat3 < ./cblat3.dat
  213. @$(GREP) -q FATAL CBLAT3.SUMM && cat CBLAT3.SUMM || exit 0
  214. endif
  215. ifeq ($(BUILD_COMPLEX16),1)
  216. OPENBLAS_NUM_THREADS=2 ./zblat3 < ./zblat3.dat
  217. @$(GREP) -q FATAL ZBLAT3.SUMM && cat ZBLAT3.SUMM || exit 0
  218. endif
  219. endif
  220. endif
  221. endif
  222. level3_3m : zblat3_3m cblat3_3m
  223. ifneq ($(CROSS), 1)
  224. rm -f ?BLAT3_3M.SUMM
  225. OPENBLAS_NUM_THREADS=1 OMP_NUM_THREADS=1 ./cblat3_3m < ./cblat3_3m.dat
  226. @$(GREP) -q FATAL CBLAT3_3M.SUMM && cat CBLAT3_3M.SUMM || exit 0
  227. OPENBLAS_NUM_THREADS=1 OMP_NUM_THREADS=1 ./zblat3_3m < ./zblat3_3m.dat
  228. @$(GREP) -q FATAL ZBLAT3_3M.SUMM && cat ZBLAT3_3M.SUMM || exit 0
  229. ifdef SMP
  230. rm -f ?BLAT3_3M.SUMM
  231. ifeq ($(USE_OPENMP), 1)
  232. OMP_NUM_THREADS=2 ./cblat3_3m < ./cblat3_3m.dat
  233. @$(GREP) -q FATAL CBLAT3_3M.SUMM && cat CBLAT3_3M.SUMM || exit 0
  234. OMP_NUM_THREADS=2 ./zblat3_3m < ./zblat3_3m.dat
  235. @$(GREP) -q FATAL ZBLAT3_3M.SUMM && cat ZBLAT3_3M.SUMM || exit 0
  236. else
  237. OPENBLAS_NUM_THREADS=2 ./cblat3_3m < ./cblat3_3m.dat
  238. @$(GREP) -q FATAL CBLAT3_3M.SUMM && cat CBLAT3_3M.SUMM || exit 0
  239. OPENBLAS_NUM_THREADS=2 ./zblat3_3m < ./zblat3_3m.dat
  240. @$(GREP) -q FATAL ZBLAT3_3M.SUMM && cat ZBLAT3_3M.SUMM || exit 0
  241. endif
  242. endif
  243. endif
  244. FLDFLAGS = $(FFLAGS:-fPIC=) $(LDFLAGS)
  245. ifeq ($(USE_OPENMP), 1)
  246. ifeq ($(F_COMPILER), GFORTRAN)
  247. ifeq ($(C_COMPILER), CLANG)
  248. CEXTRALIB = -lomp
  249. endif
  250. endif
  251. ifeq ($(F_COMPILER), NAG)
  252. CEXTRALIB = -lgomp
  253. endif
  254. endif
  255. ifeq ($(BUILD_SINGLE),1)
  256. sblat1 : sblat1.$(SUFFIX) ../$(LIBNAME)
  257. $(FC) $(FLDFLAGS) -o sblat1 sblat1.$(SUFFIX) ../$(LIBNAME) $(EXTRALIB) $(CEXTRALIB)
  258. sblat2 : sblat2.$(SUFFIX) ../$(LIBNAME)
  259. $(FC) $(FLDFLAGS) -o sblat2 sblat2.$(SUFFIX) ../$(LIBNAME) $(EXTRALIB) $(CEXTRALIB)
  260. sblat3 : sblat3.$(SUFFIX) ../$(LIBNAME)
  261. $(FC) $(FLDFLAGS) -o sblat3 sblat3.$(SUFFIX) ../$(LIBNAME) $(EXTRALIB) $(CEXTRALIB)
  262. endif
  263. ifeq ($(BUILD_DOUBLE),1)
  264. dblat1 : dblat1.$(SUFFIX) ../$(LIBNAME)
  265. $(FC) $(FLDFLAGS) -o dblat1 dblat1.$(SUFFIX) ../$(LIBNAME) $(EXTRALIB) $(CEXTRALIB)
  266. dblat2 : dblat2.$(SUFFIX) ../$(LIBNAME)
  267. $(FC) $(FLDFLAGS) -o dblat2 dblat2.$(SUFFIX) ../$(LIBNAME) $(EXTRALIB) $(CEXTRALIB)
  268. dblat3 : dblat3.$(SUFFIX) ../$(LIBNAME)
  269. $(FC) $(FLDFLAGS) -o dblat3 dblat3.$(SUFFIX) ../$(LIBNAME) $(EXTRALIB) $(CEXTRALIB)
  270. else
  271. dblat2:
  272. dblat3:
  273. endif
  274. qblat1 : qblat1.$(SUFFIX) ../$(LIBNAME)
  275. $(FC) $(FLDFLAGS) -o qblat1 qblat1.$(SUFFIX) ../$(LIBNAME) $(EXTRALIB) $(CEXTRALIB)
  276. ifeq ($(BUILD_COMPLEX),1)
  277. cblat1 : cblat1.$(SUFFIX) ../$(LIBNAME)
  278. $(FC) $(FLDFLAGS) -o cblat1 cblat1.$(SUFFIX) ../$(LIBNAME) $(EXTRALIB) $(CEXTRALIB)
  279. cblat2 : cblat2.$(SUFFIX) ../$(LIBNAME)
  280. $(FC) $(FLDFLAGS) -o cblat2 cblat2.$(SUFFIX) ../$(LIBNAME) $(EXTRALIB) $(CEXTRALIB)
  281. cblat3 : cblat3.$(SUFFIX) ../$(LIBNAME)
  282. $(FC) $(FLDFLAGS) -o cblat3 cblat3.$(SUFFIX) ../$(LIBNAME) $(EXTRALIB) $(CEXTRALIB)
  283. endif
  284. ifeq ($(BUILD_COMPLEX16),1)
  285. zblat1 : zblat1.$(SUFFIX) ../$(LIBNAME)
  286. $(FC) $(FLDFLAGS) -o zblat1 zblat1.$(SUFFIX) ../$(LIBNAME) $(EXTRALIB) $(CEXTRALIB)
  287. zblat2 : zblat2.$(SUFFIX) ../$(LIBNAME)
  288. $(FC) $(FLDFLAGS) -o zblat2 zblat2.$(SUFFIX) ../$(LIBNAME) $(EXTRALIB) $(CEXTRALIB)
  289. zblat3 : zblat3.$(SUFFIX) ../$(LIBNAME)
  290. $(FC) $(FLDFLAGS) -o zblat3 zblat3.$(SUFFIX) ../$(LIBNAME) $(EXTRALIB) $(CEXTRALIB)
  291. endif
  292. ifeq ($(BUILD_BFLOAT16),1)
  293. test_sbgemm : compare_sgemm_sbgemm.c ../$(LIBNAME)
  294. $(FC) $(FLDFLAGS) -o test_sbgemm compare_sgemm_sbgemm.c ../$(LIBNAME) $(EXTRALIB) $(CEXTRALIB)
  295. endif
  296. ifeq ($(BUILD_COMPLEX),1)
  297. cblat3_3m : cblat3_3m.$(SUFFIX) ../$(LIBNAME)
  298. $(FC) $(FLDFLAGS) -o cblat3_3m cblat3_3m.$(SUFFIX) ../$(LIBNAME) $(EXTRALIB) $(CEXTRALIB)
  299. endif
  300. ifeq ($(BUILD_COMPLEX16),1)
  301. zblat3_3m : zblat3_3m.$(SUFFIX) ../$(LIBNAME)
  302. $(FC) $(FLDFLAGS) -o zblat3_3m zblat3_3m.$(SUFFIX) ../$(LIBNAME) $(EXTRALIB) $(CEXTRALIB)
  303. endif
  304. clean:
  305. @rm -f *.$(SUFFIX) *.$(PSUFFIX) gmon.$(SUFFIX)ut *.SUMM *.cxml *.exe *.pdb *.dwf \
  306. sblat1 dblat1 cblat1 zblat1 \
  307. sblat2 dblat2 cblat2 zblat2 \
  308. test_sbgemm sblat3 dblat3 cblat3 zblat3 \
  309. sblat1p dblat1p cblat1p zblat1p \
  310. sblat2p dblat2p cblat2p zblat2p \
  311. sblat3p dblat3p cblat3p zblat3p \
  312. zblat3_3m zblat3_3mp \
  313. cblat3_3m cblat3_3mp \
  314. *.stackdump *.dll
  315. libs:
  316. prof:
  317. quick :
  318. $(MAKE) -C $(TOPDIR) libs
  319. # include ../Makefile.tail