FindBLAS/LAPACK fixes
fixed: saving/changing/restoring CMAKE_FIND_LIBRARY_SUFFIXES variable. fixed: BLA_VENDORs "Apple" (Accelerate Framework) and "NAS" (vecLib Framework) fail as 'cblas_dgemm_' doesn't exist. fixed: improve "Generic" detection on Ubuntu (and I assume Debian) (work with libblas3gf and liblapack3gf packages).
This commit is contained in:
parent
cfad24a36b
commit
145de0a058
|
@ -42,6 +42,8 @@
|
||||||
include(CheckFunctionExists)
|
include(CheckFunctionExists)
|
||||||
include(CheckFortranFunctionExists)
|
include(CheckFortranFunctionExists)
|
||||||
|
|
||||||
|
set(_blas_ORIG_CMAKE_FIND_LIBRARY_SUFFIXES ${CMAKE_FIND_LIBRARY_SUFFIXES})
|
||||||
|
|
||||||
# Check the language being used
|
# Check the language being used
|
||||||
get_property( _LANGUAGES_ GLOBAL PROPERTY ENABLED_LANGUAGES )
|
get_property( _LANGUAGES_ GLOBAL PROPERTY ENABLED_LANGUAGES )
|
||||||
if( _LANGUAGES_ MATCHES Fortran )
|
if( _LANGUAGES_ MATCHES Fortran )
|
||||||
|
@ -89,13 +91,18 @@ foreach(_library ${_list})
|
||||||
if(_libraries_work)
|
if(_libraries_work)
|
||||||
if (BLA_STATIC)
|
if (BLA_STATIC)
|
||||||
if (WIN32)
|
if (WIN32)
|
||||||
set(CMAKE_FIND_LIBRARY_SUFFIXES ".lib;.dll")
|
set(CMAKE_FIND_LIBRARY_SUFFIXES .lib ${CMAKE_FIND_LIBRRAY_SUFFIXES})
|
||||||
endif ( WIN32 )
|
endif ( WIN32 )
|
||||||
if (APPLE)
|
if (APPLE)
|
||||||
set(CMAKE_FIND_LIBRARY_SUFFIXES ".lib;.dll")
|
set(CMAKE_FIND_LIBRARY_SUFFIXES .lib ${CMAKE_FIND_LIBRRAY_SUFFIXES})
|
||||||
else (APPLE)
|
else (APPLE)
|
||||||
set(CMAKE_FIND_LIBRARY_SUFFIXES ".a;.so")
|
set(CMAKE_FIND_LIBRARY_SUFFIXES .a ${CMAKE_FIND_LIBRRAY_SUFFIXES})
|
||||||
endif (APPLE)
|
endif (APPLE)
|
||||||
|
else (BLA_STATIC)
|
||||||
|
if (CMAKE_SYSTEM_NAME STREQUAL "Linux")
|
||||||
|
# for ubuntu's libblas3gf and liblapack3gf packages
|
||||||
|
set(CMAKE_FIND_LIBRARY_SUFFIXES ${CMAKE_FIND_LIBRRAY_SUFFIXES} .so.3gf)
|
||||||
|
endif ()
|
||||||
endif (BLA_STATIC)
|
endif (BLA_STATIC)
|
||||||
find_library(${_prefix}_${_library}_LIBRARY
|
find_library(${_prefix}_${_library}_LIBRARY
|
||||||
NAMES ${_library}
|
NAMES ${_library}
|
||||||
|
@ -408,7 +415,7 @@ if(NOT BLAS_LIBRARIES)
|
||||||
check_fortran_libraries(
|
check_fortran_libraries(
|
||||||
BLAS_LIBRARIES
|
BLAS_LIBRARIES
|
||||||
BLAS
|
BLAS
|
||||||
cblas_dgemm
|
dgemm
|
||||||
""
|
""
|
||||||
"Accelerate"
|
"Accelerate"
|
||||||
""
|
""
|
||||||
|
@ -421,7 +428,7 @@ if (BLA_VENDOR STREQUAL "NAS" OR BLA_VENDOR STREQUAL "All")
|
||||||
check_fortran_libraries(
|
check_fortran_libraries(
|
||||||
BLAS_LIBRARIES
|
BLAS_LIBRARIES
|
||||||
BLAS
|
BLAS
|
||||||
cblas_dgemm
|
dgemm
|
||||||
""
|
""
|
||||||
"vecLib"
|
"vecLib"
|
||||||
""
|
""
|
||||||
|
@ -613,3 +620,5 @@ else(BLA_F95)
|
||||||
endif(BLAS_FOUND)
|
endif(BLAS_FOUND)
|
||||||
endif(NOT BLAS_FIND_QUIETLY)
|
endif(NOT BLAS_FIND_QUIETLY)
|
||||||
endif(BLA_F95)
|
endif(BLA_F95)
|
||||||
|
|
||||||
|
set(CMAKE_FIND_LIBRARY_SUFFIXES ${_blas_ORIG_CMAKE_FIND_LIBRARY_SUFFIXES})
|
||||||
|
|
|
@ -36,6 +36,8 @@
|
||||||
# (To distribute this file outside of CMake, substitute the full
|
# (To distribute this file outside of CMake, substitute the full
|
||||||
# License text for the above reference.)
|
# License text for the above reference.)
|
||||||
|
|
||||||
|
set(_lapack_ORIG_CMAKE_FIND_LIBRARY_SUFFIXES ${CMAKE_FIND_LIBRARY_SUFFIXES})
|
||||||
|
|
||||||
get_property(_LANGUAGES_ GLOBAL PROPERTY ENABLED_LANGUAGES)
|
get_property(_LANGUAGES_ GLOBAL PROPERTY ENABLED_LANGUAGES)
|
||||||
if (NOT _LANGUAGES_ MATCHES Fortran)
|
if (NOT _LANGUAGES_ MATCHES Fortran)
|
||||||
include(CheckFunctionExists)
|
include(CheckFunctionExists)
|
||||||
|
@ -46,6 +48,8 @@ endif (NOT _LANGUAGES_ MATCHES Fortran)
|
||||||
set(LAPACK_FOUND FALSE)
|
set(LAPACK_FOUND FALSE)
|
||||||
set(LAPACK95_FOUND FALSE)
|
set(LAPACK95_FOUND FALSE)
|
||||||
|
|
||||||
|
# TODO: move this stuff to separate module
|
||||||
|
|
||||||
macro(Check_Lapack_Libraries LIBRARIES _prefix _name _flags _list _blas _threads)
|
macro(Check_Lapack_Libraries LIBRARIES _prefix _name _flags _list _blas _threads)
|
||||||
# This macro checks for the existence of the combination of fortran libraries
|
# This macro checks for the existence of the combination of fortran libraries
|
||||||
# given by _list. If the combination is found, this macro checks (using the
|
# given by _list. If the combination is found, this macro checks (using the
|
||||||
|
@ -61,38 +65,38 @@ macro(Check_Lapack_Libraries LIBRARIES _prefix _name _flags _list _blas _threads
|
||||||
set(_libraries_work TRUE)
|
set(_libraries_work TRUE)
|
||||||
set(${LIBRARIES})
|
set(${LIBRARIES})
|
||||||
set(_combined_name)
|
set(_combined_name)
|
||||||
|
if (NOT _libdir)
|
||||||
|
if (WIN32)
|
||||||
|
set(_libdir ENV LIB)
|
||||||
|
elseif (APPLE)
|
||||||
|
set(_libdir /usr/local/lib /usr/lib /usr/local/lib64 /usr/lib64 ENV DYLD_LIBRARY_PATH)
|
||||||
|
else ()
|
||||||
|
set(_libdir /usr/local/lib /usr/lib /usr/local/lib64 /usr/lib64 ENV LD_LIBRARY_PATH)
|
||||||
|
endif ()
|
||||||
|
endif ()
|
||||||
foreach(_library ${_list})
|
foreach(_library ${_list})
|
||||||
set(_combined_name ${_combined_name}_${_library})
|
set(_combined_name ${_combined_name}_${_library})
|
||||||
|
|
||||||
if(_libraries_work)
|
if(_libraries_work)
|
||||||
IF (WIN32)
|
if (BLA_STATIC)
|
||||||
if(BLA_STATIC)
|
if (WIN32)
|
||||||
set(CMAKE_FIND_LIBRARY_SUFFIXES ".lib;.dll")
|
set(CMAKE_FIND_LIBRARY_SUFFIXES .lib ${CMAKE_FIND_LIBRRAY_SUFFIXES})
|
||||||
endif(BLA_STATIC)
|
endif ( WIN32 )
|
||||||
|
if (APPLE)
|
||||||
|
set(CMAKE_FIND_LIBRARY_SUFFIXES .lib ${CMAKE_FIND_LIBRRAY_SUFFIXES})
|
||||||
|
else (APPLE)
|
||||||
|
set(CMAKE_FIND_LIBRARY_SUFFIXES .a ${CMAKE_FIND_LIBRRAY_SUFFIXES})
|
||||||
|
endif (APPLE)
|
||||||
|
else (BLA_STATIC)
|
||||||
|
if (CMAKE_SYSTEM_NAME STREQUAL "Linux")
|
||||||
|
# for ubuntu's libblas3gf and liblapack3gf packages
|
||||||
|
set(CMAKE_FIND_LIBRARY_SUFFIXES ${CMAKE_FIND_LIBRRAY_SUFFIXES} .so.3gf)
|
||||||
|
endif ()
|
||||||
|
endif (BLA_STATIC)
|
||||||
find_library(${_prefix}_${_library}_LIBRARY
|
find_library(${_prefix}_${_library}_LIBRARY
|
||||||
NAMES ${_library}
|
NAMES ${_library}
|
||||||
PATHS ENV LIB
|
PATHS ${_libdir}
|
||||||
)
|
)
|
||||||
ENDIF (WIN32)
|
|
||||||
|
|
||||||
if(APPLE)
|
|
||||||
if(BLA_STATIC)
|
|
||||||
set(CMAKE_FIND_LIBRARY_SUFFIXES ".a;.so;.dylib")
|
|
||||||
endif(BLA_STATIC)
|
|
||||||
find_library(${_prefix}_${_library}_LIBRARY
|
|
||||||
NAMES ${_library}
|
|
||||||
PATHS /usr/local/lib /usr/lib /usr/local/lib64 /usr/lib64 ENV DYLD_LIBRARY_PATH
|
|
||||||
)
|
|
||||||
else(APPLE)
|
|
||||||
if(BLA_STATIC)
|
|
||||||
set(CMAKE_FIND_LIBRARY_SUFFIXES ".a;.so")
|
|
||||||
endif(BLA_STATIC)
|
|
||||||
find_library(${_prefix}_${_library}_LIBRARY
|
|
||||||
NAMES ${_library}
|
|
||||||
PATHS /usr/local/lib /usr/lib /usr/local/lib64 /usr/lib64 ENV LD_LIBRARY_PATH
|
|
||||||
)
|
|
||||||
endif(APPLE)
|
|
||||||
|
|
||||||
mark_as_advanced(${_prefix}_${_library}_LIBRARY)
|
mark_as_advanced(${_prefix}_${_library}_LIBRARY)
|
||||||
set(${LIBRARIES} ${${LIBRARIES}} ${${_prefix}_${_library}_LIBRARY})
|
set(${LIBRARIES} ${${LIBRARIES}} ${${_prefix}_${_library}_LIBRARY})
|
||||||
set(_libraries_work ${${_prefix}_${_library}_LIBRARY})
|
set(_libraries_work ${${_prefix}_${_library}_LIBRARY})
|
||||||
|
@ -165,7 +169,7 @@ endif (BLA_VENDOR STREQUAL "Goto" OR BLA_VENDOR STREQUAL "All")
|
||||||
|
|
||||||
|
|
||||||
#acml lapack
|
#acml lapack
|
||||||
if (BLA_VENDOR STREQUAL "ACML.*" OR BLA_VENDOR STREQUAL "All")
|
if (BLA_VENDOR MATCHES "ACML.*" OR BLA_VENDOR STREQUAL "All")
|
||||||
if (BLAS_LIBRARIES MATCHES ".+acml.+")
|
if (BLAS_LIBRARIES MATCHES ".+acml.+")
|
||||||
set (LAPACK_LIBRARIES ${BLAS_LIBRARIES})
|
set (LAPACK_LIBRARIES ${BLAS_LIBRARIES})
|
||||||
endif ()
|
endif ()
|
||||||
|
@ -297,3 +301,5 @@ else(BLA_F95)
|
||||||
endif(LAPACK_FOUND)
|
endif(LAPACK_FOUND)
|
||||||
endif(NOT LAPACK_FIND_QUIETLY)
|
endif(NOT LAPACK_FIND_QUIETLY)
|
||||||
endif(BLA_F95)
|
endif(BLA_F95)
|
||||||
|
|
||||||
|
set(CMAKE_FIND_LIBRARY_SUFFIXES ${_lapack_ORIG_CMAKE_FIND_LIBRARY_SUFFIXES})
|
||||||
|
|
Loading…
Reference in New Issue