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

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725
  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" OR ${TARGET} STREQUAL "SAPPHIRERAPIDS")
  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" OR ${TARGET} STREQUAL "CORTEXA55")
  38. set(TARGET "ARMV7")
  39. endif ()
  40. if (${TARGET} STREQUAL "POWER8" OR ${TARGET} STREQUAL "POWER9" OR ${TARGET} STREQUAL "POWER10")
  41. set(TARGET "POWER6")
  42. endif ()
  43. endif ()
  44. if (DEFINED TARGET)
  45. message(STATUS "-- -- -- -- -- -- -- -- -- -- -- -- --")
  46. message(STATUS "Targeting the ${TARGET} architecture.")
  47. set(GETARCH_FLAGS "-DFORCE_${TARGET}")
  48. endif ()
  49. # On x86_64 build getarch with march=native. This is required to detect AVX512 support in getarch.
  50. if (X86_64 AND NOT ${CMAKE_C_COMPILER_ID} STREQUAL "PGI")
  51. set(GETARCH_FLAGS "${GETARCH_FLAGS} -march=native")
  52. endif ()
  53. # On x86 no AVX support is available
  54. if (X86 OR X86_64)
  55. if ((DEFINED BINARY AND BINARY EQUAL 32) OR ("$CMAKE_SIZEOF_VOID_P}" EQUAL "4"))
  56. set(GETARCH_FLAGS "${GETARCH_FLAGS} -DNO_AVX -DNO_AVX2 -DNO_AVX512")
  57. endif ()
  58. endif ()
  59. if (INTERFACE64)
  60. message(STATUS "Using 64-bit integers.")
  61. set(GETARCH_FLAGS "${GETARCH_FLAGS} -DUSE64BITINT")
  62. endif ()
  63. if (NOT DEFINED GEMM_MULTITHREAD_THRESHOLD)
  64. set(GEMM_MULTITHREAD_THRESHOLD 4)
  65. endif ()
  66. message(STATUS "GEMM multithread threshold set to ${GEMM_MULTITHREAD_THRESHOLD}.")
  67. set(GETARCH_FLAGS "${GETARCH_FLAGS} -DGEMM_MULTITHREAD_THRESHOLD=${GEMM_MULTITHREAD_THRESHOLD}")
  68. if (NO_AVX)
  69. message(STATUS "Disabling Advanced Vector Extensions (AVX).")
  70. set(GETARCH_FLAGS "${GETARCH_FLAGS} -DNO_AVX")
  71. endif ()
  72. if (NO_AVX2)
  73. message(STATUS "Disabling Advanced Vector Extensions 2 (AVX2).")
  74. set(GETARCH_FLAGS "${GETARCH_FLAGS} -DNO_AVX2")
  75. endif ()
  76. if (NO_AVX512)
  77. message(STATUS "Disabling Advanced Vector Extensions 512 (AVX512).")
  78. set(GETARCH_FLAGS "${GETARCH_FLAGS} -DNO_AVX512")
  79. endif ()
  80. if (CMAKE_BUILD_TYPE STREQUAL "Debug")
  81. set(GETARCH_FLAGS "${GETARCH_FLAGS} ${CMAKE_C_FLAGS_DEBUG}")
  82. endif ()
  83. if (NOT DEFINED NO_PARALLEL_MAKE)
  84. set(NO_PARALLEL_MAKE 0)
  85. endif ()
  86. set(GETARCH_FLAGS "${GETARCH_FLAGS} -DNO_PARALLEL_MAKE=${NO_PARALLEL_MAKE}")
  87. if (CMAKE_C_COMPILER STREQUAL loongcc)
  88. set(GETARCH_FLAGS "${GETARCH_FLAGS} -static")
  89. endif ()
  90. if (POWER)
  91. set (NO_WARMUP 1)
  92. execute_process(COMMAND bash -c "as -v < /dev/null 2>&1 | grep GNU 2>&1 >/dev/null" RESULT_VARIABLE HAVE_GAS)
  93. set(GETARCH_FLAGS "${GETARCH_FLAGS} -DHAVE_GAS=${HAVE_GAS}")
  94. endif()
  95. #if don't use Fortran, it will only compile CBLAS.
  96. if (ONLY_CBLAS)
  97. set(NO_LAPACK 1)
  98. else ()
  99. set(ONLY_CBLAS 0)
  100. endif ()
  101. # N.B. this is NUM_THREAD in Makefile.system which is probably a bug -hpa
  102. if (NOT CMAKE_CROSSCOMPILING)
  103. if (NOT DEFINED NUM_CORES)
  104. include(ProcessorCount)
  105. ProcessorCount(NUM_CORES)
  106. endif()
  107. endif()
  108. if (NOT DEFINED NUM_PARALLEL)
  109. set(NUM_PARALLEL 1)
  110. endif()
  111. if (NOT DEFINED NUM_THREADS)
  112. if (DEFINED NUM_CORES AND NOT NUM_CORES EQUAL 0)
  113. # HT?
  114. set(NUM_THREADS ${NUM_CORES})
  115. else ()
  116. set(NUM_THREADS 0)
  117. endif ()
  118. endif()
  119. if (${NUM_THREADS} LESS 2)
  120. set(USE_THREAD 0)
  121. elseif(NOT DEFINED USE_THREAD)
  122. set(USE_THREAD 1)
  123. endif ()
  124. if (USE_THREAD)
  125. message(STATUS "Multi-threading enabled with ${NUM_THREADS} threads.")
  126. else()
  127. if (${USE_LOCKING})
  128. set(CCOMMON_OPT "${CCOMMON_OPT} -DUSE_LOCKING")
  129. endif ()
  130. endif ()
  131. include("${PROJECT_SOURCE_DIR}/cmake/prebuild.cmake")
  132. if (DEFINED TARGET)
  133. if (${TARGET} STREQUAL COOPERLAKE AND NOT NO_AVX512)
  134. if (${CMAKE_C_COMPILER_ID} STREQUAL "GNU")
  135. execute_process(COMMAND ${CMAKE_C_COMPILER} -dumpversion OUTPUT_VARIABLE GCC_VERSION)
  136. if (${CMAKE_C_COMPILER_VERSION} VERSION_GREATER 10.09)
  137. set (KERNEL_DEFINITIONS "${KERNEL_DEFINITIONS} -march=cooperlake")
  138. else()
  139. set (KERNEL_DEFINITIONS "${KERNEL_DEFINITIONS} -march=skylake-avx512")
  140. endif()
  141. elseif (${CMAKE_C_COMPILER_ID} STREQUAL "Clang" OR ${CMAKE_C_COMPILER_ID} STREQUAL "AppleClang")
  142. if (${CMAKE_C_COMPILER_VERSION} VERSION_GREATER 8.99)
  143. set (KERNEL_DEFINITIONS "${KERNEL_DEFINITIONS} -march=cooperlake")
  144. else()
  145. set (KERNEL_DEFINITIONS "${KERNEL_DEFINITIONS} -march=skylake-avx512")
  146. endif()
  147. endif()
  148. endif()
  149. if (${TARGET} STREQUAL SAPPHIRERAPIDS AND NOT NO_AVX512)
  150. if (${CMAKE_C_COMPILER_ID} STREQUAL "GNU")
  151. execute_process(COMMAND ${CMAKE_C_COMPILER} -dumpversion OUTPUT_VARIABLE GCC_VERSION)
  152. if (${CMAKE_C_COMPILER_VERSION} VERSION_GREATER 11.0)
  153. set (KERNEL_DEFINITIONS "${KERNEL_DEFINITIONS} -march=sapphirerapids")
  154. else()
  155. set (KERNEL_DEFINITIONS "${KERNEL_DEFINITIONS} -march=skylake-avx512")
  156. endif()
  157. elseif (${CMAKE_C_COMPILER_ID} STREQUAL "Clang" OR ${CMAKE_C_COMPILER_ID} STREQUAL "AppleClang")
  158. if (${CMAKE_C_COMPILER_VERSION} VERSION_GREATER 12.0)
  159. set (KERNEL_DEFINITIONS "${KERNEL_DEFINITIONS} -march=sapphirerapids")
  160. else()
  161. set (KERNEL_DEFINITIONS "${KERNEL_DEFINITIONS} -march=skylake-avx512")
  162. endif()
  163. endif()
  164. endif()
  165. if (${TARGET} STREQUAL SKYLAKEX AND NOT NO_AVX512)
  166. set (KERNEL_DEFINITIONS "${KERNEL_DEFINITIONS} -march=skylake-avx512")
  167. endif()
  168. if (${TARGET} STREQUAL HASWELL AND NOT NO_AVX2)
  169. if (${CMAKE_C_COMPILER_ID} STREQUAL "GNU")
  170. execute_process(COMMAND ${CMAKE_C_COMPILER} -dumpversion OUTPUT_VARIABLE GCC_VERSION)
  171. if (${GCC_VERSION} VERSION_GREATER 4.7 OR ${GCC_VERSION} VERSION_EQUAL 4.7)
  172. set (KERNEL_DEFINITIONS "${KERNEL_DEFINITIONS} -mavx2")
  173. endif()
  174. elseif (${CMAKE_C_COMPILER_ID} STREQUAL "CLANG")
  175. set (KERNEL_DEFINITIONS "${KERNEL_DEFINITIONS} -mavx2")
  176. endif()
  177. endif()
  178. if (DEFINED HAVE_AVX)
  179. if (NOT NO_AVX)
  180. set (KERNEL_DEFINITIONS "${KERNEL_DEFINITIONS} -mavx")
  181. endif()
  182. endif()
  183. if (DEFINED HAVE_AVX2)
  184. if (NOT NO_AVX2)
  185. set (KERNEL_DEFINITIONS "${KERNEL_DEFINITIONS} -mavx2")
  186. endif()
  187. endif()
  188. # if (DEFINED HAVE_FMA3)
  189. # if (NOT NO_AVX2)
  190. # set (KERNEL_DEFINITIONS "${KERNEL_DEFINITIONS} -mfma")
  191. # endif()
  192. # endif()
  193. if (DEFINED HAVE_SSE)
  194. set (KERNEL_DEFINITIONS "${KERNEL_DEFINITIONS} -msse")
  195. endif()
  196. if (DEFINED HAVE_SSE2)
  197. set (KERNEL_DEFINITIONS "${KERNEL_DEFINITIONS} -msse2")
  198. endif()
  199. if (DEFINED HAVE_SSE3)
  200. set (KERNEL_DEFINITIONS "${KERNEL_DEFINITIONS} -msse3")
  201. endif()
  202. if (DEFINED HAVE_SSSE3)
  203. set (KERNEL_DEFINITIONS "${KERNEL_DEFINITIONS} -mssse3")
  204. endif()
  205. if (DEFINED HAVE_SSE4_1)
  206. set (KERNEL_DEFINITIONS "${KERNEL_DEFINITIONS} -msse4.1")
  207. endif()
  208. if (${TARGET} STREQUAL POWER10)
  209. execute_process(COMMAND ${CMAKE_C_COMPILER} -dumpversion OUTPUT_VARIABLE GCC_VERSION)
  210. if (${GCC_VERSION} VERSION_GREATER 10.2 OR ${GCC_VERSION} VERSION_EQUAL 10.2)
  211. set (KERNEL_DEFINITIONS "${KERNEL_DEFINITIONS} -mcpu=power10 -mtune=power10 -mvsx -fno-fast-math")
  212. else ()
  213. message(FATAL_ERROR "Compiler GCC.${GCC_VERSION} does not support Power10.")
  214. endif()
  215. endif()
  216. if (${TARGET} STREQUAL POWER9)
  217. execute_process(COMMAND ${CMAKE_C_COMPILER} -dumpversion OUTPUT_VARIABLE GCC_VERSION)
  218. if (${GCC_VERSION} VERSION_GREATER 5.0 OR ${GCC_VERSION} VERSION_EQUAL 5.0)
  219. set (KERNEL_DEFINITIONS "${KERNEL_DEFINITIONS} -mcpu=power9 -mtune=power9 -mvsx -fno-fast-math")
  220. else ()
  221. set (KERNEL_DEFINITIONS "${KERNEL_DEFINITIONS} -mcpu=power8 -mtune=power8 -mvsx -fno-fast-math")
  222. message(WARNING "Compiler GCC.${GCC_VERSION} does not support fully Power9.")
  223. endif()
  224. endif()
  225. if (${TARGET} STREQUAL POWER8)
  226. set (KERNEL_DEFINITIONS "${KERNEL_DEFINITIONS} -mcpu=power8 -mtune=power8 -mvsx -fno-fast-math")
  227. endif()
  228. endif()
  229. if (DEFINED BINARY)
  230. message(STATUS "Compiling a ${BINARY}-bit binary.")
  231. endif ()
  232. if (NOT DEFINED NEED_PIC)
  233. set(NEED_PIC 1)
  234. endif ()
  235. # OS dependent settings
  236. include("${PROJECT_SOURCE_DIR}/cmake/os.cmake")
  237. # Architecture dependent settings
  238. include("${PROJECT_SOURCE_DIR}/cmake/arch.cmake")
  239. # C Compiler dependent settings
  240. include("${PROJECT_SOURCE_DIR}/cmake/cc.cmake")
  241. if (INTERFACE64)
  242. set(SUFFIX64 64)
  243. set(SUFFIX64_UNDERSCORE _64)
  244. endif()
  245. if (NOT NOFORTRAN)
  246. # Fortran Compiler dependent settings
  247. include("${PROJECT_SOURCE_DIR}/cmake/fc.cmake")
  248. else ()
  249. set(NO_LAPACK 1)
  250. set(NO_LAPACKE 1)
  251. endif ()
  252. if (BINARY64)
  253. if (INTERFACE64)
  254. # CCOMMON_OPT += -DUSE64BITINT
  255. endif ()
  256. endif ()
  257. if(EMBEDDED)
  258. set(CCOMMON_OPT "${CCOMMON_OPT} -DOS_EMBEDDED")
  259. set(CCOMMON_OPT "${CCOMMON_OPT} -mthumb -mcpu=cortex-m4 -mfloat-abi=hard -mfpu=fpv4-sp-d16")
  260. endif()
  261. if (NEED_PIC)
  262. if (${CMAKE_C_COMPILER} STREQUAL "IBM")
  263. set(CCOMMON_OPT "${CCOMMON_OPT} -qpic=large")
  264. else ()
  265. set(CCOMMON_OPT "${CCOMMON_OPT} -fPIC")
  266. endif ()
  267. if (NOT NOFORTRAN)
  268. if (${F_COMPILER} STREQUAL "SUN")
  269. set(FCOMMON_OPT "${FCOMMON_OPT} -pic")
  270. else ()
  271. set(FCOMMON_OPT "${FCOMMON_OPT} -fPIC")
  272. endif ()
  273. endif()
  274. endif ()
  275. if (X86_64 OR ${CORE} STREQUAL POWER10)
  276. set(SMALL_MATRIX_OPT TRUE)
  277. endif ()
  278. if (SMALL_MATRIX_OPT)
  279. set(CCOMMON_OPT "${CCOMMON_OPT} -DSMALL_MATRIX_OPT")
  280. endif ()
  281. if (DYNAMIC_ARCH)
  282. if (X86 OR X86_64 OR ARM64 OR POWER)
  283. set(CCOMMON_OPT "${CCOMMON_OPT} -DDYNAMIC_ARCH")
  284. if (DYNAMIC_OLDER)
  285. set(CCOMMON_OPT "${CCOMMON_OPT} -DDYNAMIC_OLDER")
  286. endif ()
  287. else ()
  288. unset (DYNAMIC_ARCH)
  289. message (STATUS "DYNAMIC_ARCH is not supported on the target architecture, removing")
  290. endif ()
  291. endif ()
  292. if (DYNAMIC_LIST)
  293. set(CCOMMON_OPT "${CCOMMON_OPT} -DDYNAMIC_LIST")
  294. foreach(DCORE ${DYNAMIC_LIST})
  295. set(CCOMMON_OPT "${CCOMMON_OPT} -DDYN_${DCORE}")
  296. endforeach ()
  297. endif ()
  298. if (NO_LAPACK)
  299. set(CCOMMON_OPT "${CCOMMON_OPT} -DNO_LAPACK")
  300. #Disable LAPACK C interface
  301. set(NO_LAPACKE 1)
  302. endif ()
  303. if (NO_LAPACKE)
  304. set(CCOMMON_OPT "${CCOMMON_OPT} -DNO_LAPACKE")
  305. endif ()
  306. if (NO_AVX)
  307. set(CCOMMON_OPT "${CCOMMON_OPT} -DNO_AVX")
  308. endif ()
  309. if (X86)
  310. set(CCOMMON_OPT "${CCOMMON_OPT} -DNO_AVX")
  311. endif ()
  312. if (NO_AVX2)
  313. set(CCOMMON_OPT "${CCOMMON_OPT} -DNO_AVX2")
  314. endif ()
  315. if (NO_AVX512)
  316. set(CCOMMON_OPT "${CCOMMON_OPT} -DNO_AVX512")
  317. endif ()
  318. if (USE_THREAD)
  319. # USE_SIMPLE_THREADED_LEVEL3 = 1
  320. # NO_AFFINITY = 1
  321. set(CCOMMON_OPT "${CCOMMON_OPT} -DSMP_SERVER")
  322. if (MIPS64)
  323. if (NOT ${CORE} STREQUAL "LOONGSON3B")
  324. set(USE_SIMPLE_THREADED_LEVEL3 1)
  325. endif ()
  326. endif ()
  327. if (BIGNUMA)
  328. set(CCOMMON_OPT "${CCOMMON_OPT} -DBIGNUMA")
  329. endif ()
  330. endif ()
  331. if (NO_WARMUP)
  332. set(CCOMMON_OPT "${CCOMMON_OPT} -DNO_WARMUP")
  333. endif ()
  334. if (CONSISTENT_FPCSR)
  335. set(CCOMMON_OPT "${CCOMMON_OPT} -DCONSISTENT_FPCSR")
  336. endif ()
  337. if (USE_TLS)
  338. set(CCOMMON_OPT "${CCOMMON_OPT} -DUSE_TLS")
  339. endif ()
  340. # Only for development
  341. # set(CCOMMON_OPT "${CCOMMON_OPT} -DPARAMTEST")
  342. # set(CCOMMON_OPT "${CCOMMON_OPT} -DPREFETCHTEST")
  343. # set(CCOMMON_OPT "${CCOMMON_OPT} -DNO_SWITCHING")
  344. # set(USE_PAPI 1)
  345. if (USE_PAPI)
  346. set(CCOMMON_OPT "${CCOMMON_OPT} -DUSE_PAPI")
  347. set(EXTRALIB "${EXTRALIB} -lpapi -lperfctr")
  348. endif ()
  349. if (DYNAMIC_THREADS)
  350. set(CCOMMON_OPT "${CCOMMON_OPT} -DDYNAMIC_THREADS")
  351. endif ()
  352. set(CCOMMON_OPT "${CCOMMON_OPT} -DMAX_CPU_NUMBER=${NUM_THREADS}")
  353. set(CCOMMON_OPT "${CCOMMON_OPT} -DMAX_PARALLEL_NUMBER=${NUM_PARALLEL}")
  354. if (BUFFERSIZE)
  355. set(CCOMMON_OPT "${CCOMMON_OPT} -DBUFFERSIZE=${BUFFERSIZE}")
  356. endif ()
  357. if (USE_SIMPLE_THREADED_LEVEL3)
  358. set(CCOMMON_OPT "${CCOMMON_OPT} -DUSE_SIMPLE_THREADED_LEVEL3")
  359. endif ()
  360. if (NOT ${CMAKE_SYSTEM_NAME} STREQUAL "Windows")
  361. if (DEFINED MAX_STACK_ALLOC)
  362. if (NOT ${MAX_STACK_ALLOC} EQUAL 0)
  363. set(CCOMMON_OPT "${CCOMMON_OPT} -DMAX_STACK_ALLOC=${MAX_STACK_ALLOC}")
  364. endif ()
  365. else ()
  366. set(CCOMMON_OPT "${CCOMMON_OPT} -DMAX_STACK_ALLOC=2048")
  367. endif ()
  368. endif ()
  369. if (NOT ${CMAKE_SYSTEM_NAME} STREQUAL "Windows")
  370. if (DEFINED BLAS3_MEM_ALLOC_THRESHOLD)
  371. if (NOT ${BLAS3_MEM_ALLOC_THRESHOLD} EQUAL 32)
  372. set(CCOMMON_OPT "${CCOMMON_OPT} -DBLAS3_MEM_ALLOC_THRESHOLD=${BLAS3_MEM_ALLOC_THRESHOLD}")
  373. endif()
  374. endif()
  375. endif()
  376. if (DEFINED LIBNAMESUFFIX)
  377. set(LIBPREFIX "libopenblas_${LIBNAMESUFFIX}")
  378. else ()
  379. set(LIBPREFIX "libopenblas")
  380. endif ()
  381. if (NOT DEFINED SYMBOLPREFIX)
  382. set(SYMBOLPREFIX "")
  383. endif ()
  384. if (NOT DEFINED SYMBOLSUFFIX)
  385. set(SYMBOLSUFFIX "")
  386. endif ()
  387. set(KERNELDIR "${PROJECT_SOURCE_DIR}/kernel/${ARCH}")
  388. # TODO: need to convert these Makefiles
  389. # include ${PROJECT_SOURCE_DIR}/cmake/${ARCH}.cmake
  390. if (${CORE} STREQUAL "PPC440")
  391. set(CCOMMON_OPT "${CCOMMON_OPT} -DALLOC_QALLOC")
  392. endif ()
  393. if (${CORE} STREQUAL "PPC440FP2")
  394. set(STATIC_ALLOCATION 1)
  395. endif ()
  396. if (NOT ${CMAKE_SYSTEM_NAME} STREQUAL "Linux")
  397. set(NO_AFFINITY 1)
  398. endif ()
  399. if (NOT X86_64 AND NOT X86 AND NOT ${CORE} STREQUAL "LOONGSON3B")
  400. set(NO_AFFINITY 1)
  401. endif ()
  402. if (NO_AFFINITY)
  403. set(CCOMMON_OPT "${CCOMMON_OPT} -DNO_AFFINITY")
  404. endif ()
  405. if (FUNCTION_PROFILE)
  406. set(CCOMMON_OPT "${CCOMMON_OPT} -DFUNCTION_PROFILE")
  407. endif ()
  408. if (HUGETLB_ALLOCATION)
  409. set(CCOMMON_OPT "${CCOMMON_OPT} -DALLOC_HUGETLB")
  410. endif ()
  411. if (DEFINED HUGETLBFILE_ALLOCATION)
  412. set(CCOMMON_OPT "${CCOMMON_OPT} -DALLOC_HUGETLBFILE -DHUGETLB_FILE_NAME=${HUGETLBFILE_ALLOCATION})")
  413. endif ()
  414. if (STATIC_ALLOCATION)
  415. set(CCOMMON_OPT "${CCOMMON_OPT} -DALLOC_STATIC")
  416. endif ()
  417. if (DEVICEDRIVER_ALLOCATION)
  418. set(CCOMMON_OPT "${CCOMMON_OPT} -DALLOC_DEVICEDRIVER -DDEVICEDRIVER_NAME=\"/dev/mapper\"")
  419. endif ()
  420. if (MIXED_MEMORY_ALLOCATION)
  421. set(CCOMMON_OPT "${CCOMMON_OPT} -DMIXED_MEMORY_ALLOCATION")
  422. endif ()
  423. set(CCOMMON_OPT "${CCOMMON_OPT} -DVERSION=\"\\\"${OpenBLAS_VERSION}\\\"\"")
  424. set(REVISION "-r${OpenBLAS_VERSION}")
  425. set(MAJOR_VERSION ${OpenBLAS_MAJOR_VERSION})
  426. set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${CCOMMON_OPT}")
  427. if (NOT BUILD_SINGLE AND NOT BUILD_DOUBLE AND NOT BUILD_COMPLEX AND NOT BUILD_COMPLEX16)
  428. set (BUILD_SINGLE ON)
  429. set (BUILD_DOUBLE ON)
  430. set (BUILD_COMPLEX ON)
  431. set (BUILD_COMPLEX16 ON)
  432. endif()
  433. if (BUILD_SINGLE)
  434. set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -DBUILD_SINGLE")
  435. endif()
  436. if (BUILD_DOUBLE)
  437. set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -DBUILD_DOUBLE")
  438. endif()
  439. if (BUILD_COMPLEX)
  440. set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -DBUILD_COMPLEX")
  441. endif()
  442. if (BUILD_COMPLEX16)
  443. set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -DBUILD_COMPLEX16")
  444. endif()
  445. if (BUILD_BFLOAT16)
  446. set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -DBUILD_BFLOAT16")
  447. endif()
  448. if(NOT MSVC)
  449. set(CMAKE_ASM_FLAGS "${CMAKE_ASM_FLAGS} ${CCOMMON_OPT}")
  450. endif()
  451. # TODO: not sure what PFLAGS is -hpa
  452. set(PFLAGS "${PFLAGS} ${CCOMMON_OPT} -I${TOPDIR} -DPROFILE ${COMMON_PROF}")
  453. set(CMAKE_Fortran_FLAGS "${CMAKE_Fortran_FLAGS} ${FCOMMON_OPT}")
  454. # TODO: not sure what FPFLAGS is -hpa
  455. set(FPFLAGS "${FPFLAGS} ${FCOMMON_OPT} ${COMMON_PROF}")
  456. #For LAPACK Fortran codes.
  457. set(LAPACK_FFLAGS "${LAPACK_FFLAGS} ${CMAKE_Fortran_FLAGS}")
  458. set(LAPACK_FPFLAGS "${LAPACK_FPFLAGS} ${FPFLAGS}")
  459. #Disable -fopenmp for LAPACK Fortran codes on Windows.
  460. if (${CMAKE_SYSTEM_NAME} STREQUAL "Windows")
  461. set(FILTER_FLAGS "-fopenmp;-mp;-openmp;-xopenmp=parallel")
  462. foreach (FILTER_FLAG ${FILTER_FLAGS})
  463. string(REPLACE ${FILTER_FLAG} "" LAPACK_FFLAGS ${LAPACK_FFLAGS})
  464. string(REPLACE ${FILTER_FLAG} "" LAPACK_FPFLAGS ${LAPACK_FPFLAGS})
  465. endforeach ()
  466. endif ()
  467. if ("${F_COMPILER}" STREQUAL "GFORTRAN")
  468. # lapack-netlib is rife with uninitialized warnings -hpa
  469. set(LAPACK_FFLAGS "${LAPACK_FFLAGS} -Wno-maybe-uninitialized")
  470. endif ()
  471. set(LAPACK_CFLAGS "${CMAKE_C_CFLAGS} -DHAVE_LAPACK_CONFIG_H")
  472. if (INTERFACE64)
  473. set(LAPACK_CFLAGS "${LAPACK_CFLAGS} -DLAPACK_ILP64")
  474. endif ()
  475. if (${CMAKE_SYSTEM_NAME} STREQUAL "Windows")
  476. set(LAPACK_CFLAGS "${LAPACK_CFLAGS} -DOPENBLAS_OS_WINDOWS")
  477. endif ()
  478. if (${CMAKE_C_COMPILER} STREQUAL "LSB" OR ${CMAKE_SYSTEM_NAME} STREQUAL "Windows")
  479. set(LAPACK_CFLAGS "${LAPACK_CFLAGS} -DLAPACK_COMPLEX_STRUCTURE")
  480. endif ()
  481. if ("${CMAKE_BUILD_TYPE}" STREQUAL "Release")
  482. if ("${F_COMPILER}" STREQUAL "FLANG")
  483. if (${CMAKE_Fortran_COMPILER_VERSION} VERSION_LESS_EQUAL 3)
  484. set(CMAKE_Fortran_FLAGS_RELEASE "${CMAKE_Fortran_FLAGS_RELEASE} -fno-unroll-loops")
  485. endif ()
  486. endif ()
  487. endif ()
  488. if (NOT DEFINED SUFFIX)
  489. set(SUFFIX o)
  490. endif ()
  491. if (NOT DEFINED PSUFFIX)
  492. set(PSUFFIX po)
  493. endif ()
  494. if (NOT DEFINED LIBSUFFIX)
  495. set(LIBSUFFIX a)
  496. endif ()
  497. if (DYNAMIC_ARCH)
  498. if (USE_THREAD)
  499. set(LIBNAME "${LIBPREFIX}p${REVISION}.${LIBSUFFIX}")
  500. set(LIBNAME_P "${LIBPREFIX}p${REVISION}_p.${LIBSUFFIX}")
  501. else ()
  502. set(LIBNAME "${LIBPREFIX}${REVISION}.${LIBSUFFIX}")
  503. set(LIBNAME_P "${LIBPREFIX}${REVISION}_p.${LIBSUFFIX}")
  504. endif ()
  505. else ()
  506. if (USE_THREAD)
  507. set(LIBNAME "${LIBPREFIX}_${LIBCORE}p${REVISION}.${LIBSUFFIX}")
  508. set(LIBNAME_P "${LIBPREFIX}_${LIBCORE}p${REVISION}_p.${LIBSUFFIX}")
  509. else ()
  510. set(LIBNAME "${LIBPREFIX}_${LIBCORE}${REVISION}.${LIBSUFFIX}")
  511. set(LIBNAME_P "${LIBPREFIX}_${LIBCORE}${REVISION}_p.${LIBSUFFIX}")
  512. endif ()
  513. endif ()
  514. set(LIBDLLNAME "${LIBPREFIX}.dll")
  515. set(LIBSONAME "${LIBNAME}.${LIBSUFFIX}.so")
  516. set(LIBDYNNAME "${LIBNAME}.${LIBSUFFIX}.dylib")
  517. set(LIBDEFNAME "${LIBNAME}.${LIBSUFFIX}.def")
  518. set(LIBEXPNAME "${LIBNAME}.${LIBSUFFIX}.exp")
  519. set(LIBZIPNAME "${LIBNAME}.${LIBSUFFIX}.zip")
  520. set(LIBS "${PROJECT_SOURCE_DIR}/${LIBNAME}")
  521. set(LIBS_P "${PROJECT_SOURCE_DIR}/${LIBNAME_P}")
  522. set(LIB_COMPONENTS BLAS)
  523. if (NOT NO_CBLAS)
  524. set(LIB_COMPONENTS "${LIB_COMPONENTS} CBLAS")
  525. endif ()
  526. if (NOT NO_LAPACK)
  527. set(LIB_COMPONENTS "${LIB_COMPONENTS} LAPACK")
  528. if (NOT NO_LAPACKE)
  529. set(LIB_COMPONENTS "${LIB_COMPONENTS} LAPACKE")
  530. endif ()
  531. if (BUILD_RELAPACK)
  532. set(LIB_COMPONENTS "${LIB_COMPONENTS} ReLAPACK")
  533. endif ()
  534. endif ()
  535. if (ONLY_CBLAS)
  536. set(LIB_COMPONENTS CBLAS)
  537. endif ()
  538. # For GEMM3M
  539. set(USE_GEMM3M 0)
  540. if (DEFINED ARCH)
  541. if (X86 OR X86_64 OR ${ARCH} STREQUAL "ia64" OR MIPS64)
  542. set(USE_GEMM3M 1)
  543. endif ()
  544. if (${CORE} STREQUAL "generic")
  545. set(USE_GEMM3M 0)
  546. endif ()
  547. endif ()
  548. #export OSNAME
  549. #export ARCH
  550. #export CORE
  551. #export LIBCORE
  552. #export PGCPATH
  553. #export CONFIG
  554. #export CC
  555. #export FC
  556. #export BU
  557. #export FU
  558. #export NEED2UNDERSCORES
  559. #export USE_THREAD
  560. #export NUM_THREADS
  561. #export NUM_CORES
  562. #export SMP
  563. #export MAKEFILE_RULE
  564. #export NEED_PIC
  565. #export BINARY
  566. #export BINARY32
  567. #export BINARY64
  568. #export F_COMPILER
  569. #export C_COMPILER
  570. #export USE_OPENMP
  571. #export CROSS
  572. #export CROSS_SUFFIX
  573. #export NOFORTRAN
  574. #export NO_FBLAS
  575. #export EXTRALIB
  576. #export CEXTRALIB
  577. #export FEXTRALIB
  578. #export HAVE_SSE
  579. #export HAVE_SSE2
  580. #export HAVE_SSE3
  581. #export HAVE_SSSE3
  582. #export HAVE_SSE4_1
  583. #export HAVE_SSE4_2
  584. #export HAVE_SSE4A
  585. #export HAVE_SSE5
  586. #export HAVE_AVX
  587. #export HAVE_VFP
  588. #export HAVE_VFPV3
  589. #export HAVE_VFPV4
  590. #export HAVE_NEON
  591. #export KERNELDIR
  592. #export FUNCTION_PROFILE
  593. #export TARGET_CORE
  594. #
  595. #export SBGEMM_UNROLL_M
  596. #export SBGEMM_UNROLL_N
  597. #export SGEMM_UNROLL_M
  598. #export SGEMM_UNROLL_N
  599. #export DGEMM_UNROLL_M
  600. #export DGEMM_UNROLL_N
  601. #export QGEMM_UNROLL_M
  602. #export QGEMM_UNROLL_N
  603. #export CGEMM_UNROLL_M
  604. #export CGEMM_UNROLL_N
  605. #export ZGEMM_UNROLL_M
  606. #export ZGEMM_UNROLL_N
  607. #export XGEMM_UNROLL_M
  608. #export XGEMM_UNROLL_N
  609. #export CGEMM3M_UNROLL_M
  610. #export CGEMM3M_UNROLL_N
  611. #export ZGEMM3M_UNROLL_M
  612. #export ZGEMM3M_UNROLL_N
  613. #export XGEMM3M_UNROLL_M
  614. #export XGEMM3M_UNROLL_N
  615. #if (USE_CUDA)
  616. # export CUDADIR
  617. # export CUCC
  618. # export CUFLAGS
  619. # export CULIB
  620. #endif