2024-03-10 06:28:23 -05:00
|
|
|
//@build-fail
|
|
|
|
//! Make sure that monomorphization-time const errors from `static_assert` take priority over the
|
|
|
|
//! error from simd_extract. Basically this checks that if a const fails to evaluate in some
|
|
|
|
//! function, we don't bother codegen'ing the function.
|
|
|
|
#![feature(generic_arg_infer)]
|
|
|
|
#![feature(core_intrinsics)]
|
|
|
|
#![feature(repr_simd)]
|
2024-04-19 10:54:41 -05:00
|
|
|
|
2024-03-10 06:28:23 -05:00
|
|
|
use std::intrinsics::simd::*;
|
|
|
|
|
|
|
|
#[repr(simd)]
|
|
|
|
#[allow(non_camel_case_types)]
|
2024-08-22 03:28:20 -05:00
|
|
|
struct int8x4_t([u8; 4]);
|
2024-03-10 06:28:23 -05:00
|
|
|
|
|
|
|
fn get_elem<const LANE: u32>(a: int8x4_t) -> u8 {
|
|
|
|
const { assert!(LANE < 4); } // the error should be here...
|
|
|
|
//~^ ERROR failed
|
|
|
|
//~| assertion failed
|
|
|
|
unsafe { simd_extract(a, LANE) } // ...not here
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
2024-08-22 03:28:20 -05:00
|
|
|
get_elem::<4>(int8x4_t([0, 0, 0, 0]));
|
2024-03-10 06:28:23 -05:00
|
|
|
}
|