105 lines
3.8 KiB
CMake
105 lines
3.8 KiB
CMake
# - Finds SIMD support
|
|
#
|
|
# The following variables are set:
|
|
# SIMD_C_FLAGS - flags to add to the C compiler for this package.
|
|
# SIMD_FOUND - true if support for this package is found.
|
|
#
|
|
#=============================================================================
|
|
# Based on FindOpenMP.cmake, which is:
|
|
#
|
|
# Copyright 2009 Kitware, Inc.
|
|
# Copyright 2008-2009 André Rigland Brodtkorb <Andre.Brodtkorb@ifi.uio.no>
|
|
#
|
|
# Redistribution and use in source and binary forms, with or without
|
|
# modification, are permitted provided that the following conditions are
|
|
# met:
|
|
#
|
|
# * Redistributions of source code must retain the above copyright notice,
|
|
# this list of conditions and the following disclaimer.
|
|
#
|
|
# * Redistributions in binary form must reproduce the above copyright notice,
|
|
# this list of conditions and the following disclaimer in the documentation
|
|
# and/or other materials provided with the distribution.
|
|
#
|
|
# * The names of Kitware, Inc., the Insight Consortium, or the names of
|
|
# any consortium members, or of any contributors, may not be used to
|
|
# endorse or promote products derived from this software without
|
|
# specific prior written permission.
|
|
#
|
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDER AND CONTRIBUTORS ``AS IS''
|
|
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
# ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE FOR
|
|
# ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
|
# SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
|
|
# CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
|
|
# OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
include (CheckCSourceCompiles)
|
|
include (FindPackageHandleStandardArgs)
|
|
|
|
if (CMAKE_SYSTEM_PROCESSOR MATCHES "^arm")
|
|
set (SIMD_C_FLAG_CANDIDATES
|
|
# Gcc
|
|
"-Wno-cast-align -mfpu=neon-vfpv4 -mcpu=cortex-a7"
|
|
"-Wno-cast-align -mfpu=neon -mfloat-abi=hard"
|
|
"-Wno-cast-align -mfpu=neon -mfloat-abi=softfp"
|
|
"-Wno-cast-align -mfpu=neon -mfloat-abi=soft"
|
|
)
|
|
set (SIMD_C_TEST_SOURCE "
|
|
#include <arm_neon.h>
|
|
int main() {
|
|
float32x4_t a = vdupq_n_f32(0), b = a, c = vaddq_f32(a,b);
|
|
return 0;
|
|
}
|
|
")
|
|
else ()
|
|
if (WIN32) # Safety for when mixed lib/app compilers (but performance hit)
|
|
set (GCC_WIN32_SIMD_OPTS "-mincoming-stack-boundary=2")
|
|
endif ()
|
|
|
|
set (SIMD_C_FLAG_CANDIDATES
|
|
# x64
|
|
"-Wno-cast-align"
|
|
" "
|
|
# Microsoft Visual Studio x86
|
|
"/arch:SSE /fp:fast -D__SSE__"
|
|
# Gcc x86
|
|
"-Wno-cast-align -msse -mfpmath=sse ${GCC_WIN32_SIMD_OPTS}"
|
|
# Gcc x86 (old versions)
|
|
"-msse -mfpmath=sse"
|
|
)
|
|
set (SIMD_C_TEST_SOURCE "
|
|
#include <xmmintrin.h>
|
|
int main() {
|
|
__m128 a = _mm_setzero_ps(), b = a, c = _mm_add_ps(a,b);
|
|
return 0;
|
|
}
|
|
")
|
|
endif ()
|
|
|
|
if (DEFINED SIMD_C_FLAGS)
|
|
set (SIMD_C_FLAG_CANDIDATES)
|
|
endif ()
|
|
|
|
foreach (FLAG ${SIMD_C_FLAG_CANDIDATES})
|
|
set (SAFE_CMAKE_REQUIRED_FLAGS "${CMAKE_REQUIRED_FLAGS}")
|
|
set (CMAKE_REQUIRED_FLAGS "${FLAG}")
|
|
unset (SIMD_FLAG_DETECTED CACHE)
|
|
message (STATUS "Try SIMD C flag = [${FLAG}]")
|
|
check_c_source_compiles ("${SIMD_C_TEST_SOURCE}" SIMD_FLAG_DETECTED)
|
|
set (CMAKE_REQUIRED_FLAGS "${SAFE_CMAKE_REQUIRED_FLAGS}")
|
|
if (SIMD_FLAG_DETECTED)
|
|
set (SIMD_C_FLAGS_INTERNAL "${FLAG}")
|
|
break ()
|
|
endif ()
|
|
endforeach ()
|
|
|
|
set (SIMD_C_FLAGS "${SIMD_C_FLAGS_INTERNAL}"
|
|
CACHE STRING "C compiler flags for SIMD vectorization")
|
|
|
|
find_package_handle_standard_args (SIMD DEFAULT_MSG SIMD_C_FLAGS SIMD_C_FLAGS)
|
|
mark_as_advanced (SIMD_C_FLAGS)
|