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