summaryrefslogtreecommitdiffstats
path: root/tests/codegen/intrinsics/transmute-x64.rs
blob: 99d258c62040fed5c5cc72b84d84b759c9352d04 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
// compile-flags: -O -C no-prepopulate-passes
// only-x86_64 (it's using arch-specific types)
// min-llvm-version: 15.0 # this test assumes `ptr`s

#![crate_type = "lib"]

use std::arch::x86_64::{__m128, __m128i, __m256i};
use std::mem::transmute;

// CHECK-LABEL: @check_sse_float_to_int(
#[no_mangle]
pub unsafe fn check_sse_float_to_int(x: __m128) -> __m128i {
    // CHECK-NOT: alloca
    // CHECK: %1 = load <4 x float>, ptr %x, align 16
    // CHECK: store <4 x float> %1, ptr %0, align 16
    transmute(x)
}

// CHECK-LABEL: @check_sse_pair_to_avx(
#[no_mangle]
pub unsafe fn check_sse_pair_to_avx(x: (__m128i, __m128i)) -> __m256i {
    // CHECK-NOT: alloca
    // CHECK: %1 = load <4 x i64>, ptr %x, align 16
    // CHECK: store <4 x i64> %1, ptr %0, align 32
    transmute(x)
}

// CHECK-LABEL: @check_sse_pair_from_avx(
#[no_mangle]
pub unsafe fn check_sse_pair_from_avx(x: __m256i) -> (__m128i, __m128i) {
    // CHECK-NOT: alloca
    // CHECK: %1 = load <4 x i64>, ptr %x, align 32
    // CHECK: store <4 x i64> %1, ptr %0, align 16
    transmute(x)
}