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.

CMakeLists.txt 25 kB

5 years ago
5 years ago
5 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646
  1. ##
  2. ## Author: Hank Anderson <hank@statease.com>
  3. ##
  4. cmake_minimum_required(VERSION 3.16.0)
  5. project(OpenBLAS C ASM)
  6. set(OpenBLAS_MAJOR_VERSION 0)
  7. set(OpenBLAS_MINOR_VERSION 3)
  8. set(OpenBLAS_PATCH_VERSION 28.dev)
  9. set(OpenBLAS_VERSION "${OpenBLAS_MAJOR_VERSION}.${OpenBLAS_MINOR_VERSION}.${OpenBLAS_PATCH_VERSION}")
  10. # Adhere to GNU filesystem layout conventions
  11. include(GNUInstallDirs)
  12. include(CMakePackageConfigHelpers)
  13. #######
  14. option(BUILD_WITHOUT_LAPACK "Do not build LAPACK and LAPACKE (Only BLAS or CBLAS)" OFF)
  15. option(BUILD_LAPACK_DEPRECATED "When building LAPACK, include also some older, deprecated routines" ON)
  16. set(LAPACK_STRLEN "" CACHE STRING "When building LAPACK, use this type (e.g. \"int\") for character lengths (defaults to size_t)")
  17. option(BUILD_TESTING "Build LAPACK testsuite when building LAPACK" ON)
  18. option(BUILD_BENCHMARKS "Build the collection of BLAS/LAPACK benchmarks" OFF)
  19. option(C_LAPACK "Build LAPACK from C sources instead of the original Fortran" OFF)
  20. option(BUILD_WITHOUT_CBLAS "Do not build the C interface (CBLAS) to the BLAS functions" OFF)
  21. option(DYNAMIC_ARCH "Include support for multiple CPU targets, with automatic selection at runtime (x86/x86_64, aarch64, ppc or RISCV64-RVV1.0 only)" OFF)
  22. option(DYNAMIC_OLDER "Include specific support for older x86 cpu models (Penryn,Dunnington,Atom,Nano,Opteron) with DYNAMIC_ARCH" OFF)
  23. option(BUILD_RELAPACK "Build with ReLAPACK (recursive implementation of several LAPACK functions on top of standard LAPACK)" OFF)
  24. option(USE_LOCKING "Use locks even in single-threaded builds to make them callable from multiple threads" OFF)
  25. option(USE_PERL "Use the older PERL scripts for build preparation instead of universal shell scripts" OFF)
  26. option(NO_WARMUP "Do not run a benchmark on each startup just to find the best location for the memory buffer" ON)
  27. option(FIXED_LIBNAME "Use a non-versioned name for the library and no symbolic linking to variant names" OFF)
  28. set(LIBNAMEPREFIX "" CACHE STRING "Add a prefix to the openblas part of the library name" )
  29. set(LIBNAMESUFFIX "" CACHE STRING "Add a suffix after the openblas part of the library name" )
  30. if(${CMAKE_SYSTEM_NAME} MATCHES "Linux")
  31. option(NO_AFFINITY "Disable support for CPU affinity masks to avoid binding processes from e.g. R or numpy/scipy to a single core" ON)
  32. else()
  33. set(NO_AFFINITY 1)
  34. endif()
  35. option(CPP_THREAD_SAFETY_TEST "Run a massively parallel DGEMM test to confirm thread safety of the library (requires OpenMP and about 1.3GB of RAM)" OFF)
  36. option(CPP_THREAD_SAFETY_GEMV "Run a massively parallel DGEMV test to confirm thread safety of the library (requires OpenMP)" OFF)
  37. option(BUILD_STATIC_LIBS "Build static library" OFF)
  38. if(NOT BUILD_STATIC_LIBS AND NOT BUILD_SHARED_LIBS)
  39. set(BUILD_STATIC_LIBS ON CACHE BOOL "Build static library" FORCE)
  40. endif()
  41. if((BUILD_STATIC_LIBS AND BUILD_SHARED_LIBS) AND MSVC)
  42. message(WARNING "Could not enable both BUILD_STATIC_LIBS and BUILD_SHARED_LIBS with MSVC, Disable BUILD_SHARED_LIBS")
  43. set(BUILD_SHARED_LIBS OFF CACHE BOOL "Build static library" FORCE)
  44. endif()
  45. # Add a prefix or suffix to all exported symbol names in the shared library.
  46. # Avoids conflicts with other BLAS libraries, especially when using
  47. # 64 bit integer interfaces in OpenBLAS.
  48. set(SYMBOLPREFIX "" CACHE STRING "Add a prefix to all exported symbol names in the shared library to avoid conflicts with other BLAS libraries" )
  49. set(SYMBOLSUFFIX "" CACHE STRING "Add a suffix to all exported symbol names in the shared library, e.g. _64 for INTERFACE64 builds" )
  50. #######
  51. if(BUILD_WITHOUT_LAPACK)
  52. set(NO_LAPACK 1)
  53. set(NO_LAPACKE 1)
  54. endif()
  55. if(BUILD_WITHOUT_CBLAS)
  56. set(NO_CBLAS 1)
  57. endif()
  58. #######
  59. if(MSVC AND MSVC_STATIC_CRT)
  60. set(CompilerFlags
  61. CMAKE_CXX_FLAGS
  62. CMAKE_CXX_FLAGS_DEBUG
  63. CMAKE_CXX_FLAGS_RELEASE
  64. CMAKE_C_FLAGS
  65. CMAKE_C_FLAGS_DEBUG
  66. CMAKE_C_FLAGS_RELEASE
  67. )
  68. foreach(CompilerFlag ${CompilerFlags})
  69. string(REPLACE "/MD" "/MT" ${CompilerFlag} "${${CompilerFlag}}")
  70. endforeach()
  71. endif()
  72. message(WARNING "CMake support is experimental. It does not yet support all build options and may not produce the same Makefiles that OpenBLAS ships with.")
  73. if (USE_OPENMP)
  74. find_package(OpenMP REQUIRED)
  75. endif ()
  76. include("${PROJECT_SOURCE_DIR}/cmake/utils.cmake")
  77. include("${PROJECT_SOURCE_DIR}/cmake/system.cmake")
  78. set(OpenBLAS_LIBNAME ${LIBNAMEPREFIX}openblas${LIBNAMESUFFIX}${SUFFIX64_UNDERSCORE})
  79. set(BLASDIRS interface driver/level2 driver/level3 driver/others)
  80. if (NOT DYNAMIC_ARCH)
  81. list(APPEND BLASDIRS kernel)
  82. endif ()
  83. if (DEFINED SANITY_CHECK)
  84. list(APPEND BLASDIRS reference)
  85. endif ()
  86. set(SUBDIRS ${BLASDIRS})
  87. if (NOT NO_LAPACK)
  88. if(BUILD_RELAPACK)
  89. list(APPEND SUBDIRS relapack/src)
  90. endif()
  91. list(APPEND SUBDIRS lapack)
  92. endif ()
  93. if (NOT DEFINED BUILD_BFLOAT16)
  94. set (BUILD_BFLOAT16 false)
  95. endif ()
  96. # set which float types we want to build for
  97. if (NOT DEFINED BUILD_SINGLE AND NOT DEFINED BUILD_DOUBLE AND NOT DEFINED BUILD_COMPLEX AND NOT DEFINED BUILD_COMPLEX16)
  98. # if none are defined, build for all
  99. # set(BUILD_BFLOAT16 true)
  100. set(BUILD_SINGLE true)
  101. set(BUILD_DOUBLE true)
  102. set(BUILD_COMPLEX true)
  103. set(BUILD_COMPLEX16 true)
  104. endif ()
  105. if (NOT DEFINED BUILD_MATGEN)
  106. set(BUILD_MATGEN true)
  107. endif()
  108. set(FLOAT_TYPES "")
  109. if (BUILD_SINGLE)
  110. message(STATUS "Building Single Precision")
  111. list(APPEND FLOAT_TYPES "SINGLE") # defines nothing
  112. endif ()
  113. if (BUILD_DOUBLE)
  114. message(STATUS "Building Double Precision")
  115. list(APPEND FLOAT_TYPES "DOUBLE") # defines DOUBLE
  116. endif ()
  117. if (BUILD_COMPLEX)
  118. message(STATUS "Building Complex Precision")
  119. list(APPEND FLOAT_TYPES "COMPLEX") # defines COMPLEX
  120. endif ()
  121. if (BUILD_COMPLEX16)
  122. message(STATUS "Building Double Complex Precision")
  123. list(APPEND FLOAT_TYPES "ZCOMPLEX") # defines COMPLEX and DOUBLE
  124. endif ()
  125. if (BUILD_BFLOAT16)
  126. message(STATUS "Building Half Precision")
  127. # list(APPEND FLOAT_TYPES "BFLOAT16") # defines nothing
  128. endif ()
  129. if (NOT DEFINED CORE OR "${CORE}" STREQUAL "UNKNOWN")
  130. message(FATAL_ERROR "Detecting CPU failed. Please set TARGET explicitly, e.g. make TARGET=your_cpu_target. Please read README for details.")
  131. endif ()
  132. #Set default output directory
  133. set( CMAKE_LIBRARY_OUTPUT_DIRECTORY ${PROJECT_BINARY_DIR}/lib)
  134. set( CMAKE_ARCHIVE_OUTPUT_DIRECTORY ${PROJECT_BINARY_DIR}/lib)
  135. if(MSVC)
  136. set( CMAKE_LIBRARY_OUTPUT_DIRECTORY_DEBUG ${PROJECT_BINARY_DIR}/lib/Debug)
  137. set( CMAKE_ARCHIVE_OUTPUT_DIRECTORY_RELEASE ${PROJECT_BINARY_DIR}/lib/Release)
  138. endif ()
  139. # get obj vars into format that add_library likes: $<TARGET_OBJS:objlib> (see http://www.cmake.org/cmake/help/v3.0/command/add_library.html)
  140. set(TARGET_OBJS "")
  141. foreach (SUBDIR ${SUBDIRS})
  142. add_subdirectory(${SUBDIR})
  143. string(REPLACE "/" "_" subdir_obj ${SUBDIR})
  144. list(APPEND TARGET_OBJS "$<TARGET_OBJECTS:${subdir_obj}>")
  145. endforeach ()
  146. # netlib:
  147. # Can't just use lapack-netlib's CMake files, since they are set up to search for BLAS, build and install a binary. We just want to build a couple of lib files out of lapack and lapacke.
  148. # Not using add_subdirectory here because lapack-netlib already has its own CMakeLists.txt. Instead include a cmake script with the sources we want.
  149. if (NOT NO_LAPACK)
  150. include("${PROJECT_SOURCE_DIR}/cmake/lapack.cmake")
  151. if (NOT NO_LAPACKE)
  152. include("${PROJECT_SOURCE_DIR}/cmake/lapacke.cmake")
  153. endif ()
  154. endif ()
  155. # Only generate .def for dll on MSVC and always produce pdb files for debug and release
  156. if(MSVC)
  157. if (${CMAKE_MAJOR_VERSION}.${CMAKE_MINOR_VERSION} VERSION_LESS 3.4)
  158. set(OpenBLAS_DEF_FILE "${PROJECT_BINARY_DIR}/openblas.def")
  159. endif()
  160. set(CMAKE_C_FLAGS_RELEASE "${CMAKE_C_FLAGS_RELEASE} /Zi")
  161. set(CMAKE_SHARED_LINKER_FLAGS_RELEASE "${CMAKE_SHARED_LINKER_FLAGS_RELEASE} /DEBUG /OPT:REF /OPT:ICF")
  162. endif()
  163. if (${DYNAMIC_ARCH})
  164. add_subdirectory(kernel)
  165. foreach(TARGET_CORE ${DYNAMIC_CORE})
  166. message("${TARGET_CORE}")
  167. list(APPEND TARGET_OBJS "$<TARGET_OBJECTS:kernel_${TARGET_CORE}>")
  168. endforeach()
  169. endif ()
  170. # add objects to the openblas lib
  171. if(NOT NO_LAPACK)
  172. add_library(LAPACK_OVERRIDES OBJECT ${LA_SOURCES})
  173. list(APPEND TARGET_OBJS "$<TARGET_OBJECTS:LAPACK_OVERRIDES>")
  174. endif()
  175. if(NOT NO_LAPACKE)
  176. add_library(LAPACKE OBJECT ${LAPACKE_SOURCES})
  177. list(APPEND TARGET_OBJS "$<TARGET_OBJECTS:LAPACKE>")
  178. endif()
  179. #if(BUILD_RELAPACK)
  180. # add_library(RELAPACK OBJECT ${RELA_SOURCES})
  181. # list(APPEND TARGET_OBJS "$<TARGET_OBJECTS:RELAPACK>")
  182. #endif()
  183. set(OpenBLAS_LIBS "")
  184. if(BUILD_STATIC_LIBS)
  185. add_library(${OpenBLAS_LIBNAME}_static STATIC ${TARGET_OBJS} ${OpenBLAS_DEF_FILE})
  186. target_include_directories(${OpenBLAS_LIBNAME}_static INTERFACE $<INSTALL_INTERFACE:include/openblas${SUFFIX64}>)
  187. list(APPEND OpenBLAS_LIBS ${OpenBLAS_LIBNAME}_static)
  188. endif()
  189. if(BUILD_SHARED_LIBS)
  190. add_library(${OpenBLAS_LIBNAME}_shared SHARED ${TARGET_OBJS} ${OpenBLAS_DEF_FILE})
  191. target_include_directories(${OpenBLAS_LIBNAME}_shared INTERFACE $<INSTALL_INTERFACE:include/openblas${SUFFIX64}>)
  192. list(APPEND OpenBLAS_LIBS ${OpenBLAS_LIBNAME}_shared)
  193. endif()
  194. if(BUILD_STATIC_LIBS)
  195. add_library(${OpenBLAS_LIBNAME} ALIAS ${OpenBLAS_LIBNAME}_static)
  196. else()
  197. add_library(${OpenBLAS_LIBNAME} ALIAS ${OpenBLAS_LIBNAME}_shared)
  198. endif()
  199. set_target_properties(${OpenBLAS_LIBS} PROPERTIES OUTPUT_NAME ${OpenBLAS_LIBNAME})
  200. # Android needs to explicitly link against libm
  201. if (${CMAKE_SYSTEM_NAME} MATCHES "AIX|Android|Linux|FreeBSD|OpenBSD|NetBSD|DragonFly|Darwin")
  202. if(BUILD_STATIC_LIBS)
  203. target_link_libraries(${OpenBLAS_LIBNAME}_static m)
  204. endif()
  205. if(BUILD_SHARED_LIBS)
  206. target_link_libraries(${OpenBLAS_LIBNAME}_shared m)
  207. endif()
  208. endif()
  209. if (USE_OPENMP)
  210. if(BUILD_STATIC_LIBS)
  211. target_link_libraries(${OpenBLAS_LIBNAME}_static OpenMP::OpenMP_C)
  212. endif()
  213. if(BUILD_SHARED_LIBS)
  214. target_link_libraries(${OpenBLAS_LIBNAME}_shared OpenMP::OpenMP_C)
  215. endif()
  216. endif()
  217. # Seems that this hack doesn't required since macOS 11 Big Sur
  218. if (APPLE AND BUILD_SHARED_LIBS AND CMAKE_HOST_SYSTEM_VERSION VERSION_LESS 20)
  219. set (CMAKE_C_USE_RESPONSE_FILE_FOR_OBJECTS 1)
  220. if (NOT NOFORTRAN)
  221. set (CMAKE_Fortran_USE_RESPONSE_FILE_FOR_OBJECTS 1)
  222. set (CMAKE_Fortran_CREATE_SHARED_LIBRARY
  223. "sh -c 'cat ${CMAKE_BINARY_DIR}/CMakeFiles/openblas_shared.dir/objects*.rsp | xargs -n 1024 ${CMAKE_AR} -ru libopenblas.a && exit 0' "
  224. "sh -c '${CMAKE_AR} -rs libopenblas.a ${CMAKE_BINARY_DIR}/driver/others/CMakeFiles/driver_others.dir/xerbla.c.o && exit 0' "
  225. "sh -c 'echo \"\" | ${CMAKE_Fortran_COMPILER} -o dummy.o -c -x f95-cpp-input - '"
  226. "sh -c '${CMAKE_Fortran_COMPILER} -fpic -shared -Wl,-all_load -Wl,-force_load,libopenblas.a -Wl,-noall_load dummy.o -o ${CMAKE_LIBRARY_OUTPUT_DIRECTORY}/libopenblas.${OpenBLAS_MAJOR_VERSION}.${OpenBLAS_MINOR_VERSION}.dylib'"
  227. "sh -c 'ls -l ${CMAKE_BINARY_DIR}/lib'")
  228. else ()
  229. set (CMAKE_C_CREATE_SHARED_LIBRARY
  230. "sh -c 'cat ${CMAKE_BINARY_DIR}/CMakeFiles/openblas_shared.dir/objects*.rsp | xargs -n 1024 ${CMAKE_AR} -ru libopenblas.a && exit 0' "
  231. "sh -c '${CMAKE_AR} -rs libopenblas.a ${CMAKE_BINARY_DIR}/driver/others/CMakeFiles/driver_others.dir/xerbla.c.o && exit 0' "
  232. "sh -c '${CMAKE_C_COMPILER} -fpic -shared -Wl,-all_load -Wl,-force_load,libopenblas.a -Wl,-noall_load -o ${CMAKE_LIBRARY_OUTPUT_DIRECTORY}/libopenblas.${OpenBLAS_MAJOR_VERSION}.${OpenBLAS_MINOR_VERSION}.dylib'")
  233. endif ()
  234. endif()
  235. # Handle MSVC exports
  236. if(MSVC AND BUILD_SHARED_LIBS)
  237. if (${CMAKE_MAJOR_VERSION}.${CMAKE_MINOR_VERSION} VERSION_LESS 3.4)
  238. include("${PROJECT_SOURCE_DIR}/cmake/export.cmake")
  239. else()
  240. # Creates verbose .def file (51KB vs 18KB)
  241. set_target_properties(${OpenBLAS_LIBNAME}_shared PROPERTIES WINDOWS_EXPORT_ALL_SYMBOLS true)
  242. endif()
  243. endif()
  244. # Set output for libopenblas
  245. set_target_properties( ${OpenBLAS_LIBS} PROPERTIES RUNTIME_OUTPUT_DIRECTORY ${PROJECT_BINARY_DIR}/lib)
  246. set_target_properties( ${OpenBLAS_LIBS} PROPERTIES LIBRARY_OUTPUT_NAME_DEBUG "${OpenBLAS_LIBNAME}_d")
  247. set_target_properties( ${OpenBLAS_LIBS} PROPERTIES EXPORT_NAME "OpenBLAS")
  248. foreach (OUTPUTCONFIG ${CMAKE_CONFIGURATION_TYPES})
  249. string( TOUPPER ${OUTPUTCONFIG} OUTPUTCONFIG )
  250. set_target_properties( ${OpenBLAS_LIBS} PROPERTIES RUNTIME_OUTPUT_DIRECTORY_${OUTPUTCONFIG} ${PROJECT_BINARY_DIR}/lib/${OUTPUTCONFIG} )
  251. set_target_properties( ${OpenBLAS_LIBS} PROPERTIES LIBRARY_OUTPUT_DIRECTORY_${OUTPUTCONFIG} ${PROJECT_BINARY_DIR}/lib/${OUTPUTCONFIG} )
  252. set_target_properties( ${OpenBLAS_LIBS} PROPERTIES ARCHIVE_OUTPUT_DIRECTORY_${OUTPUTCONFIG} ${PROJECT_BINARY_DIR}/lib/${OUTPUTCONFIG} )
  253. endforeach()
  254. enable_testing()
  255. if (USE_THREAD)
  256. # Add threading library to linker
  257. find_package(Threads)
  258. if (THREADS_HAVE_PTHREAD_ARG)
  259. set_target_properties(${OpenBLAS_LIBS} PROPERTIES
  260. COMPILE_OPTIONS "-pthread"
  261. INTERFACE_COMPILE_OPTIONS "-pthread"
  262. )
  263. endif()
  264. if(BUILD_STATIC_LIBS)
  265. target_link_libraries(${OpenBLAS_LIBNAME}_static ${CMAKE_THREAD_LIBS_INIT})
  266. endif()
  267. if(BUILD_SHARED_LIBS)
  268. target_link_libraries(${OpenBLAS_LIBNAME}_shared ${CMAKE_THREAD_LIBS_INIT})
  269. endif()
  270. endif()
  271. #if (MSVC OR NOT NOFORTRAN)
  272. if (NOT NO_CBLAS)
  273. if (NOT ONLY_CBLAS)
  274. # Broken without fortran on unix
  275. add_subdirectory(utest)
  276. endif()
  277. endif()
  278. if (NOT NOFORTRAN)
  279. if (NOT ONLY_CBLAS)
  280. # Build test and ctest
  281. add_subdirectory(test)
  282. endif()
  283. if (BUILD_TESTING AND NOT BUILD_WITHOUT_LAPACK)
  284. add_subdirectory(lapack-netlib/TESTING)
  285. endif()
  286. endif()
  287. if(NOT NO_CBLAS)
  288. if (NOT ONLY_CBLAS)
  289. add_subdirectory(ctest)
  290. endif()
  291. endif()
  292. if (CPP_THREAD_SAFETY_TEST OR CPP_THREAD_SAFETY_GEMV)
  293. add_subdirectory(cpp_thread_test)
  294. endif()
  295. if (NOT FIXED_LIBNAME)
  296. set_target_properties(${OpenBLAS_LIBS} PROPERTIES
  297. VERSION ${OpenBLAS_MAJOR_VERSION}.${OpenBLAS_MINOR_VERSION}
  298. SOVERSION ${OpenBLAS_MAJOR_VERSION}
  299. )
  300. endif()
  301. if (BUILD_SHARED_LIBS AND BUILD_RELAPACK)
  302. if (NOT MSVC)
  303. target_link_libraries(${OpenBLAS_LIBNAME}_shared "-Wl,-allow-multiple-definition")
  304. else()
  305. set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} /FORCE:MULTIPLE")
  306. endif()
  307. endif()
  308. if (BUILD_SHARED_LIBS AND NOT ${SYMBOLPREFIX}${SYMBOLSUFFIX} STREQUAL "")
  309. if (NOT DEFINED ARCH)
  310. set(ARCH_IN "x86_64")
  311. else()
  312. set(ARCH_IN ${ARCH})
  313. endif()
  314. if (${CORE} STREQUAL "generic")
  315. set(ARCH_IN "GENERIC")
  316. endif ()
  317. if (NOT DEFINED EXPRECISION)
  318. set(EXPRECISION_IN 0)
  319. else()
  320. set(EXPRECISION_IN ${EXPRECISION})
  321. endif()
  322. if (NOT DEFINED NO_CBLAS)
  323. set(NO_CBLAS_IN 0)
  324. else()
  325. set(NO_CBLAS_IN ${NO_CBLAS})
  326. endif()
  327. if (NOT DEFINED NO_LAPACK)
  328. set(NO_LAPACK_IN 0)
  329. else()
  330. set(NO_LAPACK_IN ${NO_LAPACK})
  331. endif()
  332. if (NOT DEFINED NO_LAPACKE)
  333. set(NO_LAPACKE_IN 0)
  334. else()
  335. set(NO_LAPACKE_IN ${NO_LAPACKE})
  336. endif()
  337. if (NOT DEFINED NEED2UNDERSCORES)
  338. set(NEED2UNDERSCORES_IN 0)
  339. else()
  340. set(NEED2UNDERSCORES_IN ${NEED2UNDERSCORES})
  341. endif()
  342. if (NOT DEFINED ONLY_CBLAS)
  343. set(ONLY_CBLAS_IN 0)
  344. else()
  345. set(ONLY_CBLAS_IN ${ONLY_CBLAS})
  346. endif()
  347. if (NOT DEFINED BU)
  348. set(BU _)
  349. endif()
  350. if (NOT ${SYMBOLPREFIX} STREQUAL "")
  351. message(STATUS "adding prefix ${SYMBOLPREFIX} to names of exported symbols in ${OpenBLAS_LIBNAME}")
  352. endif()
  353. if (NOT ${SYMBOLSUFFIX} STREQUAL "")
  354. message(STATUS "adding suffix ${SYMBOLSUFFIX} to names of exported symbols in ${OpenBLAS_LIBNAME}")
  355. endif()
  356. if (${BUILD_LAPACK_DEPRECATED})
  357. set (BLD 1)
  358. else ()
  359. set (BLD 0)
  360. endif()
  361. if (${BUILD_BFLOAT16})
  362. set (BBF16 1)
  363. else ()
  364. set (BBF16 0)
  365. endif()
  366. if (${BUILD_SINGLE})
  367. set (BS 1)
  368. else ()
  369. set (BS 0)
  370. endif()
  371. if (${BUILD_DOUBLE})
  372. set (BD 1)
  373. else ()
  374. set (BD 0)
  375. endif()
  376. if (${BUILD_COMPLEX})
  377. set (BC 1)
  378. else ()
  379. set (BC 0)
  380. endif()
  381. if (${BUILD_COMPLEX16})
  382. set (BZ 1)
  383. else ()
  384. set (BZ 0)
  385. endif()
  386. if (NOT USE_PERL)
  387. add_custom_command(TARGET ${OpenBLAS_LIBNAME}_shared POST_BUILD
  388. COMMAND ${PROJECT_SOURCE_DIR}/exports/gensymbol "objcopy" "${ARCH}" "${BU}" "${EXPRECISION_IN}" "${NO_CBLAS_IN}" "${NO_LAPACK_IN}" "${NO_LAPACKE_IN}" "${NEED2UNDERSCORES_IN}" "${ONLY_CBLAS_IN}" \"${SYMBOLPREFIX}\" \"${SYMBOLSUFFIX}\" "${BLD}" "${BBF16}" "${BS}" "${BD}" "${BC}" "${BZ}" > ${PROJECT_BINARY_DIR}/objcopy.def
  389. COMMAND objcopy -v --redefine-syms ${PROJECT_BINARY_DIR}/objcopy.def ${PROJECT_BINARY_DIR}/lib/lib${OpenBLAS_LIBNAME}.so
  390. COMMENT "renaming symbols"
  391. )
  392. else()
  393. add_custom_command(TARGET ${OpenBLAS_LIBNAME}_shared POST_BUILD
  394. COMMAND perl ${PROJECT_SOURCE_DIR}/exports/gensymbol.pl "objcopy" "${ARCH}" "${BU}" "${EXPRECISION_IN}" "${NO_CBLAS_IN}" "${NO_LAPACK_IN}" "${NO_LAPACKE_IN}" "${NEED2UNDERSCORES_IN}" "${ONLY_CBLAS_IN}" \"${SYMBOLPREFIX}\" \"${SYMBOLSUFFIX}\" "${BLD}" "${BBF16}" "${BS}" "${BD}" "${BC}" "${BZ}" > ${PROJECT_BINARY_DIR}/objcopy.def
  395. COMMAND objcopy -v --redefine-syms ${PROJECT_BINARY_DIR}/objcopy.def ${PROJECT_BINARY_DIR}/lib/lib${OpenBLAS_LIBNAME}.so
  396. COMMENT "renaming symbols"
  397. )
  398. endif()
  399. endif()
  400. if (BUILD_BENCHMARKS)
  401. #find_package(OpenMP REQUIRED)
  402. file(GLOB SOURCES "benchmark/*.c")
  403. if (NOT USE_OPENMP)
  404. file(GLOB REMFILE "benchmark/smallscaling.c")
  405. list(REMOVE_ITEM SOURCES ${REMFILE})
  406. endif()
  407. if (BUILD_WITHOUT_LAPACK)
  408. file(GLOB REMFILE "benchmark/cholesky.c")
  409. list(REMOVE_ITEM SOURCES ${REMFILE})
  410. file(GLOB REMFILE "benchmark/geev.c")
  411. list(REMOVE_ITEM SOURCES ${REMFILE})
  412. file(GLOB REMFILE "benchmark/gesv.c")
  413. list(REMOVE_ITEM SOURCES ${REMFILE})
  414. file(GLOB REMFILE "benchmark/getri.c")
  415. list(REMOVE_ITEM SOURCES ${REMFILE})
  416. file(GLOB REMFILE "benchmark/potrf.c")
  417. list(REMOVE_ITEM SOURCES ${REMFILE})
  418. file(GLOB REMFILE "benchmark/spmv.c")
  419. list(REMOVE_ITEM SOURCES ${REMFILE})
  420. file(GLOB REMFILE "benchmark/symv.c")
  421. list(REMOVE_ITEM SOURCES ${REMFILE})
  422. file(GLOB REMFILE "benchmark/linpack.c")
  423. list(REMOVE_ITEM SOURCES ${REMFILE})
  424. endif()
  425. if (NOT USE_GEMM3M)
  426. file(GLOB REMFILE "benchmark/gemm3m.c")
  427. list(REMOVE_ITEM SOURCES ${REMFILE})
  428. endif()
  429. foreach(source ${SOURCES})
  430. get_filename_component(name ${source} NAME_WE)
  431. if ((NOT ${name} STREQUAL "zdot-intel") AND (NOT ${name} STREQUAL "cula_wrapper"))
  432. set(defines DEFAULT COMPLEX DOUBLE "COMPLEX\;DOUBLE")
  433. foreach(define ${defines})
  434. set(target_name "benchmark_${name}")
  435. if (NOT "${define}" STREQUAL "DEFAULT")
  436. string(JOIN "_" define_str ${define})
  437. set(target_name "${target_name}_${define_str}")
  438. endif()
  439. if ((NOT ${target_name} STREQUAL "benchmark_imax_COMPLEX") AND (NOT ${target_name} STREQUAL "benchmark_imax_COMPLEX_DOUBLE") AND
  440. (NOT ${target_name} STREQUAL "benchmark_imin_COMPLEX") AND (NOT ${target_name} STREQUAL "benchmark_imin_COMPLEX_DOUBLE") AND
  441. (NOT ${target_name} STREQUAL "benchmark_max_COMPLEX") AND (NOT ${target_name} STREQUAL "benchmark_max_COMPLEX_DOUBLE") AND
  442. (NOT ${target_name} STREQUAL "benchmark_min_COMPLEX") AND (NOT ${target_name} STREQUAL "benchmark_min_COMPLEX_DOUBLE"))
  443. add_executable(${target_name} ${source})
  444. target_include_directories(${target_name} PRIVATE ${CMAKE_CURRENT_SOURCE_DIR} ${CMAKE_CURRENT_BINARY_DIR})
  445. target_link_libraries(${target_name} ${OpenBLAS_LIBNAME} )
  446. # target_link_libraries(${target_name} ${OpenBLAS_LIBNAME} OpenMP::OpenMP_C)
  447. if (NOT "${define}" STREQUAL "DEFAULT")
  448. target_compile_definitions(${target_name} PRIVATE ${define})
  449. endif()
  450. endif()
  451. endforeach()
  452. endif()
  453. endforeach()
  454. endif()
  455. # Install project
  456. # Install libraries
  457. if(BUILD_SHARED_LIBS AND BUILD_STATIC_LIBS)
  458. install(TARGETS ${OpenBLAS_LIBNAME}_shared
  459. EXPORT "OpenBLAS${SUFFIX64}Targets"
  460. RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR}
  461. ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR}
  462. LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR} )
  463. install(TARGETS ${OpenBLAS_LIBNAME}_static
  464. ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR}
  465. LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR} )
  466. else()
  467. install(TARGETS ${OpenBLAS_LIBS}
  468. EXPORT "OpenBLAS${SUFFIX64}Targets"
  469. RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR}
  470. ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR}
  471. LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR} )
  472. endif()
  473. # Install headers
  474. set(CMAKE_INSTALL_INCLUDEDIR ${CMAKE_INSTALL_INCLUDEDIR}/openblas${SUFFIX64})
  475. set(CMAKE_INSTALL_FULL_INCLUDEDIR ${CMAKE_INSTALL_PREFIX}/${CMAKE_INSTALL_INCLUDEDIR})
  476. message(STATUS "Generating openblas_config.h in ${CMAKE_INSTALL_INCLUDEDIR}")
  477. set(OPENBLAS_CONFIG_H ${CMAKE_BINARY_DIR}/openblas_config.h)
  478. file(WRITE ${OPENBLAS_CONFIG_H} "#ifndef OPENBLAS_CONFIG_H\n")
  479. file(APPEND ${OPENBLAS_CONFIG_H} "#define OPENBLAS_CONFIG_H\n")
  480. file(STRINGS ${PROJECT_BINARY_DIR}/config.h __lines)
  481. foreach(line ${__lines})
  482. string(REPLACE "#define " "" line ${line})
  483. file(APPEND ${OPENBLAS_CONFIG_H} "#define OPENBLAS_${line}\n")
  484. endforeach()
  485. file(APPEND ${OPENBLAS_CONFIG_H} "#define OPENBLAS_VERSION \"OpenBLAS ${OpenBLAS_VERSION}\"\n")
  486. file(READ ${CMAKE_CURRENT_SOURCE_DIR}/openblas_config_template.h OPENBLAS_CONFIG_TEMPLATE_H_CONTENTS)
  487. file(APPEND ${OPENBLAS_CONFIG_H} "${OPENBLAS_CONFIG_TEMPLATE_H_CONTENTS}\n")
  488. file(APPEND ${OPENBLAS_CONFIG_H} "#endif /* OPENBLAS_CONFIG_H */\n")
  489. install (FILES ${OPENBLAS_CONFIG_H} DESTINATION ${CMAKE_INSTALL_INCLUDEDIR})
  490. if(NOT NOFORTRAN)
  491. message(STATUS "Generating f77blas.h in ${CMAKE_INSTALL_INCLUDEDIR}")
  492. set(F77BLAS_H ${CMAKE_BINARY_DIR}/generated/f77blas.h)
  493. file(WRITE ${F77BLAS_H} "#ifndef OPENBLAS_F77BLAS_H\n")
  494. file(APPEND ${F77BLAS_H} "#define OPENBLAS_F77BLAS_H\n")
  495. file(APPEND ${F77BLAS_H} "#include \"openblas_config.h\"\n")
  496. file(READ ${CMAKE_CURRENT_SOURCE_DIR}/common_interface.h COMMON_INTERFACE_H_CONTENTS)
  497. file(APPEND ${F77BLAS_H} "${COMMON_INTERFACE_H_CONTENTS}\n")
  498. file(APPEND ${F77BLAS_H} "#endif")
  499. install (FILES ${F77BLAS_H} DESTINATION ${CMAKE_INSTALL_INCLUDEDIR})
  500. endif()
  501. if(NOT NO_CBLAS)
  502. message (STATUS "Generating cblas.h in ${CMAKE_INSTALL_INCLUDEDIR}")
  503. set(CBLAS_H ${CMAKE_BINARY_DIR}/generated/cblas.h)
  504. file(READ ${CMAKE_CURRENT_SOURCE_DIR}/cblas.h CBLAS_H_CONTENTS)
  505. string(REPLACE "common" "openblas_config" CBLAS_H_CONTENTS_NEW "${CBLAS_H_CONTENTS}")
  506. if (NOT ${SYMBOLPREFIX} STREQUAL "")
  507. string(REPLACE " cblas" " ${SYMBOLPREFIX}cblas" CBLAS_H_CONTENTS "${CBLAS_H_CONTENTS_NEW}")
  508. string(REPLACE " openblas" " ${SYMBOLPREFIX}openblas" CBLAS_H_CONTENTS_NEW "${CBLAS_H_CONTENTS}")
  509. string (REPLACE " ${SYMBOLPREFIX}openblas_complex" " openblas_complex" CBLAS_H_CONTENTS "${CBLAS_H_CONTENTS_NEW}")
  510. string(REPLACE " goto" " ${SYMBOLPREFIX}goto" CBLAS_H_CONTENTS_NEW "${CBLAS_H_CONTENTS}")
  511. endif()
  512. if (NOT ${SYMBOLSUFFIX} STREQUAL "")
  513. string(REGEX REPLACE "(cblas[^ (]*)" "\\1${SYMBOLSUFFIX}" CBLAS_H_CONTENTS "${CBLAS_H_CONTENTS_NEW}")
  514. string(REGEX REPLACE "(openblas[^ (]*)" "\\1${SYMBOLSUFFIX}" CBLAS_H_CONTENTS_NEW "${CBLAS_H_CONTENTS}")
  515. string(REGEX REPLACE "(openblas_complex[^ ]*)${SYMBOLSUFFIX}" "\\1" CBLAS_H_CONTENTS "${CBLAS_H_CONTENTS_NEW}")
  516. string(REGEX REPLACE "(goto[^ (]*)" "\\1${SYMBOLSUFFIX}" CBLAS_H_CONTENTS_NEW "${CBLAS_H_CONTENTS}")
  517. endif()
  518. file(WRITE ${CBLAS_H} "${CBLAS_H_CONTENTS_NEW}")
  519. install (FILES ${CBLAS_H} DESTINATION ${CMAKE_INSTALL_INCLUDEDIR})
  520. endif()
  521. if(NOT NO_LAPACKE)
  522. message (STATUS "Copying LAPACKE header files to ${CMAKE_INSTALL_INCLUDEDIR}")
  523. if(BUILD_STATIC_LIBS)
  524. add_dependencies( ${OpenBLAS_LIBNAME}_static genlapacke)
  525. endif()
  526. if(BUILD_SHARED_LIBS)
  527. add_dependencies( ${OpenBLAS_LIBNAME}_shared genlapacke)
  528. endif()
  529. FILE(GLOB_RECURSE INCLUDE_FILES "${CMAKE_CURRENT_SOURCE_DIR}/lapack-netlib/LAPACKE/*.h")
  530. install (FILES ${INCLUDE_FILES} DESTINATION ${CMAKE_INSTALL_INCLUDEDIR})
  531. ADD_CUSTOM_TARGET(genlapacke
  532. COMMAND ${CMAKE_COMMAND} -E copy ${CMAKE_CURRENT_SOURCE_DIR}/lapack-netlib/LAPACKE/include/lapacke_mangling_with_flags.h.in "${CMAKE_BINARY_DIR}/lapacke_mangling.h"
  533. )
  534. install (FILES ${CMAKE_BINARY_DIR}/lapacke_mangling.h DESTINATION ${CMAKE_INSTALL_INCLUDEDIR})
  535. endif()
  536. # Install pkg-config files
  537. configure_file(${PROJECT_SOURCE_DIR}/cmake/openblas.pc.in ${PROJECT_BINARY_DIR}/openblas${SUFFIX64}.pc @ONLY)
  538. install (FILES ${PROJECT_BINARY_DIR}/openblas${SUFFIX64}.pc DESTINATION ${CMAKE_INSTALL_LIBDIR}/pkgconfig/)
  539. set(PN OpenBLAS)
  540. set(CMAKECONFIG_INSTALL_DIR "${CMAKE_INSTALL_LIBDIR}/cmake/${PN}${SUFFIX64}")
  541. configure_package_config_file(cmake/${PN}Config.cmake.in
  542. "${CMAKE_CURRENT_BINARY_DIR}/${PN}${SUFFIX64}Config.cmake"
  543. INSTALL_DESTINATION ${CMAKECONFIG_INSTALL_DIR})
  544. write_basic_package_version_file(${CMAKE_CURRENT_BINARY_DIR}/${PN}ConfigVersion.cmake
  545. VERSION ${${PN}_VERSION}
  546. COMPATIBILITY AnyNewerVersion)
  547. install(FILES ${CMAKE_CURRENT_BINARY_DIR}/${PN}${SUFFIX64}Config.cmake
  548. DESTINATION ${CMAKECONFIG_INSTALL_DIR})
  549. install(FILES ${CMAKE_CURRENT_BINARY_DIR}/${PN}ConfigVersion.cmake
  550. RENAME ${PN}${SUFFIX64}ConfigVersion.cmake
  551. DESTINATION ${CMAKECONFIG_INSTALL_DIR})
  552. install(EXPORT "${PN}${SUFFIX64}Targets"
  553. NAMESPACE "${PN}${SUFFIX64}::"
  554. DESTINATION ${CMAKECONFIG_INSTALL_DIR})