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.

system.cmake 16 kB

7 years ago
5 years ago
7 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623
  1. ##
  2. ## Author: Hank Anderson <hank@statease.com>
  3. ## Description: Ported from OpenBLAS/Makefile.system
  4. ##
  5. set(NETLIB_LAPACK_DIR "${PROJECT_SOURCE_DIR}/lapack-netlib")
  6. # System detection, via CMake.
  7. include("${PROJECT_SOURCE_DIR}/cmake/system_check.cmake")
  8. if(CMAKE_CROSSCOMPILING AND NOT DEFINED TARGET)
  9. # Detect target without running getarch
  10. if (ARM64)
  11. set(TARGET "ARMV8")
  12. elseif(ARM)
  13. set(TARGET "ARMV7") # TODO: Ask compiler which arch this is
  14. else()
  15. message(FATAL_ERROR "When cross compiling, a TARGET is required.")
  16. endif()
  17. endif()
  18. # Other files expect CORE, which is actually TARGET and will become TARGET_CORE for kernel build. Confused yet?
  19. # It seems we are meant to use TARGET as input and CORE internally as kernel.
  20. if(NOT DEFINED CORE AND DEFINED TARGET)
  21. set(CORE ${TARGET})
  22. endif()
  23. # TARGET_CORE will override TARGET which is used in DYNAMIC_ARCH=1.
  24. if (DEFINED TARGET_CORE)
  25. set(TARGET ${TARGET_CORE})
  26. endif ()
  27. # Force fallbacks for 32bit
  28. if (DEFINED BINARY AND DEFINED TARGET AND BINARY EQUAL 32)
  29. message(STATUS "Compiling a ${BINARY}-bit binary.")
  30. set(NO_AVX 1)
  31. if (${TARGET} STREQUAL "HASWELL" OR ${TARGET} STREQUAL "SANDYBRIDGE" OR ${TARGET} STREQUAL "SKYLAKEX" OR ${TARGET} STREQUAL "COOPERLAKE")
  32. set(TARGET "NEHALEM")
  33. endif ()
  34. if (${TARGET} STREQUAL "BULLDOZER" OR ${TARGET} STREQUAL "PILEDRIVER" OR ${TARGET} STREQUAL "ZEN")
  35. set(TARGET "BARCELONA")
  36. endif ()
  37. if (${TARGET} STREQUAL "ARMV8" OR ${TARGET} STREQUAL "CORTEXA57" OR ${TARGET} STREQUAL "CORTEXA53")
  38. set(TARGET "ARMV7")
  39. endif ()
  40. endif ()
  41. if (DEFINED TARGET)
  42. if (${TARGET} STREQUAL "COOPERLAKE" AND NOT NO_AVX512)
  43. # if (${CMAKE_C_COMPILER_ID} STREQUAL "GNU")
  44. execute_process(COMMAND ${CMAKE_C_COMPILER} -dumpversion OUTPUT_VARIABLE GCC_VERSION)
  45. if (${GCC_VERSION} VERSION_GREATER 10.1 OR ${GCC_VERSION} VERSION_EQUAL 10.1)
  46. set (KERNEL_DEFINITIONS "${KERNEL_DEFINITIONS} -march=cooperlake")
  47. else()
  48. set (KERNEL_DEFINITIONS "${KERNEL_DEFINITIONS} -march=skylake-avx512")
  49. endif()
  50. # elseif (${CMAKE_C_COMPILER_ID} STREQUAL "CLANG")
  51. # set (KERNEL_DEFINITIONS "${KERNEL_DEFINITIONS} -mavx2")
  52. # endif()
  53. endif()
  54. if (${TARGET} STREQUAL "SKYLAKEX" AND NOT NO_AVX512)
  55. set (KERNEL_DEFINITIONS "${KERNEL_DEFINITIONS} -march=skylake-avx512")
  56. endif()
  57. if (${TARGET} STREQUAL "HASWELL" AND NOT NO_AVX2)
  58. if (${CMAKE_C_COMPILER_ID} STREQUAL "GNU")
  59. execute_process(COMMAND ${CMAKE_C_COMPILER} -dumpversion OUTPUT_VARIABLE GCC_VERSION)
  60. if (${GCC_VERSION} VERSION_GREATER 4.7 OR ${GCC_VERSION} VERSION_EQUAL 4.7)
  61. set (KERNEL_DEFINITIONS "${KERNEL_DEFINITIONS} -mavx2")
  62. endif()
  63. elseif (${CMAKE_C_COMPILER_ID} STREQUAL "CLANG")
  64. set (KERNEL_DEFINITIONS "${KERNEL_DEFINITIONS} -mavx2")
  65. endif()
  66. endif()
  67. if (DEFINED HAVE_SSE3)
  68. set (KERNEL_DEFINITIONS "${KERNEL_DEFINITIONS} -msse3")
  69. endif()
  70. endif()
  71. if (DEFINED TARGET)
  72. message(STATUS "Targeting the ${TARGET} architecture.")
  73. set(GETARCH_FLAGS "-DFORCE_${TARGET}")
  74. endif ()
  75. # On x86_64 build getarch with march=native. This is required to detect AVX512 support in getarch.
  76. if (X86_64 AND NOT ${CMAKE_C_COMPILER_ID} STREQUAL "PGI")
  77. set(GETARCH_FLAGS "${GETARCH_FLAGS} -march=native")
  78. endif ()
  79. # On x86 no AVX support is available
  80. if (X86 OR X86_64)
  81. if ((DEFINED BINARY AND BINARY EQUAL 32) OR ("$CMAKE_SIZEOF_VOID_P}" EQUAL "4"))
  82. set(GETARCH_FLAGS "${GETARCH_FLAGS} -DNO_AVX -DNO_AVX2 -DNO_AVX512")
  83. endif ()
  84. endif ()
  85. if (INTERFACE64)
  86. message(STATUS "Using 64-bit integers.")
  87. set(GETARCH_FLAGS "${GETARCH_FLAGS} -DUSE64BITINT")
  88. endif ()
  89. if (NOT DEFINED GEMM_MULTITHREAD_THRESHOLD)
  90. set(GEMM_MULTITHREAD_THRESHOLD 4)
  91. endif ()
  92. message(STATUS "GEMM multithread threshold set to ${GEMM_MULTITHREAD_THRESHOLD}.")
  93. set(GETARCH_FLAGS "${GETARCH_FLAGS} -DGEMM_MULTITHREAD_THRESHOLD=${GEMM_MULTITHREAD_THRESHOLD}")
  94. if (NO_AVX)
  95. message(STATUS "Disabling Advanced Vector Extensions (AVX).")
  96. set(GETARCH_FLAGS "${GETARCH_FLAGS} -DNO_AVX")
  97. endif ()
  98. if (NO_AVX2)
  99. message(STATUS "Disabling Advanced Vector Extensions 2 (AVX2).")
  100. set(GETARCH_FLAGS "${GETARCH_FLAGS} -DNO_AVX2")
  101. endif ()
  102. if (NO_AVX512)
  103. message(STATUS "Disabling Advanced Vector Extensions 512 (AVX512).")
  104. set(GETARCH_FLAGS "${GETARCH_FLAGS} -DNO_AVX512")
  105. endif ()
  106. if (CMAKE_BUILD_TYPE STREQUAL "Debug")
  107. set(GETARCH_FLAGS "${GETARCH_FLAGS} ${CMAKE_C_FLAGS_DEBUG}")
  108. endif ()
  109. if (NOT DEFINED NO_PARALLEL_MAKE)
  110. set(NO_PARALLEL_MAKE 0)
  111. endif ()
  112. set(GETARCH_FLAGS "${GETARCH_FLAGS} -DNO_PARALLEL_MAKE=${NO_PARALLEL_MAKE}")
  113. if (CMAKE_C_COMPILER STREQUAL loongcc)
  114. set(GETARCH_FLAGS "${GETARCH_FLAGS} -static")
  115. endif ()
  116. #if don't use Fortran, it will only compile CBLAS.
  117. if (ONLY_CBLAS)
  118. set(NO_LAPACK 1)
  119. else ()
  120. set(ONLY_CBLAS 0)
  121. endif ()
  122. # N.B. this is NUM_THREAD in Makefile.system which is probably a bug -hpa
  123. if (NOT CMAKE_CROSSCOMPILING)
  124. if (NOT DEFINED NUM_CORES)
  125. include(ProcessorCount)
  126. ProcessorCount(NUM_CORES)
  127. endif()
  128. endif()
  129. if (NOT DEFINED NUM_PARALLEL)
  130. set(NUM_PARALLEL 1)
  131. endif()
  132. if (NOT DEFINED NUM_THREADS)
  133. if (DEFINED NUM_CORES AND NOT NUM_CORES EQUAL 0)
  134. # HT?
  135. set(NUM_THREADS ${NUM_CORES})
  136. else ()
  137. set(NUM_THREADS 0)
  138. endif ()
  139. endif()
  140. if (${NUM_THREADS} LESS 2)
  141. set(USE_THREAD 0)
  142. elseif(NOT DEFINED USE_THREAD)
  143. set(USE_THREAD 1)
  144. endif ()
  145. if (USE_THREAD)
  146. message(STATUS "Multi-threading enabled with ${NUM_THREADS} threads.")
  147. else()
  148. if (${USE_LOCKING})
  149. set(CCOMMON_OPT "${CCOMMON_OPT} -DUSE_LOCKING")
  150. endif ()
  151. endif ()
  152. include("${PROJECT_SOURCE_DIR}/cmake/prebuild.cmake")
  153. if (DEFINED BINARY)
  154. message(STATUS "Compiling a ${BINARY}-bit binary.")
  155. endif ()
  156. if (NOT DEFINED NEED_PIC)
  157. set(NEED_PIC 1)
  158. endif ()
  159. # OS dependent settings
  160. include("${PROJECT_SOURCE_DIR}/cmake/os.cmake")
  161. # Architecture dependent settings
  162. include("${PROJECT_SOURCE_DIR}/cmake/arch.cmake")
  163. # C Compiler dependent settings
  164. include("${PROJECT_SOURCE_DIR}/cmake/cc.cmake")
  165. if (NOT NOFORTRAN)
  166. # Fortran Compiler dependent settings
  167. include("${PROJECT_SOURCE_DIR}/cmake/fc.cmake")
  168. else ()
  169. set(NO_LAPACK 1)
  170. set(NO_LAPACKE 1)
  171. endif ()
  172. if (BINARY64)
  173. if (INTERFACE64)
  174. # CCOMMON_OPT += -DUSE64BITINT
  175. endif ()
  176. endif ()
  177. if (NEED_PIC)
  178. if (${CMAKE_C_COMPILER} STREQUAL "IBM")
  179. set(CCOMMON_OPT "${CCOMMON_OPT} -qpic=large")
  180. else ()
  181. set(CCOMMON_OPT "${CCOMMON_OPT} -fPIC")
  182. endif ()
  183. if (NOT NOFORTRAN)
  184. if (${F_COMPILER} STREQUAL "SUN")
  185. set(FCOMMON_OPT "${FCOMMON_OPT} -pic")
  186. else ()
  187. set(FCOMMON_OPT "${FCOMMON_OPT} -fPIC")
  188. endif ()
  189. endif()
  190. endif ()
  191. if (DYNAMIC_ARCH)
  192. if (X86 OR X86_64 OR ARM64 OR PPC)
  193. set(CCOMMON_OPT "${CCOMMON_OPT} -DDYNAMIC_ARCH")
  194. if (DYNAMIC_OLDER)
  195. set(CCOMMON_OPT "${CCOMMON_OPT} -DDYNAMIC_OLDER")
  196. endif ()
  197. else ()
  198. unset (DYNAMIC_ARCH)
  199. message (STATUS "DYNAMIC_ARCH is not supported on the target architecture, removing")
  200. endif ()
  201. endif ()
  202. if (DYNAMIC_LIST)
  203. set(CCOMMON_OPT "${CCOMMON_OPT} -DDYNAMIC_LIST")
  204. foreach(DCORE ${DYNAMIC_LIST})
  205. set(CCOMMON_OPT "${CCOMMON_OPT} -DDYN_${DCORE}")
  206. endforeach ()
  207. endif ()
  208. if (NO_LAPACK)
  209. set(CCOMMON_OPT "${CCOMMON_OPT} -DNO_LAPACK")
  210. #Disable LAPACK C interface
  211. set(NO_LAPACKE 1)
  212. endif ()
  213. if (NO_LAPACKE)
  214. set(CCOMMON_OPT "${CCOMMON_OPT} -DNO_LAPACKE")
  215. endif ()
  216. if (NO_AVX)
  217. set(CCOMMON_OPT "${CCOMMON_OPT} -DNO_AVX")
  218. endif ()
  219. if (X86)
  220. set(CCOMMON_OPT "${CCOMMON_OPT} -DNO_AVX")
  221. endif ()
  222. if (NO_AVX2)
  223. set(CCOMMON_OPT "${CCOMMON_OPT} -DNO_AVX2")
  224. endif ()
  225. if (USE_THREAD)
  226. # USE_SIMPLE_THREADED_LEVEL3 = 1
  227. # NO_AFFINITY = 1
  228. set(CCOMMON_OPT "${CCOMMON_OPT} -DSMP_SERVER")
  229. if (MIPS64)
  230. if (NOT ${CORE} STREQUAL "LOONGSON3B")
  231. set(USE_SIMPLE_THREADED_LEVEL3 1)
  232. endif ()
  233. endif ()
  234. if (BIGNUMA)
  235. set(CCOMMON_OPT "${CCOMMON_OPT} -DBIGNUMA")
  236. endif ()
  237. endif ()
  238. if (NO_WARMUP)
  239. set(CCOMMON_OPT "${CCOMMON_OPT} -DNO_WARMUP")
  240. endif ()
  241. if (CONSISTENT_FPCSR)
  242. set(CCOMMON_OPT "${CCOMMON_OPT} -DCONSISTENT_FPCSR")
  243. endif ()
  244. if (USE_TLS)
  245. set(CCOMMON_OPT "${CCOMMON_OPT} -DUSE_TLS")
  246. endif ()
  247. # Only for development
  248. # set(CCOMMON_OPT "${CCOMMON_OPT} -DPARAMTEST")
  249. # set(CCOMMON_OPT "${CCOMMON_OPT} -DPREFETCHTEST")
  250. # set(CCOMMON_OPT "${CCOMMON_OPT} -DNO_SWITCHING")
  251. # set(USE_PAPI 1)
  252. if (USE_PAPI)
  253. set(CCOMMON_OPT "${CCOMMON_OPT} -DUSE_PAPI")
  254. set(EXTRALIB "${EXTRALIB} -lpapi -lperfctr")
  255. endif ()
  256. if (DYNAMIC_THREADS)
  257. set(CCOMMON_OPT "${CCOMMON_OPT} -DDYNAMIC_THREADS")
  258. endif ()
  259. set(CCOMMON_OPT "${CCOMMON_OPT} -DMAX_CPU_NUMBER=${NUM_THREADS}")
  260. set(CCOMMON_OPT "${CCOMMON_OPT} -DMAX_PARALLEL_NUMBER=${NUM_PARALLEL}")
  261. if (BUFFERSIZE)
  262. set(CCOMMON_OPT "${CCOMMON_OPT} -DBUFFERSIZE=${BUFFERSIZE}")
  263. endif ()
  264. if (USE_SIMPLE_THREADED_LEVEL3)
  265. set(CCOMMON_OPT "${CCOMMON_OPT} -DUSE_SIMPLE_THREADED_LEVEL3")
  266. endif ()
  267. if (NOT ${CMAKE_SYSTEM_NAME} STREQUAL "Windows")
  268. if (DEFINED MAX_STACK_ALLOC)
  269. if (NOT ${MAX_STACK_ALLOC} EQUAL 0)
  270. set(CCOMMON_OPT "${CCOMMON_OPT} -DMAX_STACK_ALLOC=${MAX_STACK_ALLOC}")
  271. endif ()
  272. else ()
  273. set(CCOMMON_OPT "${CCOMMON_OPT} -DMAX_STACK_ALLOC=2048")
  274. endif ()
  275. endif ()
  276. if (NOT ${CMAKE_SYSTEM_NAME} STREQUAL "Windows")
  277. if (DEFINED BLAS3_MEM_ALLOC_THRESHOLD)
  278. if (NOT ${BLAS3_MEM_ALLOC_THRESHOLD} EQUAL 32)
  279. set(CCOMMON_OPT "${CCOMMON_OPT} -DBLAS3_MEM_ALLOC_THRESHOLD=${BLAS3_MEM_ALLOC_THRESHOLD}")
  280. endif()
  281. endif()
  282. endif()
  283. if (DEFINED LIBNAMESUFFIX)
  284. set(LIBPREFIX "libopenblas_${LIBNAMESUFFIX}")
  285. else ()
  286. set(LIBPREFIX "libopenblas")
  287. endif ()
  288. if (NOT DEFINED SYMBOLPREFIX)
  289. set(SYMBOLPREFIX "")
  290. endif ()
  291. if (NOT DEFINED SYMBOLSUFFIX)
  292. set(SYMBOLSUFFIX "")
  293. endif ()
  294. set(KERNELDIR "${PROJECT_SOURCE_DIR}/kernel/${ARCH}")
  295. # TODO: need to convert these Makefiles
  296. # include ${PROJECT_SOURCE_DIR}/cmake/${ARCH}.cmake
  297. if (${CORE} STREQUAL "PPC440")
  298. set(CCOMMON_OPT "${CCOMMON_OPT} -DALLOC_QALLOC")
  299. endif ()
  300. if (${CORE} STREQUAL "PPC440FP2")
  301. set(STATIC_ALLOCATION 1)
  302. endif ()
  303. if (NOT ${CMAKE_SYSTEM_NAME} STREQUAL "Linux")
  304. set(NO_AFFINITY 1)
  305. endif ()
  306. if (NOT X86_64 AND NOT X86 AND NOT ${CORE} STREQUAL "LOONGSON3B")
  307. set(NO_AFFINITY 1)
  308. endif ()
  309. if (NO_AFFINITY)
  310. set(CCOMMON_OPT "${CCOMMON_OPT} -DNO_AFFINITY")
  311. endif ()
  312. if (FUNCTION_PROFILE)
  313. set(CCOMMON_OPT "${CCOMMON_OPT} -DFUNCTION_PROFILE")
  314. endif ()
  315. if (HUGETLB_ALLOCATION)
  316. set(CCOMMON_OPT "${CCOMMON_OPT} -DALLOC_HUGETLB")
  317. endif ()
  318. if (DEFINED HUGETLBFILE_ALLOCATION)
  319. set(CCOMMON_OPT "${CCOMMON_OPT} -DALLOC_HUGETLBFILE -DHUGETLB_FILE_NAME=${HUGETLBFILE_ALLOCATION})")
  320. endif ()
  321. if (STATIC_ALLOCATION)
  322. set(CCOMMON_OPT "${CCOMMON_OPT} -DALLOC_STATIC")
  323. endif ()
  324. if (DEVICEDRIVER_ALLOCATION)
  325. set(CCOMMON_OPT "${CCOMMON_OPT} -DALLOC_DEVICEDRIVER -DDEVICEDRIVER_NAME=\"/dev/mapper\"")
  326. endif ()
  327. if (MIXED_MEMORY_ALLOCATION)
  328. set(CCOMMON_OPT "${CCOMMON_OPT} -DMIXED_MEMORY_ALLOCATION")
  329. endif ()
  330. set(CCOMMON_OPT "${CCOMMON_OPT} -DVERSION=\"\\\"${OpenBLAS_VERSION}\\\"\"")
  331. set(REVISION "-r${OpenBLAS_VERSION}")
  332. set(MAJOR_VERSION ${OpenBLAS_MAJOR_VERSION})
  333. set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${CCOMMON_OPT}")
  334. if (NOT BUILD_SINGLE AND NOT BUILD_DOUBLE AND NOT BUILD_COMPLEX AND NOT BUILD_COMPLEX16)
  335. set (BUILD_SINGLE ON)
  336. set (BUILD_DOUBLE ON)
  337. set (BUILD_COMPLEX ON)
  338. set (BUILD_COMPLEX16 ON)
  339. endif()
  340. if (BUILD_SINGLE)
  341. set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -DBUILD_SINGLE")
  342. endif()
  343. if (BUILD_DOUBLE)
  344. set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -DBUILD_DOUBLE")
  345. endif()
  346. if (BUILD_COMPLEX)
  347. set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -DBUILD_COMPLEX")
  348. endif()
  349. if (BUILD_COMPLEX16)
  350. set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -DBUILD_COMPLEX16")
  351. endif()
  352. if(NOT MSVC)
  353. set(CMAKE_ASM_FLAGS "${CMAKE_ASM_FLAGS} ${CCOMMON_OPT}")
  354. endif()
  355. # TODO: not sure what PFLAGS is -hpa
  356. set(PFLAGS "${PFLAGS} ${CCOMMON_OPT} -I${TOPDIR} -DPROFILE ${COMMON_PROF}")
  357. set(CMAKE_Fortran_FLAGS "${CMAKE_Fortran_FLAGS} ${FCOMMON_OPT}")
  358. # TODO: not sure what FPFLAGS is -hpa
  359. set(FPFLAGS "${FPFLAGS} ${FCOMMON_OPT} ${COMMON_PROF}")
  360. #For LAPACK Fortran codes.
  361. set(LAPACK_FFLAGS "${LAPACK_FFLAGS} ${CMAKE_Fortran_FLAGS}")
  362. set(LAPACK_FPFLAGS "${LAPACK_FPFLAGS} ${FPFLAGS}")
  363. #Disable -fopenmp for LAPACK Fortran codes on Windows.
  364. if (${CMAKE_SYSTEM_NAME} STREQUAL "Windows")
  365. set(FILTER_FLAGS "-fopenmp;-mp;-openmp;-xopenmp=parallel")
  366. foreach (FILTER_FLAG ${FILTER_FLAGS})
  367. string(REPLACE ${FILTER_FLAG} "" LAPACK_FFLAGS ${LAPACK_FFLAGS})
  368. string(REPLACE ${FILTER_FLAG} "" LAPACK_FPFLAGS ${LAPACK_FPFLAGS})
  369. endforeach ()
  370. endif ()
  371. if ("${F_COMPILER}" STREQUAL "GFORTRAN")
  372. # lapack-netlib is rife with uninitialized warnings -hpa
  373. set(LAPACK_FFLAGS "${LAPACK_FFLAGS} -Wno-maybe-uninitialized")
  374. endif ()
  375. set(LAPACK_CFLAGS "${CMAKE_C_CFLAGS} -DHAVE_LAPACK_CONFIG_H")
  376. if (INTERFACE64)
  377. set(LAPACK_CFLAGS "${LAPACK_CFLAGS} -DLAPACK_ILP64")
  378. endif ()
  379. if (${CMAKE_SYSTEM_NAME} STREQUAL "Windows")
  380. set(LAPACK_CFLAGS "${LAPACK_CFLAGS} -DOPENBLAS_OS_WINDOWS")
  381. endif ()
  382. if (${CMAKE_C_COMPILER} STREQUAL "LSB" OR ${CMAKE_SYSTEM_NAME} STREQUAL "Windows")
  383. set(LAPACK_CFLAGS "${LAPACK_CFLAGS} -DLAPACK_COMPLEX_STRUCTURE")
  384. endif ()
  385. if ("${CMAKE_BUILD_TYPE}" STREQUAL "Release")
  386. if ("${F_COMPILER}" STREQUAL "FLANG")
  387. if (${CMAKE_Fortran_COMPILER_VERSION} VERSION_LESS_EQUAL 3)
  388. set(CMAKE_Fortran_FLAGS_RELEASE "${CMAKE_Fortran_FLAGS_RELEASE} -fno-unroll-loops")
  389. endif ()
  390. endif ()
  391. endif ()
  392. if (NOT DEFINED SUFFIX)
  393. set(SUFFIX o)
  394. endif ()
  395. if (NOT DEFINED PSUFFIX)
  396. set(PSUFFIX po)
  397. endif ()
  398. if (NOT DEFINED LIBSUFFIX)
  399. set(LIBSUFFIX a)
  400. endif ()
  401. if (DYNAMIC_ARCH)
  402. if (USE_THREAD)
  403. set(LIBNAME "${LIBPREFIX}p${REVISION}.${LIBSUFFIX}")
  404. set(LIBNAME_P "${LIBPREFIX}p${REVISION}_p.${LIBSUFFIX}")
  405. else ()
  406. set(LIBNAME "${LIBPREFIX}${REVISION}.${LIBSUFFIX}")
  407. set(LIBNAME_P "${LIBPREFIX}${REVISION}_p.${LIBSUFFIX}")
  408. endif ()
  409. else ()
  410. if (USE_THREAD)
  411. set(LIBNAME "${LIBPREFIX}_${LIBCORE}p${REVISION}.${LIBSUFFIX}")
  412. set(LIBNAME_P "${LIBPREFIX}_${LIBCORE}p${REVISION}_p.${LIBSUFFIX}")
  413. else ()
  414. set(LIBNAME "${LIBPREFIX}_${LIBCORE}${REVISION}.${LIBSUFFIX}")
  415. set(LIBNAME_P "${LIBPREFIX}_${LIBCORE}${REVISION}_p.${LIBSUFFIX}")
  416. endif ()
  417. endif ()
  418. set(LIBDLLNAME "${LIBPREFIX}.dll")
  419. set(LIBSONAME "${LIBNAME}.${LIBSUFFIX}.so")
  420. set(LIBDYNNAME "${LIBNAME}.${LIBSUFFIX}.dylib")
  421. set(LIBDEFNAME "${LIBNAME}.${LIBSUFFIX}.def")
  422. set(LIBEXPNAME "${LIBNAME}.${LIBSUFFIX}.exp")
  423. set(LIBZIPNAME "${LIBNAME}.${LIBSUFFIX}.zip")
  424. set(LIBS "${PROJECT_SOURCE_DIR}/${LIBNAME}")
  425. set(LIBS_P "${PROJECT_SOURCE_DIR}/${LIBNAME_P}")
  426. set(LIB_COMPONENTS BLAS)
  427. if (NOT NO_CBLAS)
  428. set(LIB_COMPONENTS "${LIB_COMPONENTS} CBLAS")
  429. endif ()
  430. if (NOT NO_LAPACK)
  431. set(LIB_COMPONENTS "${LIB_COMPONENTS} LAPACK")
  432. if (NOT NO_LAPACKE)
  433. set(LIB_COMPONENTS "${LIB_COMPONENTS} LAPACKE")
  434. endif ()
  435. if (BUILD_RELAPACK)
  436. set(LIB_COMPONENTS "${LIB_COMPONENTS} ReLAPACK")
  437. endif ()
  438. endif ()
  439. if (ONLY_CBLAS)
  440. set(LIB_COMPONENTS CBLAS)
  441. endif ()
  442. # For GEMM3M
  443. set(USE_GEMM3M 0)
  444. if (DEFINED ARCH)
  445. if (X86 OR X86_64 OR ${ARCH} STREQUAL "ia64" OR MIPS64)
  446. set(USE_GEMM3M 1)
  447. endif ()
  448. if (${CORE} STREQUAL "generic")
  449. set(USE_GEMM3M 0)
  450. endif ()
  451. endif ()
  452. #export OSNAME
  453. #export ARCH
  454. #export CORE
  455. #export LIBCORE
  456. #export PGCPATH
  457. #export CONFIG
  458. #export CC
  459. #export FC
  460. #export BU
  461. #export FU
  462. #export NEED2UNDERSCORES
  463. #export USE_THREAD
  464. #export NUM_THREADS
  465. #export NUM_CORES
  466. #export SMP
  467. #export MAKEFILE_RULE
  468. #export NEED_PIC
  469. #export BINARY
  470. #export BINARY32
  471. #export BINARY64
  472. #export F_COMPILER
  473. #export C_COMPILER
  474. #export USE_OPENMP
  475. #export CROSS
  476. #export CROSS_SUFFIX
  477. #export NOFORTRAN
  478. #export NO_FBLAS
  479. #export EXTRALIB
  480. #export CEXTRALIB
  481. #export FEXTRALIB
  482. #export HAVE_SSE
  483. #export HAVE_SSE2
  484. #export HAVE_SSE3
  485. #export HAVE_SSSE3
  486. #export HAVE_SSE4_1
  487. #export HAVE_SSE4_2
  488. #export HAVE_SSE4A
  489. #export HAVE_SSE5
  490. #export HAVE_AVX
  491. #export HAVE_VFP
  492. #export HAVE_VFPV3
  493. #export HAVE_VFPV4
  494. #export HAVE_NEON
  495. #export KERNELDIR
  496. #export FUNCTION_PROFILE
  497. #export TARGET_CORE
  498. #
  499. #export SHGEMM_UNROLL_M
  500. #export SHGEMM_UNROLL_N
  501. #export SGEMM_UNROLL_M
  502. #export SGEMM_UNROLL_N
  503. #export DGEMM_UNROLL_M
  504. #export DGEMM_UNROLL_N
  505. #export QGEMM_UNROLL_M
  506. #export QGEMM_UNROLL_N
  507. #export CGEMM_UNROLL_M
  508. #export CGEMM_UNROLL_N
  509. #export ZGEMM_UNROLL_M
  510. #export ZGEMM_UNROLL_N
  511. #export XGEMM_UNROLL_M
  512. #export XGEMM_UNROLL_N
  513. #export CGEMM3M_UNROLL_M
  514. #export CGEMM3M_UNROLL_N
  515. #export ZGEMM3M_UNROLL_M
  516. #export ZGEMM3M_UNROLL_N
  517. #export XGEMM3M_UNROLL_M
  518. #export XGEMM3M_UNROLL_N
  519. #if (USE_CUDA)
  520. # export CUDADIR
  521. # export CUCC
  522. # export CUFLAGS
  523. # export CULIB
  524. #endif