Skip to content

Commit

Permalink
FindAVXFix
Browse files Browse the repository at this point in the history
  • Loading branch information
larshg committed Feb 9, 2021
1 parent 4e8efca commit 5658471
Show file tree
Hide file tree
Showing 2 changed files with 33 additions and 34 deletions.
2 changes: 1 addition & 1 deletion CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -133,7 +133,7 @@ if(CMAKE_COMPILER_IS_MSVC)
add_compile_options(/bigobj)

if("${CMAKE_CXX_FLAGS}" STREQUAL "${CMAKE_CXX_FLAGS_DEFAULT}")
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} /fp:precise /wd4800 /wd4521 /wd4251 /wd4275 /wd4305 /wd4355 ${SSE_FLAGS_STR}")
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} /fp:precise /wd4800 /wd4521 /wd4251 /wd4275 /wd4305 /wd4355 ${SSE_FLAGS_STR} ${AVX_FLAGS}")

# Add extra code generation/link optimizations
if(CMAKE_MSVC_CODE_LINK_OPTIMIZATION AND (NOT BUILD_CUDA) AND (NOT BUILD_GPU))
Expand Down
65 changes: 32 additions & 33 deletions cmake/pcl_find_avx.cmake
Original file line number Diff line number Diff line change
@@ -1,40 +1,39 @@
###############################################################################
# Check for the presence of AVX and figure out the flags to use for it.
macro(PCL_CHECK_FOR_AVX)
set(AVX_FLAGS)
set(AVX_DEFINITIONS)
set(AVX_FLAGS)
set(AVX_DEFINITIONS)

include(CheckCXXSourceRuns)
include(CheckCXXSourceRuns)

check_cxx_source_runs("
#include <immintrin.h>
int main()
{
__m256 a;
a = _mm256_set1_ps(0);
return 0;
}"
HAVE_AVX)

check_cxx_source_runs("
#include <immintrin.h>
int main()
{
__m256i a = {0};
a = _mm256_abs_epi16(a);
return 0;
}"
HAVE_AVX2)

if(MSVC)
if(HAVE_AVX)
set(AVX_DEFINITIONS "${AVX_DEFINITIONS} -D__AVX__")
add_definitions(/arch:AVX)
endif()
if(HAVE_AVX2)
set(AVX_DEFINITIONS "${AVX_DEFINITIONS} -D__AVX2__")
add_definitions(/arch:AVX2)
endif()
check_cxx_source_runs("
#include <immintrin.h>
int main()
{
__m256 a;
a = _mm256_set1_ps(0);
return 0;
}"
HAVE_AVX)

check_cxx_source_runs("
#include <immintrin.h>
int main()
{
__m256i a = {0};
a = _mm256_abs_epi16(a);
return 0;
}"
HAVE_AVX2)

if(MSVC)
if(HAVE_AVX)
string(APPEND AVX_DEFINITIONS " -D__AVX__")
set(AVX_FLAGS "/arch:AVX")
endif()

if(HAVE_AVX2)
string(APPEND AVX_DEFINITIONS " -D__AVX2__")
set(AVX_FLAGS "/arch:AVX2")
endif()
endif()
endmacro()

0 comments on commit 5658471

Please sign in to comment.