【发布时间】:2019-11-11 18:04:33
【问题描述】:
我在编译英特尔 SIMD 分散内在函数时遇到问题。我已将原始代码简化为:
double *tmpMemoryDoubles= (double *) malloc(1024);
__m256i tmpRegisterIndex = _mm256_set_epi64x(0, 1, 2, 3);
__m256d tmpRegisterDouble = _mm256_set_pd(0.0, 0.0, 0.0, 0.0);
_mm256_i64scatter_pd(tmpMemoryDoubles, tmpRegisterIndex, tmpRegisterDouble, 1);
_mm256_i64scatter_pd() 的文档将参数定义为:
void _mm256_i64scatter_pd (void* base_addr, __m256i vindex, __m256d a, const int scale)
这是错误信息:
/usr/lib/gcc/x86_64-linux-gnu/7/include/avx512vlintrin.h:11152:1: error: inlining failed in call to always_inline 'void _mm256_i64scatter_pd(void*, __m256i, __m256d, int)': target specific option mismatch
_mm256_i64scatter_pd (void *__addr, __m256i __index,
src_avx2/PRE_build_region_impulse_devel_avx2.cpp:631:33: note: called from here
_mm256_i64scatter_pd(tmpMemoryDoubles, tmpRegisterIndex, tmpRegisterDouble, 1);
谁能看出我做错了什么?
【问题讨论】:
-
这可能是因为我没有 AVX512 CPU 吗?
-
如果 AVX512 问题是原因,我想我会期待更多信息丰富的错误消息。