Merge topic 'findblas-bugs'
4585e57
FindBLAS/FindLAPACK: Work with MKL version 10.3 (#12924, #12925)
This commit is contained in:
commit
d39acfa105
|
@ -23,6 +23,7 @@
|
||||||
##########
|
##########
|
||||||
### List of vendors (BLA_VENDOR) valid in this module
|
### List of vendors (BLA_VENDOR) valid in this module
|
||||||
## Goto,ATLAS PhiPACK,CXML,DXML,SunPerf,SCSL,SGIMATH,IBMESSL,Intel10_32 (intel mkl v10 32 bit),Intel10_64lp (intel mkl v10 64 bit,lp thread model, lp64 model),
|
## Goto,ATLAS PhiPACK,CXML,DXML,SunPerf,SCSL,SGIMATH,IBMESSL,Intel10_32 (intel mkl v10 32 bit),Intel10_64lp (intel mkl v10 64 bit,lp thread model, lp64 model),
|
||||||
|
## Intel10_64lp_seq (intel mkl v10 64 bit,sequential code, lp64 model),
|
||||||
## Intel( older versions of mkl 32 and 64 bit), ACML,ACML_MP,ACML_GPU,Apple, NAS, Generic
|
## Intel( older versions of mkl 32 and 64 bit), ACML,ACML_MP,ACML_GPU,Apple, NAS, Generic
|
||||||
# C/CXX should be enabled to use Intel mkl
|
# C/CXX should be enabled to use Intel mkl
|
||||||
|
|
||||||
|
@ -85,6 +86,7 @@ if (NOT _libdir)
|
||||||
set(_libdir /usr/local/lib /usr/lib /usr/local/lib64 /usr/lib64 ENV LD_LIBRARY_PATH)
|
set(_libdir /usr/local/lib /usr/lib /usr/local/lib64 /usr/lib64 ENV LD_LIBRARY_PATH)
|
||||||
endif ()
|
endif ()
|
||||||
endif ()
|
endif ()
|
||||||
|
|
||||||
foreach(_library ${_list})
|
foreach(_library ${_list})
|
||||||
set(_combined_name ${_combined_name}_${_library})
|
set(_combined_name ${_combined_name}_${_library})
|
||||||
|
|
||||||
|
@ -115,7 +117,7 @@ foreach(_library ${_list})
|
||||||
endforeach(_library ${_list})
|
endforeach(_library ${_list})
|
||||||
if(_libraries_work)
|
if(_libraries_work)
|
||||||
# Test this combination of libraries.
|
# Test this combination of libraries.
|
||||||
set(CMAKE_REQUIRED_LIBRARIES ${_flags} ${${LIBRARIES}} ${_threads})
|
set(CMAKE_REQUIRED_LIBRARIES ${_flags} ${${LIBRARIES}} ${_thread})
|
||||||
# message("DEBUG: CMAKE_REQUIRED_LIBRARIES = ${CMAKE_REQUIRED_LIBRARIES}")
|
# message("DEBUG: CMAKE_REQUIRED_LIBRARIES = ${CMAKE_REQUIRED_LIBRARIES}")
|
||||||
if (_CHECK_FORTRAN)
|
if (_CHECK_FORTRAN)
|
||||||
check_fortran_function_exists("${_name}" ${_prefix}${_combined_name}_WORKS)
|
check_fortran_function_exists("${_name}" ${_prefix}${_combined_name}_WORKS)
|
||||||
|
@ -460,117 +462,99 @@ if (BLA_VENDOR MATCHES "Intel*" OR BLA_VENDOR STREQUAL "All")
|
||||||
else(BLAS_FIND_QUIETLY OR NOT BLAS_FIND_REQUIRED)
|
else(BLAS_FIND_QUIETLY OR NOT BLAS_FIND_REQUIRED)
|
||||||
find_package(Threads REQUIRED)
|
find_package(Threads REQUIRED)
|
||||||
endif(BLAS_FIND_QUIETLY OR NOT BLAS_FIND_REQUIRED)
|
endif(BLAS_FIND_QUIETLY OR NOT BLAS_FIND_REQUIRED)
|
||||||
if (WIN32)
|
|
||||||
|
set(BLAS_SEARCH_LIBS "")
|
||||||
|
|
||||||
if(BLA_F95)
|
if(BLA_F95)
|
||||||
if(NOT BLAS95_LIBRARIES)
|
set(BLAS_mkl_SEARCH_SYMBOL SGEMM)
|
||||||
check_fortran_libraries(
|
set(_LIBRARIES BLAS95_LIBRARIES)
|
||||||
BLAS95_LIBRARIES
|
if (WIN32)
|
||||||
BLAS
|
list(APPEND BLAS_SEARCH_LIBS
|
||||||
sgemm
|
"mkl_blas95 mkl_intel_c mkl_intel_thread mkl_core libguide40")
|
||||||
""
|
|
||||||
"mkl_blas95;mkl_intel_c;mkl_intel_thread;mkl_core;libguide40"
|
|
||||||
""
|
|
||||||
)
|
|
||||||
endif(NOT BLAS95_LIBRARIES)
|
|
||||||
else(BLA_F95)
|
|
||||||
if(NOT BLAS_LIBRARIES)
|
|
||||||
check_fortran_libraries(
|
|
||||||
BLAS_LIBRARIES
|
|
||||||
BLAS
|
|
||||||
SGEMM
|
|
||||||
""
|
|
||||||
"mkl_c_dll;mkl_intel_thread_dll;mkl_core_dll;libguide40"
|
|
||||||
""
|
|
||||||
)
|
|
||||||
endif(NOT BLAS_LIBRARIES)
|
|
||||||
endif(BLA_F95)
|
|
||||||
else (WIN32)
|
else (WIN32)
|
||||||
if (BLA_VENDOR STREQUAL "Intel10_32" OR BLA_VENDOR STREQUAL "All")
|
if (BLA_VENDOR STREQUAL "Intel10_32" OR BLA_VENDOR STREQUAL "All")
|
||||||
if(BLA_F95)
|
list(APPEND BLAS_SEARCH_LIBS
|
||||||
if(NOT BLAS95_LIBRARIES)
|
"mkl_blas95 mkl_intel mkl_intel_thread mkl_core guide")
|
||||||
check_fortran_libraries(
|
endif ()
|
||||||
BLAS95_LIBRARIES
|
|
||||||
BLAS
|
|
||||||
sgemm
|
|
||||||
""
|
|
||||||
"mkl_blas95;mkl_intel;mkl_intel_thread;mkl_core;guide"
|
|
||||||
"${CMAKE_THREAD_LIBS_INIT};${LM}"
|
|
||||||
)
|
|
||||||
endif(NOT BLAS95_LIBRARIES)
|
|
||||||
else(BLA_F95)
|
|
||||||
if(NOT BLAS_LIBRARIES)
|
|
||||||
check_fortran_libraries(
|
|
||||||
BLAS_LIBRARIES
|
|
||||||
BLAS
|
|
||||||
sgemm
|
|
||||||
""
|
|
||||||
"mkl_intel;mkl_intel_thread;mkl_core;guide"
|
|
||||||
"${CMAKE_THREAD_LIBS_INIT}"
|
|
||||||
"${LM}"
|
|
||||||
)
|
|
||||||
endif(NOT BLAS_LIBRARIES)
|
|
||||||
endif(BLA_F95)
|
|
||||||
endif (BLA_VENDOR STREQUAL "Intel10_32" OR BLA_VENDOR STREQUAL "All")
|
|
||||||
if (BLA_VENDOR STREQUAL "Intel10_64lp" OR BLA_VENDOR STREQUAL "All")
|
if (BLA_VENDOR STREQUAL "Intel10_64lp" OR BLA_VENDOR STREQUAL "All")
|
||||||
if(BLA_F95)
|
# old version
|
||||||
if(NOT BLAS95_LIBRARIES)
|
list(APPEND BLAS_SEARCH_LIBS
|
||||||
check_fortran_libraries(
|
"mkl_blas95 mkl_intel_lp64 mkl_intel_thread mkl_core guide")
|
||||||
BLAS95_LIBRARIES
|
|
||||||
BLAS
|
# mkl >= 10.3
|
||||||
sgemm
|
if (CMAKE_C_COMPILER MATCHES ".+gcc.*")
|
||||||
""
|
list(APPEND BLAS_SEARCH_LIBS
|
||||||
"mkl_blas95;mkl_intel_lp64;mkl_intel_thread;mkl_core;guide"
|
"mkl_blas95_lp64 mkl_intel_lp64 mkl_gnu_thread mkl_core")
|
||||||
"${CMAKE_THREAD_LIBS_INIT};${LM}"
|
set(LM "${LM};-lgomp")
|
||||||
)
|
else ()
|
||||||
endif(NOT BLAS95_LIBRARIES)
|
list(APPEND BLAS_SEARCH_LIBS
|
||||||
else(BLA_F95)
|
"mkl_blas95_lp64 mkl_intel_lp64 mkl_intel_thread mkl_core iomp5")
|
||||||
if(NOT BLAS_LIBRARIES)
|
endif ()
|
||||||
check_fortran_libraries(
|
endif ()
|
||||||
BLAS_LIBRARIES
|
|
||||||
BLAS
|
|
||||||
sgemm
|
|
||||||
""
|
|
||||||
"mkl_intel_lp64;mkl_intel_thread;mkl_core;guide"
|
|
||||||
"${CMAKE_THREAD_LIBS_INIT};${LM}"
|
|
||||||
)
|
|
||||||
endif(NOT BLAS_LIBRARIES)
|
|
||||||
endif(BLA_F95)
|
|
||||||
endif (BLA_VENDOR STREQUAL "Intel10_64lp" OR BLA_VENDOR STREQUAL "All")
|
|
||||||
endif (WIN32)
|
endif (WIN32)
|
||||||
|
if (BLA_VENDOR STREQUAL "Intel10_64lp_seq" OR BLA_VENDOR STREQUAL "All")
|
||||||
|
list(APPEND BLAS_SEARCH_LIBS
|
||||||
|
"mkl_blas95_lp64 mkl_intel_lp64 mkl_sequential mkl_core")
|
||||||
|
endif ()
|
||||||
|
else (BLA_F95)
|
||||||
|
set(BLAS_mkl_SEARCH_SYMBOL sgemm)
|
||||||
|
set(_LIBRARIES BLAS_LIBRARIES)
|
||||||
|
if (WIN32)
|
||||||
|
list(APPEND BLAS_SEARCH_LIBS
|
||||||
|
"mkl_c_dll mkl_intel_thread_dll mkl_core_dll libguide40")
|
||||||
|
else (WIN32)
|
||||||
|
if (BLA_VENDOR STREQUAL "Intel10_32" OR BLA_VENDOR STREQUAL "All")
|
||||||
|
list(APPEND BLAS_SEARCH_LIBS
|
||||||
|
"mkl_intel mkl_intel_thread mkl_core guide")
|
||||||
|
endif ()
|
||||||
|
if (BLA_VENDOR STREQUAL "Intel10_64lp" OR BLA_VENDOR STREQUAL "All")
|
||||||
|
|
||||||
|
# old version
|
||||||
|
list(APPEND BLAS_SEARCH_LIBS
|
||||||
|
"mkl_intel_lp64 mkl_intel_thread mkl_core guide")
|
||||||
|
|
||||||
|
# mkl >= 10.3
|
||||||
|
if (CMAKE_C_COMPILER MATCHES ".+gcc.*")
|
||||||
|
list(APPEND BLAS_SEARCH_LIBS
|
||||||
|
"mkl_intel_lp64 mkl_gnu_thread mkl_core")
|
||||||
|
set(LM "${LM};-lgomp")
|
||||||
|
else ()
|
||||||
|
list(APPEND BLAS_SEARCH_LIBS
|
||||||
|
"mkl_intel_lp64 mkl_intel_thread mkl_core iomp5")
|
||||||
|
endif ()
|
||||||
|
endif ()
|
||||||
|
|
||||||
#older vesions of intel mkl libs
|
#older vesions of intel mkl libs
|
||||||
# BLAS in intel mkl library? (shared)
|
if (BLA_VENDOR STREQUAL "Intel" OR BLA_VENDOR STREQUAL "All")
|
||||||
if(NOT BLAS_LIBRARIES)
|
list(APPEND BLAS_SEARCH_LIBS
|
||||||
|
"mkl")
|
||||||
|
list(APPEND BLAS_SEARCH_LIBS
|
||||||
|
"mkl_ia32")
|
||||||
|
list(APPEND BLAS_SEARCH_LIBS
|
||||||
|
"mkl_em64t")
|
||||||
|
endif ()
|
||||||
|
endif (WIN32)
|
||||||
|
if (BLA_VENDOR STREQUAL "Intel10_64lp_seq" OR BLA_VENDOR STREQUAL "All")
|
||||||
|
list(APPEND BLAS_SEARCH_LIBS
|
||||||
|
"mkl_intel_lp64 mkl_sequential mkl_core")
|
||||||
|
endif ()
|
||||||
|
endif (BLA_F95)
|
||||||
|
|
||||||
|
foreach (IT ${BLAS_SEARCH_LIBS})
|
||||||
|
string(REPLACE " " ";" SEARCH_LIBS ${IT})
|
||||||
|
if (${_LIBRARIES})
|
||||||
|
else ()
|
||||||
check_fortran_libraries(
|
check_fortran_libraries(
|
||||||
BLAS_LIBRARIES
|
${_LIBRARIES}
|
||||||
BLAS
|
BLAS
|
||||||
sgemm
|
${BLAS_mkl_SEARCH_SYMBOL}
|
||||||
""
|
""
|
||||||
"mkl;guide"
|
"${SEARCH_LIBS}"
|
||||||
"${CMAKE_THREAD_LIBS_INIT};${LM}"
|
"${CMAKE_THREAD_LIBS_INIT};${LM}"
|
||||||
)
|
)
|
||||||
endif(NOT BLAS_LIBRARIES)
|
endif ()
|
||||||
#BLAS in intel mkl library? (static, 32bit)
|
endforeach ()
|
||||||
if(NOT BLAS_LIBRARIES)
|
|
||||||
check_fortran_libraries(
|
|
||||||
BLAS_LIBRARIES
|
|
||||||
BLAS
|
|
||||||
sgemm
|
|
||||||
""
|
|
||||||
"mkl_ia32;guide"
|
|
||||||
"${CMAKE_THREAD_LIBS_INIT};${LM}"
|
|
||||||
)
|
|
||||||
endif(NOT BLAS_LIBRARIES)
|
|
||||||
#BLAS in intel mkl library? (static, em64t 64bit)
|
|
||||||
if(NOT BLAS_LIBRARIES)
|
|
||||||
check_fortran_libraries(
|
|
||||||
BLAS_LIBRARIES
|
|
||||||
BLAS
|
|
||||||
sgemm
|
|
||||||
""
|
|
||||||
"mkl_em64t;guide"
|
|
||||||
"${CMAKE_THREAD_LIBS_INIT};${LM}"
|
|
||||||
)
|
|
||||||
endif(NOT BLAS_LIBRARIES)
|
|
||||||
endif (_LANGUAGES_ MATCHES C OR _LANGUAGES_ MATCHES CXX)
|
endif (_LANGUAGES_ MATCHES C OR _LANGUAGES_ MATCHES CXX)
|
||||||
endif (BLA_VENDOR MATCHES "Intel*" OR BLA_VENDOR STREQUAL "All")
|
endif (BLA_VENDOR MATCHES "Intel*" OR BLA_VENDOR STREQUAL "All")
|
||||||
|
|
||||||
|
|
|
@ -220,6 +220,9 @@ if (BLA_VENDOR STREQUAL "Generic" OR
|
||||||
endif ()
|
endif ()
|
||||||
#intel lapack
|
#intel lapack
|
||||||
if (BLA_VENDOR MATCHES "Intel*" OR BLA_VENDOR STREQUAL "All")
|
if (BLA_VENDOR MATCHES "Intel*" OR BLA_VENDOR STREQUAL "All")
|
||||||
|
if (NOT WIN32)
|
||||||
|
set(LM "-lm")
|
||||||
|
endif ()
|
||||||
if (_LANGUAGES_ MATCHES C OR _LANGUAGES_ MATCHES CXX)
|
if (_LANGUAGES_ MATCHES C OR _LANGUAGES_ MATCHES CXX)
|
||||||
if(LAPACK_FIND_QUIETLY OR NOT LAPACK_FIND_REQUIRED)
|
if(LAPACK_FIND_QUIETLY OR NOT LAPACK_FIND_REQUIRED)
|
||||||
find_PACKAGE(Threads)
|
find_PACKAGE(Threads)
|
||||||
|
@ -228,6 +231,7 @@ endif ()
|
||||||
endif(LAPACK_FIND_QUIETLY OR NOT LAPACK_FIND_REQUIRED)
|
endif(LAPACK_FIND_QUIETLY OR NOT LAPACK_FIND_REQUIRED)
|
||||||
if (BLA_F95)
|
if (BLA_F95)
|
||||||
if(NOT LAPACK95_LIBRARIES)
|
if(NOT LAPACK95_LIBRARIES)
|
||||||
|
# old
|
||||||
check_lapack_libraries(
|
check_lapack_libraries(
|
||||||
LAPACK95_LIBRARIES
|
LAPACK95_LIBRARIES
|
||||||
LAPACK
|
LAPACK
|
||||||
|
@ -235,11 +239,24 @@ endif ()
|
||||||
""
|
""
|
||||||
"mkl_lapack95"
|
"mkl_lapack95"
|
||||||
"${BLAS95_LIBRARIES}"
|
"${BLAS95_LIBRARIES}"
|
||||||
"${CMAKE_THREAD_LIBS_INIT}"
|
"${CMAKE_THREAD_LIBS_INIT};${LM}"
|
||||||
|
)
|
||||||
|
endif(NOT LAPACK95_LIBRARIES)
|
||||||
|
if(NOT LAPACK95_LIBRARIES)
|
||||||
|
# new >= 10.3
|
||||||
|
check_lapack_libraries(
|
||||||
|
LAPACK95_LIBRARIES
|
||||||
|
LAPACK
|
||||||
|
CHEEV
|
||||||
|
""
|
||||||
|
"mkl_intel_lp64"
|
||||||
|
"${BLAS95_LIBRARIES}"
|
||||||
|
"${CMAKE_THREAD_LIBS_INIT};${LM}"
|
||||||
)
|
)
|
||||||
endif(NOT LAPACK95_LIBRARIES)
|
endif(NOT LAPACK95_LIBRARIES)
|
||||||
else(BLA_F95)
|
else(BLA_F95)
|
||||||
if(NOT LAPACK_LIBRARIES)
|
if(NOT LAPACK_LIBRARIES)
|
||||||
|
# old
|
||||||
check_lapack_libraries(
|
check_lapack_libraries(
|
||||||
LAPACK_LIBRARIES
|
LAPACK_LIBRARIES
|
||||||
LAPACK
|
LAPACK
|
||||||
|
@ -247,7 +264,19 @@ endif ()
|
||||||
""
|
""
|
||||||
"mkl_lapack"
|
"mkl_lapack"
|
||||||
"${BLAS_LIBRARIES}"
|
"${BLAS_LIBRARIES}"
|
||||||
"${CMAKE_THREAD_LIBS_INIT}"
|
"${CMAKE_THREAD_LIBS_INIT};${LM}"
|
||||||
|
)
|
||||||
|
endif(NOT LAPACK_LIBRARIES)
|
||||||
|
if(NOT LAPACK_LIBRARIES)
|
||||||
|
# new >= 10.3
|
||||||
|
check_lapack_libraries(
|
||||||
|
LAPACK_LIBRARIES
|
||||||
|
LAPACK
|
||||||
|
cheev
|
||||||
|
""
|
||||||
|
"mkl_gf_lp64"
|
||||||
|
"${BLAS_LIBRARIES}"
|
||||||
|
"${CMAKE_THREAD_LIBS_INIT};${LM}"
|
||||||
)
|
)
|
||||||
endif(NOT LAPACK_LIBRARIES)
|
endif(NOT LAPACK_LIBRARIES)
|
||||||
endif(BLA_F95)
|
endif(BLA_F95)
|
||||||
|
|
Loading…
Reference in New Issue