diff options
| author | Guillaume Gomez <guillaume1.gomez@gmail.com> | 2025-07-21 14:34:12 +0200 |
|---|---|---|
| committer | Guillaume Gomez <guillaume1.gomez@gmail.com> | 2025-07-22 14:28:48 +0200 |
| commit | a27f3e3fd1e4d16160f8885b6b06665b5319f56c (patch) | |
| tree | b033935392cbadf6f85d2dbddf433a88e323aeeb /tests/codegen/simd/extract-insert-dyn.rs | |
| parent | ed93c1783b404d728d4809973a0550eb33cd293f (diff) | |
| download | rust-a27f3e3fd1e4d16160f8885b6b06665b5319f56c.tar.gz rust-a27f3e3fd1e4d16160f8885b6b06665b5319f56c.zip | |
Rename `tests/codegen` into `tests/codegen-llvm`
Diffstat (limited to 'tests/codegen/simd/extract-insert-dyn.rs')
| -rw-r--r-- | tests/codegen/simd/extract-insert-dyn.rs | 121 |
1 files changed, 0 insertions, 121 deletions
diff --git a/tests/codegen/simd/extract-insert-dyn.rs b/tests/codegen/simd/extract-insert-dyn.rs deleted file mode 100644 index 729f0145314..00000000000 --- a/tests/codegen/simd/extract-insert-dyn.rs +++ /dev/null @@ -1,121 +0,0 @@ -//@compile-flags: -C opt-level=3 -C no-prepopulate-passes - -#![feature( - core_intrinsics, - repr_simd, - arm_target_feature, - mips_target_feature, - s390x_target_feature -)] -#![no_std] -#![crate_type = "lib"] -#![allow(non_camel_case_types)] - -// Test that `core::intrinsics::simd::{simd_extract_dyn, simd_insert_dyn}` -// lower to an LLVM extractelement or insertelement operation. - -use core::intrinsics::simd::{simd_extract, simd_extract_dyn, simd_insert, simd_insert_dyn}; - -#[repr(simd)] -#[derive(Clone, Copy)] -pub struct u32x16([u32; 16]); - -#[repr(simd)] -#[derive(Clone, Copy)] -pub struct i8x16([i8; 16]); - -// CHECK-LABEL: dyn_simd_extract -// CHECK: extractelement <16 x i8> %x, i32 %idx -#[no_mangle] -#[cfg_attr(target_family = "wasm", target_feature(enable = "simd128"))] -#[cfg_attr(target_arch = "arm", target_feature(enable = "neon"))] -#[cfg_attr(target_arch = "x86", target_feature(enable = "sse"))] -#[cfg_attr(target_arch = "mips", target_feature(enable = "msa"))] -#[cfg_attr(target_arch = "s390x", target_feature(enable = "vector"))] -unsafe extern "C" fn dyn_simd_extract(x: i8x16, idx: u32) -> i8 { - simd_extract_dyn(x, idx) -} - -// CHECK-LABEL: literal_dyn_simd_extract -// CHECK: extractelement <16 x i8> %x, i32 7 -#[no_mangle] -#[cfg_attr(target_family = "wasm", target_feature(enable = "simd128"))] -#[cfg_attr(target_arch = "arm", target_feature(enable = "neon"))] -#[cfg_attr(target_arch = "x86", target_feature(enable = "sse"))] -#[cfg_attr(target_arch = "mips", target_feature(enable = "msa"))] -#[cfg_attr(target_arch = "s390x", target_feature(enable = "vector"))] -unsafe extern "C" fn literal_dyn_simd_extract(x: i8x16) -> i8 { - simd_extract_dyn(x, 7) -} - -// CHECK-LABEL: const_dyn_simd_extract -// CHECK: extractelement <16 x i8> %x, i32 7 -#[no_mangle] -#[cfg_attr(target_family = "wasm", target_feature(enable = "simd128"))] -#[cfg_attr(target_arch = "arm", target_feature(enable = "neon"))] -#[cfg_attr(target_arch = "x86", target_feature(enable = "sse"))] -#[cfg_attr(target_arch = "mips", target_feature(enable = "msa"))] -#[cfg_attr(target_arch = "s390x", target_feature(enable = "vector"))] -unsafe extern "C" fn const_dyn_simd_extract(x: i8x16) -> i8 { - simd_extract_dyn(x, const { 3 + 4 }) -} - -// CHECK-LABEL: const_simd_extract -// CHECK: extractelement <16 x i8> %x, i32 7 -#[no_mangle] -#[cfg_attr(target_family = "wasm", target_feature(enable = "simd128"))] -#[cfg_attr(target_arch = "arm", target_feature(enable = "neon"))] -#[cfg_attr(target_arch = "x86", target_feature(enable = "sse"))] -#[cfg_attr(target_arch = "mips", target_feature(enable = "msa"))] -#[cfg_attr(target_arch = "s390x", target_feature(enable = "vector"))] -unsafe extern "C" fn const_simd_extract(x: i8x16) -> i8 { - simd_extract(x, const { 3 + 4 }) -} - -// CHECK-LABEL: dyn_simd_insert -// CHECK: insertelement <16 x i8> %x, i8 %e, i32 %idx -#[no_mangle] -#[cfg_attr(target_family = "wasm", target_feature(enable = "simd128"))] -#[cfg_attr(target_arch = "arm", target_feature(enable = "neon"))] -#[cfg_attr(target_arch = "x86", target_feature(enable = "sse"))] -#[cfg_attr(target_arch = "mips", target_feature(enable = "msa"))] -#[cfg_attr(target_arch = "s390x", target_feature(enable = "vector"))] -unsafe extern "C" fn dyn_simd_insert(x: i8x16, e: i8, idx: u32) -> i8x16 { - simd_insert_dyn(x, idx, e) -} - -// CHECK-LABEL: literal_dyn_simd_insert -// CHECK: insertelement <16 x i8> %x, i8 %e, i32 7 -#[no_mangle] -#[cfg_attr(target_family = "wasm", target_feature(enable = "simd128"))] -#[cfg_attr(target_arch = "arm", target_feature(enable = "neon"))] -#[cfg_attr(target_arch = "x86", target_feature(enable = "sse"))] -#[cfg_attr(target_arch = "mips", target_feature(enable = "msa"))] -#[cfg_attr(target_arch = "s390x", target_feature(enable = "vector"))] -unsafe extern "C" fn literal_dyn_simd_insert(x: i8x16, e: i8) -> i8x16 { - simd_insert_dyn(x, 7, e) -} - -// CHECK-LABEL: const_dyn_simd_insert -// CHECK: insertelement <16 x i8> %x, i8 %e, i32 7 -#[no_mangle] -#[cfg_attr(target_family = "wasm", target_feature(enable = "simd128"))] -#[cfg_attr(target_arch = "arm", target_feature(enable = "neon"))] -#[cfg_attr(target_arch = "x86", target_feature(enable = "sse"))] -#[cfg_attr(target_arch = "mips", target_feature(enable = "msa"))] -#[cfg_attr(target_arch = "s390x", target_feature(enable = "vector"))] -unsafe extern "C" fn const_dyn_simd_insert(x: i8x16, e: i8) -> i8x16 { - simd_insert_dyn(x, const { 3 + 4 }, e) -} - -// CHECK-LABEL: const_simd_insert -// CHECK: insertelement <16 x i8> %x, i8 %e, i32 7 -#[no_mangle] -#[cfg_attr(target_family = "wasm", target_feature(enable = "simd128"))] -#[cfg_attr(target_arch = "arm", target_feature(enable = "neon"))] -#[cfg_attr(target_arch = "x86", target_feature(enable = "sse"))] -#[cfg_attr(target_arch = "mips", target_feature(enable = "msa"))] -#[cfg_attr(target_arch = "s390x", target_feature(enable = "vector"))] -unsafe extern "C" fn const_simd_insert(x: i8x16, e: i8) -> i8x16 { - simd_insert(x, const { 3 + 4 }, e) -} |
