use core_arch::simd_llvm::*;
use core_arch::x86::*;
use mem;
#[inline]
#[rustc_args_required_const(2)]
#[target_feature(enable = "avx")]
#[stable(feature = "simd_x86", since = "1.27.0")]
pub unsafe fn _mm256_insert_epi64(a: __m256i, i: i64, index: i32) -> __m256i {
mem::transmute(simd_insert(a.as_i64x4(), (index as u32) & 3, i))
}
#[cfg(test)]
mod tests {
use stdsimd_test::simd_test;
use core_arch::x86::*;
#[simd_test(enable = "avx")]
unsafe fn test_mm256_insert_epi64() {
let a = _mm256_setr_epi64x(1, 2, 3, 4);
let r = _mm256_insert_epi64(a, 0, 3);
let e = _mm256_setr_epi64x(1, 2, 3, 0);
assert_eq_m256i(r, e);
}
}