From b86a083d10c2c89a5864abc63a5e7077e7512b48 Mon Sep 17 00:00:00 2001 From: Jubilee <46493976+workingjubilee@users.noreply.github.com> Date: Wed, 6 Oct 2021 02:34:54 -0700 Subject: [PATCH] Add example to _mm_extract_ps (#1228) --- library/stdarch/crates/core_arch/src/lib.rs | 1 - .../stdarch/crates/core_arch/src/x86/sse41.rs | 24 ++++++++++++++++++- 2 files changed, 23 insertions(+), 2 deletions(-) diff --git a/library/stdarch/crates/core_arch/src/lib.rs b/library/stdarch/crates/core_arch/src/lib.rs index a4c889365c82..33b0627d612d 100644 --- a/library/stdarch/crates/core_arch/src/lib.rs +++ b/library/stdarch/crates/core_arch/src/lib.rs @@ -5,7 +5,6 @@ #![deny(rust_2018_idioms)] #![feature( asm, - const_panic, custom_inner_attributes, link_llvm_intrinsics, platform_intrinsics, diff --git a/library/stdarch/crates/core_arch/src/x86/sse41.rs b/library/stdarch/crates/core_arch/src/x86/sse41.rs index 6e607d4832c8..64e869867ddc 100644 --- a/library/stdarch/crates/core_arch/src/x86/sse41.rs +++ b/library/stdarch/crates/core_arch/src/x86/sse41.rs @@ -141,8 +141,30 @@ pub unsafe fn _mm_blend_ps(a: __m128, b: __m128) -> __m128 { } /// Extracts a single-precision (32-bit) floating-point element from `a`, -/// selected with `IMM8` +/// selected with `IMM8`. The returned `i32` stores the float's bit-pattern, +/// and may be converted back to a floating point number via casting. /// +/// # Example +/// ```rust +/// #[cfg(target_arch = "x86")] +/// #use std::arch::x86::*; +/// #[cfg(target_arch = "x86_64")] +/// #use std::arch::x86_64::*; +/// #fn main() { +/// # if is_x86_feature_detected!("sse4.1") { +/// # #[target_feature(enable = "sse4.1")] +/// # unsafe fn worker() { +/// let mut float_store = vec![1.0, 1.0, 2.0, 3.0]; +/// unsafe { +/// let simd_floats = _mm_set_ps(2.5, 5.0, 7.5, 10.0); +/// let x: i32 = _mm_extract_ps::<2>(simd_floats); +/// float_store.push(f32::from_bits(x as u32)); +/// } +/// assert_eq!(float_store, vec![1.0, 1.0, 2.0, 3.0, 5.0]); +/// # } +/// # unsafe { worker() } +/// #} +/// ``` /// [Intel's documentation](https://software.intel.com/sites/landingpage/IntrinsicsGuide/#text=_mm_extract_ps) #[inline] #[target_feature(enable = "sse4.1")]