about summary refs log tree commit diff
path: root/tests/assembly-llvm/asm/inline-asm-avx.rs
blob: 630acbb971a86ac4bc0ab6e3550bfa28c76183c1 (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::arch::asm;
use std::simd::Simd;

#[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
}