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

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