static void sse4_1_test (void) { union { __m128i x[NUM / 2]; long long ll[NUM]; char c[NUM * 8]; } dst, src; int i, sign = 1; for (i = 0; i < NUM; i++) { src.c[(i % 2) + (i / 2) * 16] = i * i * sign; sign = -sign; } for (i = 0; i < NUM; i += 2) dst.x [i / 2] = _mm_cvtepi8_epi64 (src.x [i / 2]); for (i = 0; i < NUM; i++) if (src.c[(i % 2) + (i / 2) * 16] != dst.ll[i]) abort (); }
__m128i test_mm_cvtepi8_epi64(__m128i a) { // CHECK-LABEL: test_mm_cvtepi8_epi64 // CHECK: call <2 x i64> @llvm.x86.sse41.pmovsxbq(<16 x i8> {{.*}}) // CHECK-ASM: pmovsxbq %xmm{{.*}}, %xmm{{.*}} return _mm_cvtepi8_epi64(a); }
__m128i test_mm_cvtepi8_epi64(__m128i a) { // CHECK-LABEL: test_mm_cvtepi8_epi64 // CHECK: shufflevector <16 x i8> {{.*}}, <16 x i8> {{.*}}, <2 x i32> <i32 0, i32 1> // CHECK: sext <2 x i8> {{.*}} to <2 x i64> return _mm_cvtepi8_epi64(a); }