Skip to content

Commit

Permalink
added option to use only openblas, rather than both openblas and lapacke
Browse files Browse the repository at this point in the history
  • Loading branch information
leomccormack committed Jan 29, 2024
1 parent db9cd7a commit 8f3a426
Show file tree
Hide file tree
Showing 3 changed files with 48 additions and 0 deletions.
21 changes: 21 additions & 0 deletions framework/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -160,6 +160,27 @@ elseif( ${SAF_PERFORMANCE_LIB} MATCHES "SAF_USE_OPEN_BLAS_AND_LAPACKE")

message(STATUS "Using OpenBLAS. Linking against: ${OPENBLAS_LIBRARY}; ${LAPACKE_LIBRARY}")

elseif( ${SAF_PERFORMANCE_LIB} MATCHES "SAF_USE_OPEN_BLAS")
target_compile_definitions(${PROJECT_NAME} PUBLIC SAF_USE_OPEN_BLAS=1)

# find and link libraries
if (NOT DEFINED OPENBLAS_LIBRARY)
find_library(OPENBLAS_LIBRARY openblas HINTS /usr/lib/x86_64-linux-gnu /usr/lib/arm-linux-gnueabihf)
endif()
target_link_libraries(${PROJECT_NAME} PUBLIC ${OPENBLAS_LIBRARY})

# Add header search paths if they are defined
if(DEFINED OPENBLAS_HEADER_PATH)
target_include_directories(${PROJECT_NAME} PUBLIC ${OPENBLAS_HEADER_PATH})
endif()

# Disable this particular warning... We know, but it's OK.
if(UNIX)
target_compile_options(${PROJECT_NAME} PRIVATE -Wno-incompatible-pointer-types)
endif()

message(STATUS "Using OpenBLAS. Linking against: ${OPENBLAS_LIBRARY}")

elseif( ${SAF_PERFORMANCE_LIB} MATCHES "SAF_USE_ATLAS")
message(STATUS "Using ATLAS...")
message(SEND_ERROR "Not yet supported! Please contribute if you use this library.")
Expand Down
25 changes: 25 additions & 0 deletions framework/include/saf_externals.h
Original file line number Diff line number Diff line change
Expand Up @@ -78,6 +78,7 @@ extern "C" {
#if (defined(SAF_USE_INTEL_MKL_LP64) + \
defined(SAF_USE_INTEL_MKL_ILP64) + \
defined(SAF_USE_OPEN_BLAS_AND_LAPACKE) + \
defined(SAF_USE_OPEN_BLAS) + \
defined(SAF_USE_ATLAS) + \
defined(SAF_USE_GSL) + \
defined(SAF_USE_APPLE_ACCELERATE)) != 1
Expand Down Expand Up @@ -144,6 +145,28 @@ extern "C" {
# include "cblas.h"
# include "lapacke.h"

#elif defined(SAF_USE_OPEN_BLAS)
/*
* Using OpenBLAS and the included LAPACK interface
* (A decent option for both x86 and ARM based architectures)
*
* This option provides implementations of the CBLAS/LAPACK functions which have
* decent performance. However, unlike Intel MKL or Apple Accelerate, it does
* not offer an optimised DFT/FFT or any other linear algebra functions outside
* of these standards. Therefore, consider also using Intel's IPP library or
* FFTW for the DFT/FFT with: "SAF_USE_INTEL_IPP" or "SAF_USE_FFTW"
*
* Note that "SAF_USE_INTEL_IPP" also offers support for certain linear algebra
* operations not covered by the CBLAS/LAPACK standards, which SAF can leverage.
*
* Alternatively, SSE/AVX/AVX-512 fallback implementations for certain linear
* algebra operations may be enabled with: "SAF_ENABLE_SIMD"
*
* More information regarding these additional options can be found below.
*/
# include "cblas.h"
# include "lapack.h"

#elif defined(SAF_USE_ATLAS)
/*
* Using the Automatically Tuned Linear Algebra Software (ATLAS) library
Expand Down Expand Up @@ -311,6 +334,8 @@ extern "C" {
# define SAF_CURRENT_PERFORMANCE_LIBRARY_STRING "Intel MKL (ILP64)"
#elif defined(SAF_USE_OPEN_BLAS_AND_LAPACKE)
# define SAF_CURRENT_PERFORMANCE_LIBRARY_STRING "OpenBLAS with LAPACKE"
#elif defined(SAF_USE_OPEN_BLAS)
# define SAF_CURRENT_PERFORMANCE_LIBRARY_STRING "OpenBLAS"
#elif defined(SAF_USE_ATLAS)
# define SAF_CURRENT_PERFORMANCE_LIBRARY_STRING "ATLAS"
#elif defined(__APPLE__) && defined(SAF_USE_APPLE_ACCELERATE)
Expand Down
2 changes: 2 additions & 0 deletions framework/modules/saf_utilities/saf_utility_veclib.c
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,8 @@
# define SAF_VECLIB_USE_LAPACKE_INTERFACE /**< LAPACK interface */
#elif defined(SAF_USE_OPEN_BLAS_AND_LAPACKE)
# define SAF_VECLIB_USE_LAPACKE_INTERFACE /**< LAPACK interface */
#elif defined(SAF_USE_OPEN_BLAS)
# define SAF_VECLIB_USE_LAPACK_FORTRAN_INTERFACE /**< LAPACK interface */
#elif defined(SAF_USE_ATLAS)
# define SAF_VECLIB_USE_CLAPACK_INTERFACE /**< LAPACK interface */
#elif defined(__APPLE__) && defined(SAF_USE_APPLE_ACCELERATE)
Expand Down

0 comments on commit 8f3a426

Please sign in to comment.