我有以下SIMD代码试图在vs2013中运行。它可以很好地编译但无法运行。谁知道为什么?
#include <cstdio>
#include <xmmintrin.h>
int main()
{
const size_t num = 7;
float a[num] = { 1, 2, 3, 4, 5, 6, 7 };
float b[num] = { 1, -1, -2, 1, -3, -2, 5 };
float c[num];
__m128 A, B, C;
A = _mm_load_ps(&a[0]); // <== crash here.
B = _mm_load_ps(&b[0]);
C = _mm_add_ps(A, B);
_mm_store_ps(&c[0], C);
return 0;
}
答案 0 :(得分:1)
使用这些内在函数加载或存储的地址需要16字节对齐(可被16整除)。看到 https://msdn.microsoft.com/en-us/library/zzd50xxt(v=vs.90).aspx
你应该像这样声明变量a,b和c:
__declspec(align(16)) float a[num] = { 1, 2, 3, 4, 5, 6, 7 };