调用always_inline' __ m128i _mm_cvtepu8_epi32(__ m128i)':目标特定选项不匹配_mm_cvtepu8_epi32(__ m128i __X)

时间:2016-03-03 12:45:39

标签: c++ compilation sse

我正在尝试从github编译this project,这是在C ++中用SIMD内在函数(SSE4.1)实现的。 github中的项目是作为Visual Studio解决方案提供的,但我尝试使用cmake在Qtcreator中移植它。当我尝试编译它时,我收到以下错误:

/usr/lib/gcc/x86_64-unknown-linux-gnu/5.3.0/include/smmintrin.h:520:1: error: inlining failed in call to always_inline '__m128i _mm_cvtepu8_epi32(__m128i)': target specific option mismatch
 _mm_cvtepu8_epi32 (__m128i __X)

我确信它与SSE优化部分有关,但由于我不熟悉这个主题,我真的不知道它意味着什么以及我如何解决它以及我搜索到的网络中我无法和真的有用了。产生以下问题的代码如下:

static void cvt8u32f(const Mat& src, Mat& dest, const float amp)
{
    const int imsize = src.size().area()/8;
    const int nn = src.size().area()- imsize*8 ;
    uchar* s = (uchar*)src.ptr(0);
    float* d = dest.ptr<float>(0);
    const __m128 mamp = _mm_set_ps1(amp);
    const __m128i zero = _mm_setzero_si128();
    for(int i=imsize;i--;)
    {
        __m128i s1 = _mm_loadl_epi64((__m128i*)s);

        _mm_store_ps(d,_mm_mul_ps(mamp,_mm_cvtepi32_ps(_mm_cvtepu8_epi32(s1))));
        _mm_store_ps(d+4,_mm_mul_ps(mamp,_mm_cvtepi32_ps(_mm_cvtepu8_epi32(_mm_srli_si128(s1,4)))));
        s+=8;
        d+=8;
    }
    for(int i=0;i<nn;i++)
    {
        *d = (float)*s * amp;
        s++,d++;
    }

}

有人可以解释我的问题是什么,我错过了什么。提前谢谢。

1 个答案:

答案 0 :(得分:2)

在file.pro中添加: QMAKE_CXXFLAGS + = - msse3