summaryrefslogtreecommitdiffstats
path: root/tests/assembly/asm/inline-asm-avx.rs
blob: c2875f3e0a44446b541799a37d74240a0667e41c (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
// assembly-output: emit-asm
// compile-flags: --crate-type=lib
// only-x86_64
// ignore-sgx

#![feature(portable_simd)]

use std::simd::Simd;
use std::arch::asm;

#[target_feature(enable = "avx")]
#[no_mangle]
// CHECK-LABEL: convert:
pub unsafe fn convert(a: *const f32) -> Simd<f32, 8> {
    // CHECK: vbroadcastss (%{{[er][a-ds0-9][xpi0-9]?}}), {{%ymm[0-7]}}
    let b: Simd<f32, 8>;
    unsafe {
        asm!(
            "vbroadcastss {b}, [{a}]",
            a = in(reg) a,
            b = out(ymm_reg) b,
        );
    }
    b
}