#[repr(simd)]pub struct __m256i([i64; 4]);
Expand description
256-bit wide integer vector type, x86-specific
This type is the same as the __m256i
type defined by Intel,
representing a 256-bit SIMD register. Usage of this type typically
corresponds to the avx
and up target features for x86/x86_64.
Internally this type may be viewed as:
i8x32
- thirty twoi8
variables packed togetheri16x16
- sixteeni16
variables packed togetheri32x8
- eighti32
variables packed togetheri64x4
- fouri64
variables packed together
(as well as unsigned versions). Each intrinsic may interpret the internal bits differently, check the documentation of the intrinsic to see how it’s being used.
The in-memory representation of this type is the same as the one of an equivalent array (i.e. the in-memory order of elements is the same, and there is no padding); however, the alignment is different and equal to the size of the type. Note that the ABI for function calls may not be the same.
Note that this means that an instance of __m256i
typically just means
a “bag of bits” which is left up to interpretation at the point of use.
§Examples
#[cfg(target_arch = "x86")]
use std::arch::x86::*;
#[cfg(target_arch = "x86_64")]
use std::arch::x86_64::*;
let all_bytes_zero = _mm256_setzero_si256();
let all_bytes_one = _mm256_set1_epi8(1);
let eight_i32 = _mm256_set_epi32(1, 2, 3, 4, 5, 6, 7, 8);
Tuple Fields§
§0: [i64; 4]
Trait Implementations§
impl Copy for __m256i
Auto Trait Implementations§
impl Freeze for __m256i
impl RefUnwindSafe for __m256i
impl Send for __m256i
impl Sync for __m256i
impl Unpin for __m256i
impl UnwindSafe for __m256i
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
clone_to_uninit
)