调用always_inline'_mm_mullo_epi32'时内联失败:目标特定选项不匹配

时间:2017-03-30 21:29:11

标签: c cmake x86 sse simd

我正在尝试使用使用SIMD内在函数的cmake编译C程序。当我尝试编译它时,我得到两个错误

/ usr / lib中/ GCC / x86_64的-Linux的GNU / 5 /包含/的 smmintrin.h :326:1:错误:内联失败呼叫always_inline '_mm_mullo_epi32':目标特定选项不匹配  _mm_mullo_epi32(__ m128i __X,__ m128i __Y)

/ usr / lib中/ GCC / x86_64的-Linux的GNU / 5 /包含/的 tmmintrin.h :136:1:错误:内联失败呼叫always_inline '_mm_shuffle_epi8':目标特定选项不匹配  _mm_shuffle_epi8(__ m128i __X,__ m128i __Y)

此问题已通过设置

StackOverflow解决
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -msse4.1")

我尝试了相同和许多其他选项。但我的项目仍然无法编译。

set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -msse4.1")  
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -sse4_1")  
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -march=nehalem")  
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -msse4.1 -msse4.2")  
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -march=native")  
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -ssse3")  

2 个答案:

答案 0 :(得分:8)

由于您正在编译C代码而不是C ++,因此您需要:

set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -msse4.1")

您可以摆脱所有其他-march XXX-msseXXX设置。

如果您使用的是C和C ++混合,那么您还可以添加:

set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -msse4.1")

答案 1 :(得分:3)

找到gcc指令开关的通用方法

文件intrin.sh:

#!/bin/bash

get_instruction ()
{
    [ -z "$1" ] && exit
    func_name="$1 "

    header_file=`grep --include=\*intrin.h -Rl "$func_name" /usr/lib/gcc | head -n1`
    [ -z "$header_file" ] && exit
    >&2 echo "find in: $header_file"

    target_directive=`grep "#pragma GCC target(\|$func_name" $header_file | grep -B 1 "$func_name" | head -n1`
    echo $target_directive | grep -o '"[^,]*[,"]' | sed 's/"//g' | sed 's/,//g'
}

instruction=`get_instruction $1`
if [ -z "$instruction" ]; then
    echo "Error: function not found: $1"
else
    echo "add this option to gcc: -m$instruction"
fi

用法:

./intrin.sh _mm_shuffle_epi8      # output: -mssse3
./intrin.sh _mm_cvtepu8_epi32     # output: -msse4.1
./intrin.sh _mm_loadu_ps          # output: -msse
./intrin.sh _mm_clmulepi64_si128  # output: -mpclmul
./intrin.sh _mm256_loadu_si256    # output: -mavx
./intrin.sh _mm512_and_ps         # output: -mavx512dq