Sophie

Sophie

distrib > Mageia > 7 > armv7hl > media > core-release > by-pkgid > 0c2243f8a1696816431e7210e991fa52 > files > 4865

rust-doc-1.35.0-1.mga7.armv7hl.rpm

<!DOCTYPE html><html lang="en"><head><meta charset="utf-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><meta name="generator" content="rustdoc"><meta name="description" content="API documentation for the Rust `x86` mod in crate `core`."><meta name="keywords" content="rust, rustlang, rust-lang, x86"><title>core::arch::x86 - Rust</title><link rel="stylesheet" type="text/css" href="../../../normalize1.35.0.css"><link rel="stylesheet" type="text/css" href="../../../rustdoc1.35.0.css" id="mainThemeStyle"><link rel="stylesheet" type="text/css" href="../../../dark1.35.0.css"><link rel="stylesheet" type="text/css" href="../../../light1.35.0.css" id="themeStyle"><script src="../../../storage1.35.0.js"></script><noscript><link rel="stylesheet" href="../../../noscript1.35.0.css"></noscript><link rel="shortcut icon" href="../../../favicon1.35.0.ico"><style type="text/css">#crate-search{background-image:url("../../../down-arrow1.35.0.svg");}</style></head><body class="rustdoc mod"><!--[if lte IE 8]><div class="warning">This old browser is unsupported and will most likely display funky things.</div><![endif]--><nav class="sidebar"><div class="sidebar-menu">&#9776;</div><a href='../../../core/index.html'><img src='../../../rust-logo1.35.0.png' alt='logo' width='100'></a><p class='location'>Module x86</p><div class="sidebar-elems"><div class="block items"><ul><li><a href="#structs">Structs</a></li><li><a href="#constants">Constants</a></li><li><a href="#functions">Functions</a></li><li><a href="#types">Type Definitions</a></li></ul></div><p class='location'><a href='../../index.html'>core</a>::<wbr><a href='../index.html'>arch</a></p><script>window.sidebarCurrent = {name: 'x86', ty: 'mod', relpath: '../'};</script><script defer src="../sidebar-items.js"></script></div></nav><div class="theme-picker"><button id="theme-picker" aria-label="Pick another theme!"><img src="../../../brush1.35.0.svg" width="18" alt="Pick another theme!"></button><div id="theme-choices"></div></div><script src="../../../theme1.35.0.js"></script><nav class="sub"><form class="search-form js-only"><div class="search-container"><div><select id="crate-search"><option value="All crates">All crates</option></select><input class="search-input" name="search" autocomplete="off" spellcheck="false" placeholder="Click or press ‘S’ to search, ‘?’ for more options…" type="search"></div><a id="settings-menu" href="../../../settings.html"><img src="../../../wheel1.35.0.svg" width="18" alt="Change settings"></a></div></form></nav><section id="main" class="content"><h1 class='fqn'><span class='out-of-band'><span class='since' title='Stable since Rust version 1.27.0'>1.27.0</span><span id='render-detail'><a id="toggle-all-docs" href="javascript:void(0)" title="collapse all docs">[<span class='inner'>&#x2212;</span>]</a></span><a class='srclink' href='../../../src/core/up/stdsimd/crates/core_arch/src/mod.rs.html#24-27' title='goto source code'>[src]</a></span><span class='in-band'>Module <a href='../../index.html'>core</a>::<wbr><a href='../index.html'>arch</a>::<wbr><a class="mod" href=''>x86</a></span></h1><div class='stability'><div class='stab portability'>This is supported on <strong>x86</strong> only.</div></div><div class='docblock'><p>Platform-specific intrinsics for the <code>x86</code> platform.</p>
<p>See the <a href="../index.html">module documentation</a> for more details.</p>
</div><h2 id='structs' class='section-header'><a href="#structs">Structs</a></h2>
<table><tr class='module-item'><td><a class="struct" href="struct.CpuidResult.html" title='core::arch::x86::CpuidResult struct'>CpuidResult</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Result of the <code>cpuid</code> instruction.</p>
</td></tr><tr class='module-item'><td><a class="struct" href="struct.__m128i.html" title='core::arch::x86::__m128i struct'>__m128i</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>128-bit wide integer vector type, x86-specific</p>
</td></tr><tr class='module-item'><td><a class="struct" href="struct.__m128.html" title='core::arch::x86::__m128 struct'>__m128</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>128-bit wide set of four <code>f32</code> types, x86-specific</p>
</td></tr><tr class='module-item'><td><a class="struct" href="struct.__m128d.html" title='core::arch::x86::__m128d struct'>__m128d</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>128-bit wide set of two <code>f64</code> types, x86-specific</p>
</td></tr><tr class='module-item'><td><a class="struct" href="struct.__m256i.html" title='core::arch::x86::__m256i struct'>__m256i</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>256-bit wide integer vector type, x86-specific</p>
</td></tr><tr class='module-item'><td><a class="struct" href="struct.__m256.html" title='core::arch::x86::__m256 struct'>__m256</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>256-bit wide set of eight <code>f32</code> types, x86-specific</p>
</td></tr><tr class='module-item'><td><a class="struct" href="struct.__m256d.html" title='core::arch::x86::__m256d struct'>__m256d</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>256-bit wide set of four <code>f64</code> types, x86-specific</p>
</td></tr><tr class='unstable module-item'><td><a class="struct" href="struct.__m64.html" title='core::arch::x86::__m64 struct'>__m64</a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86</span><p>64-bit wide integer vector type, x86-specific</p>
</td></tr><tr class='unstable module-item'><td><a class="struct" href="struct.__m512i.html" title='core::arch::x86::__m512i struct'>__m512i</a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86</span><p>512-bit wide integer vector type, x86-specific</p>
</td></tr><tr class='unstable module-item'><td><a class="struct" href="struct.__m512.html" title='core::arch::x86::__m512 struct'>__m512</a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86</span><p>512-bit wide set of sixteen <code>f32</code> types, x86-specific</p>
</td></tr><tr class='unstable module-item'><td><a class="struct" href="struct.__m512d.html" title='core::arch::x86::__m512d struct'>__m512d</a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86</span><p>512-bit wide set of eight <code>f64</code> types, x86-specific</p>
</td></tr></table><h2 id='constants' class='section-header'><a href="#constants">Constants</a></h2>
<table><tr class='module-item'><td><a class="constant" href="constant._CMP_EQ_OQ.html" title='core::arch::x86::_CMP_EQ_OQ constant'>_CMP_EQ_OQ</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Equal (ordered, non-signaling)</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._CMP_EQ_OS.html" title='core::arch::x86::_CMP_EQ_OS constant'>_CMP_EQ_OS</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Equal (ordered, signaling)</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._CMP_EQ_UQ.html" title='core::arch::x86::_CMP_EQ_UQ constant'>_CMP_EQ_UQ</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Equal (unordered, non-signaling)</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._CMP_EQ_US.html" title='core::arch::x86::_CMP_EQ_US constant'>_CMP_EQ_US</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Equal (unordered, signaling)</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._CMP_FALSE_OQ.html" title='core::arch::x86::_CMP_FALSE_OQ constant'>_CMP_FALSE_OQ</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>False (ordered, non-signaling)</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._CMP_FALSE_OS.html" title='core::arch::x86::_CMP_FALSE_OS constant'>_CMP_FALSE_OS</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>False (ordered, signaling)</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._CMP_GE_OQ.html" title='core::arch::x86::_CMP_GE_OQ constant'>_CMP_GE_OQ</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Greater-than-or-equal (ordered, non-signaling)</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._CMP_GE_OS.html" title='core::arch::x86::_CMP_GE_OS constant'>_CMP_GE_OS</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Greater-than-or-equal (ordered, signaling)</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._CMP_GT_OQ.html" title='core::arch::x86::_CMP_GT_OQ constant'>_CMP_GT_OQ</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Greater-than (ordered, non-signaling)</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._CMP_GT_OS.html" title='core::arch::x86::_CMP_GT_OS constant'>_CMP_GT_OS</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Greater-than (ordered, signaling)</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._CMP_LE_OQ.html" title='core::arch::x86::_CMP_LE_OQ constant'>_CMP_LE_OQ</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Less-than-or-equal (ordered, non-signaling)</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._CMP_LE_OS.html" title='core::arch::x86::_CMP_LE_OS constant'>_CMP_LE_OS</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Less-than-or-equal (ordered, signaling)</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._CMP_LT_OQ.html" title='core::arch::x86::_CMP_LT_OQ constant'>_CMP_LT_OQ</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Less-than (ordered, non-signaling)</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._CMP_LT_OS.html" title='core::arch::x86::_CMP_LT_OS constant'>_CMP_LT_OS</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Less-than (ordered, signaling)</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._CMP_NEQ_OQ.html" title='core::arch::x86::_CMP_NEQ_OQ constant'>_CMP_NEQ_OQ</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Not-equal (ordered, non-signaling)</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._CMP_NEQ_OS.html" title='core::arch::x86::_CMP_NEQ_OS constant'>_CMP_NEQ_OS</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Not-equal (ordered, signaling)</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._CMP_NEQ_UQ.html" title='core::arch::x86::_CMP_NEQ_UQ constant'>_CMP_NEQ_UQ</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Not-equal (unordered, non-signaling)</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._CMP_NEQ_US.html" title='core::arch::x86::_CMP_NEQ_US constant'>_CMP_NEQ_US</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Not-equal (unordered, signaling)</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._CMP_NGE_UQ.html" title='core::arch::x86::_CMP_NGE_UQ constant'>_CMP_NGE_UQ</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Not-greater-than-or-equal (unordered, non-signaling)</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._CMP_NGE_US.html" title='core::arch::x86::_CMP_NGE_US constant'>_CMP_NGE_US</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Not-greater-than-or-equal (unordered, signaling)</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._CMP_NGT_UQ.html" title='core::arch::x86::_CMP_NGT_UQ constant'>_CMP_NGT_UQ</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Not-greater-than (unordered, non-signaling)</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._CMP_NGT_US.html" title='core::arch::x86::_CMP_NGT_US constant'>_CMP_NGT_US</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Not-greater-than (unordered, signaling)</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._CMP_NLE_UQ.html" title='core::arch::x86::_CMP_NLE_UQ constant'>_CMP_NLE_UQ</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Not-less-than-or-equal (unordered, non-signaling)</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._CMP_NLE_US.html" title='core::arch::x86::_CMP_NLE_US constant'>_CMP_NLE_US</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Not-less-than-or-equal (unordered, signaling)</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._CMP_NLT_UQ.html" title='core::arch::x86::_CMP_NLT_UQ constant'>_CMP_NLT_UQ</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Not-less-than (unordered, non-signaling)</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._CMP_NLT_US.html" title='core::arch::x86::_CMP_NLT_US constant'>_CMP_NLT_US</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Not-less-than (unordered, signaling)</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._CMP_ORD_Q.html" title='core::arch::x86::_CMP_ORD_Q constant'>_CMP_ORD_Q</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Ordered (non-signaling)</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._CMP_ORD_S.html" title='core::arch::x86::_CMP_ORD_S constant'>_CMP_ORD_S</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Ordered (signaling)</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._CMP_TRUE_UQ.html" title='core::arch::x86::_CMP_TRUE_UQ constant'>_CMP_TRUE_UQ</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>True (unordered, non-signaling)</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._CMP_TRUE_US.html" title='core::arch::x86::_CMP_TRUE_US constant'>_CMP_TRUE_US</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>True (unordered, signaling)</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._CMP_UNORD_Q.html" title='core::arch::x86::_CMP_UNORD_Q constant'>_CMP_UNORD_Q</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Unordered (non-signaling)</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._CMP_UNORD_S.html" title='core::arch::x86::_CMP_UNORD_S constant'>_CMP_UNORD_S</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Unordered (signaling)</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_EXCEPT_DENORM.html" title='core::arch::x86::_MM_EXCEPT_DENORM constant'>_MM_EXCEPT_DENORM</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>See <a href="fn._mm_setcsr.html"><code>_mm_setcsr</code></a></p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_EXCEPT_DIV_ZERO.html" title='core::arch::x86::_MM_EXCEPT_DIV_ZERO constant'>_MM_EXCEPT_DIV_ZERO</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>See <a href="fn._mm_setcsr.html"><code>_mm_setcsr</code></a></p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_EXCEPT_INEXACT.html" title='core::arch::x86::_MM_EXCEPT_INEXACT constant'>_MM_EXCEPT_INEXACT</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>See <a href="fn._mm_setcsr.html"><code>_mm_setcsr</code></a></p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_EXCEPT_INVALID.html" title='core::arch::x86::_MM_EXCEPT_INVALID constant'>_MM_EXCEPT_INVALID</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>See <a href="fn._mm_setcsr.html"><code>_mm_setcsr</code></a></p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_EXCEPT_MASK.html" title='core::arch::x86::_MM_EXCEPT_MASK constant'>_MM_EXCEPT_MASK</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>See <a href="fn._MM_GET_EXCEPTION_STATE.html"><code>_MM_GET_EXCEPTION_STATE</code></a></p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_EXCEPT_OVERFLOW.html" title='core::arch::x86::_MM_EXCEPT_OVERFLOW constant'>_MM_EXCEPT_OVERFLOW</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>See <a href="fn._mm_setcsr.html"><code>_mm_setcsr</code></a></p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_EXCEPT_UNDERFLOW.html" title='core::arch::x86::_MM_EXCEPT_UNDERFLOW constant'>_MM_EXCEPT_UNDERFLOW</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>See <a href="fn._mm_setcsr.html"><code>_mm_setcsr</code></a></p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_FLUSH_ZERO_MASK.html" title='core::arch::x86::_MM_FLUSH_ZERO_MASK constant'>_MM_FLUSH_ZERO_MASK</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>See <a href="fn._MM_GET_FLUSH_ZERO_MODE.html"><code>_MM_GET_FLUSH_ZERO_MODE</code></a></p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_FLUSH_ZERO_OFF.html" title='core::arch::x86::_MM_FLUSH_ZERO_OFF constant'>_MM_FLUSH_ZERO_OFF</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>See <a href="fn._mm_setcsr.html"><code>_mm_setcsr</code></a></p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_FLUSH_ZERO_ON.html" title='core::arch::x86::_MM_FLUSH_ZERO_ON constant'>_MM_FLUSH_ZERO_ON</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>See <a href="fn._mm_setcsr.html"><code>_mm_setcsr</code></a></p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_FROUND_CEIL.html" title='core::arch::x86::_MM_FROUND_CEIL constant'>_MM_FROUND_CEIL</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>round up and do not suppress exceptions</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_FROUND_CUR_DIRECTION.html" title='core::arch::x86::_MM_FROUND_CUR_DIRECTION constant'>_MM_FROUND_CUR_DIRECTION</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>use MXCSR.RC; see <code>vendor::_MM_SET_ROUNDING_MODE</code></p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_FROUND_FLOOR.html" title='core::arch::x86::_MM_FROUND_FLOOR constant'>_MM_FROUND_FLOOR</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>round down and do not suppress exceptions</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_FROUND_NEARBYINT.html" title='core::arch::x86::_MM_FROUND_NEARBYINT constant'>_MM_FROUND_NEARBYINT</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>use MXCSR.RC and suppress exceptions; see <code>vendor::_MM_SET_ROUNDING_MODE</code></p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_FROUND_NINT.html" title='core::arch::x86::_MM_FROUND_NINT constant'>_MM_FROUND_NINT</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>round to nearest and do not suppress exceptions</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_FROUND_NO_EXC.html" title='core::arch::x86::_MM_FROUND_NO_EXC constant'>_MM_FROUND_NO_EXC</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>suppress exceptions</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_FROUND_RAISE_EXC.html" title='core::arch::x86::_MM_FROUND_RAISE_EXC constant'>_MM_FROUND_RAISE_EXC</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>do not suppress exceptions</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_FROUND_RINT.html" title='core::arch::x86::_MM_FROUND_RINT constant'>_MM_FROUND_RINT</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>use MXCSR.RC and do not suppress exceptions; see
<code>vendor::_MM_SET_ROUNDING_MODE</code></p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_FROUND_TO_NEAREST_INT.html" title='core::arch::x86::_MM_FROUND_TO_NEAREST_INT constant'>_MM_FROUND_TO_NEAREST_INT</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>round to nearest</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_FROUND_TO_NEG_INF.html" title='core::arch::x86::_MM_FROUND_TO_NEG_INF constant'>_MM_FROUND_TO_NEG_INF</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>round down</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_FROUND_TO_POS_INF.html" title='core::arch::x86::_MM_FROUND_TO_POS_INF constant'>_MM_FROUND_TO_POS_INF</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>round up</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_FROUND_TO_ZERO.html" title='core::arch::x86::_MM_FROUND_TO_ZERO constant'>_MM_FROUND_TO_ZERO</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>truncate</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_FROUND_TRUNC.html" title='core::arch::x86::_MM_FROUND_TRUNC constant'>_MM_FROUND_TRUNC</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>truncate and do not suppress exceptions</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_HINT_NTA.html" title='core::arch::x86::_MM_HINT_NTA constant'>_MM_HINT_NTA</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>See <a href="fn._mm_prefetch.html"><code>_mm_prefetch</code></a>.</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_HINT_T0.html" title='core::arch::x86::_MM_HINT_T0 constant'>_MM_HINT_T0</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>See <a href="fn._mm_prefetch.html"><code>_mm_prefetch</code></a>.</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_HINT_T1.html" title='core::arch::x86::_MM_HINT_T1 constant'>_MM_HINT_T1</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>See <a href="fn._mm_prefetch.html"><code>_mm_prefetch</code></a>.</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_HINT_T2.html" title='core::arch::x86::_MM_HINT_T2 constant'>_MM_HINT_T2</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>See <a href="fn._mm_prefetch.html"><code>_mm_prefetch</code></a>.</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_MASK_DENORM.html" title='core::arch::x86::_MM_MASK_DENORM constant'>_MM_MASK_DENORM</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>See <a href="fn._mm_setcsr.html"><code>_mm_setcsr</code></a></p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_MASK_DIV_ZERO.html" title='core::arch::x86::_MM_MASK_DIV_ZERO constant'>_MM_MASK_DIV_ZERO</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>See <a href="fn._mm_setcsr.html"><code>_mm_setcsr</code></a></p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_MASK_INEXACT.html" title='core::arch::x86::_MM_MASK_INEXACT constant'>_MM_MASK_INEXACT</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>See <a href="fn._mm_setcsr.html"><code>_mm_setcsr</code></a></p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_MASK_INVALID.html" title='core::arch::x86::_MM_MASK_INVALID constant'>_MM_MASK_INVALID</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>See <a href="fn._mm_setcsr.html"><code>_mm_setcsr</code></a></p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_MASK_MASK.html" title='core::arch::x86::_MM_MASK_MASK constant'>_MM_MASK_MASK</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>See <a href="fn._MM_GET_EXCEPTION_MASK.html"><code>_MM_GET_EXCEPTION_MASK</code></a></p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_MASK_OVERFLOW.html" title='core::arch::x86::_MM_MASK_OVERFLOW constant'>_MM_MASK_OVERFLOW</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>See <a href="fn._mm_setcsr.html"><code>_mm_setcsr</code></a></p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_MASK_UNDERFLOW.html" title='core::arch::x86::_MM_MASK_UNDERFLOW constant'>_MM_MASK_UNDERFLOW</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>See <a href="fn._mm_setcsr.html"><code>_mm_setcsr</code></a></p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_ROUND_DOWN.html" title='core::arch::x86::_MM_ROUND_DOWN constant'>_MM_ROUND_DOWN</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>See <a href="fn._mm_setcsr.html"><code>_mm_setcsr</code></a></p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_ROUND_MASK.html" title='core::arch::x86::_MM_ROUND_MASK constant'>_MM_ROUND_MASK</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>See <a href="fn._MM_GET_ROUNDING_MODE.html"><code>_MM_GET_ROUNDING_MODE</code></a></p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_ROUND_NEAREST.html" title='core::arch::x86::_MM_ROUND_NEAREST constant'>_MM_ROUND_NEAREST</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>See <a href="fn._mm_setcsr.html"><code>_mm_setcsr</code></a></p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_ROUND_TOWARD_ZERO.html" title='core::arch::x86::_MM_ROUND_TOWARD_ZERO constant'>_MM_ROUND_TOWARD_ZERO</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>See <a href="fn._mm_setcsr.html"><code>_mm_setcsr</code></a></p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._MM_ROUND_UP.html" title='core::arch::x86::_MM_ROUND_UP constant'>_MM_ROUND_UP</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>See <a href="fn._mm_setcsr.html"><code>_mm_setcsr</code></a></p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._SIDD_BIT_MASK.html" title='core::arch::x86::_SIDD_BIT_MASK constant'>_SIDD_BIT_MASK</a></td><td class='docblock-short'><span class="stab portability">x86</span><p><strong>Mask only</strong>: return the bit mask</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._SIDD_CMP_EQUAL_ANY.html" title='core::arch::x86::_SIDD_CMP_EQUAL_ANY constant'>_SIDD_CMP_EQUAL_ANY</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>For each character in <code>a</code>, find if it is in <code>b</code> <em>(Default)</em></p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._SIDD_CMP_EQUAL_EACH.html" title='core::arch::x86::_SIDD_CMP_EQUAL_EACH constant'>_SIDD_CMP_EQUAL_EACH</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>The strings defined by <code>a</code> and <code>b</code> are equal</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._SIDD_CMP_EQUAL_ORDERED.html" title='core::arch::x86::_SIDD_CMP_EQUAL_ORDERED constant'>_SIDD_CMP_EQUAL_ORDERED</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Search for the defined substring in the target</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._SIDD_CMP_RANGES.html" title='core::arch::x86::_SIDD_CMP_RANGES constant'>_SIDD_CMP_RANGES</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>For each character in <code>a</code>, determine if
<code>b[0] &lt;= c &lt;= b[1] or b[1] &lt;= c &lt;= b[2]...</code></p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._SIDD_LEAST_SIGNIFICANT.html" title='core::arch::x86::_SIDD_LEAST_SIGNIFICANT constant'>_SIDD_LEAST_SIGNIFICANT</a></td><td class='docblock-short'><span class="stab portability">x86</span><p><strong>Index only</strong>: return the least significant bit <em>(Default)</em></p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._SIDD_MASKED_NEGATIVE_POLARITY.html" title='core::arch::x86::_SIDD_MASKED_NEGATIVE_POLARITY constant'>_SIDD_MASKED_NEGATIVE_POLARITY</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Negates results only before the end of the string</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._SIDD_MASKED_POSITIVE_POLARITY.html" title='core::arch::x86::_SIDD_MASKED_POSITIVE_POLARITY constant'>_SIDD_MASKED_POSITIVE_POLARITY</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Do not negate results before the end of the string</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._SIDD_MOST_SIGNIFICANT.html" title='core::arch::x86::_SIDD_MOST_SIGNIFICANT constant'>_SIDD_MOST_SIGNIFICANT</a></td><td class='docblock-short'><span class="stab portability">x86</span><p><strong>Index only</strong>: return the most significant bit</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._SIDD_NEGATIVE_POLARITY.html" title='core::arch::x86::_SIDD_NEGATIVE_POLARITY constant'>_SIDD_NEGATIVE_POLARITY</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Negates results</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._SIDD_POSITIVE_POLARITY.html" title='core::arch::x86::_SIDD_POSITIVE_POLARITY constant'>_SIDD_POSITIVE_POLARITY</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Do not negate results <em>(Default)</em></p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._SIDD_SBYTE_OPS.html" title='core::arch::x86::_SIDD_SBYTE_OPS constant'>_SIDD_SBYTE_OPS</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>String contains signed 8-bit characters</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._SIDD_SWORD_OPS.html" title='core::arch::x86::_SIDD_SWORD_OPS constant'>_SIDD_SWORD_OPS</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>String contains unsigned 16-bit characters</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._SIDD_UBYTE_OPS.html" title='core::arch::x86::_SIDD_UBYTE_OPS constant'>_SIDD_UBYTE_OPS</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>String contains unsigned 8-bit characters <em>(Default)</em></p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._SIDD_UNIT_MASK.html" title='core::arch::x86::_SIDD_UNIT_MASK constant'>_SIDD_UNIT_MASK</a></td><td class='docblock-short'><span class="stab portability">x86</span><p><strong>Mask only</strong>: return the byte mask</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._SIDD_UWORD_OPS.html" title='core::arch::x86::_SIDD_UWORD_OPS constant'>_SIDD_UWORD_OPS</a></td><td class='docblock-short'><span class="stab portability">x86</span><p>String contains unsigned 16-bit characters</p>
</td></tr><tr class='module-item'><td><a class="constant" href="constant._XCR_XFEATURE_ENABLED_MASK.html" title='core::arch::x86::_XCR_XFEATURE_ENABLED_MASK constant'>_XCR_XFEATURE_ENABLED_MASK</a></td><td class='docblock-short'><span class="stab portability">x86</span><p><code>XFEATURE_ENABLED_MASK</code> for <code>XCR</code></p>
</td></tr></table><h2 id='functions' class='section-header'><a href="#functions">Functions</a></h2>
<table><tr class='module-item'><td><a class="fn" href="fn._MM_GET_EXCEPTION_MASK.html" title='core::arch::x86::_MM_GET_EXCEPTION_MASK fn'>_MM_GET_EXCEPTION_MASK</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>See <a href="fn._mm_setcsr.html"><code>_mm_setcsr</code></a></p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._MM_GET_EXCEPTION_STATE.html" title='core::arch::x86::_MM_GET_EXCEPTION_STATE fn'>_MM_GET_EXCEPTION_STATE</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>See <a href="fn._mm_setcsr.html"><code>_mm_setcsr</code></a></p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._MM_GET_FLUSH_ZERO_MODE.html" title='core::arch::x86::_MM_GET_FLUSH_ZERO_MODE fn'>_MM_GET_FLUSH_ZERO_MODE</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>See <a href="fn._mm_setcsr.html"><code>_mm_setcsr</code></a></p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._MM_GET_ROUNDING_MODE.html" title='core::arch::x86::_MM_GET_ROUNDING_MODE fn'>_MM_GET_ROUNDING_MODE</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>See <a href="fn._mm_setcsr.html"><code>_mm_setcsr</code></a></p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._MM_SET_EXCEPTION_MASK.html" title='core::arch::x86::_MM_SET_EXCEPTION_MASK fn'>_MM_SET_EXCEPTION_MASK</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>See <a href="fn._mm_setcsr.html"><code>_mm_setcsr</code></a></p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._MM_SET_EXCEPTION_STATE.html" title='core::arch::x86::_MM_SET_EXCEPTION_STATE fn'>_MM_SET_EXCEPTION_STATE</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>See <a href="fn._mm_setcsr.html"><code>_mm_setcsr</code></a></p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._MM_SET_FLUSH_ZERO_MODE.html" title='core::arch::x86::_MM_SET_FLUSH_ZERO_MODE fn'>_MM_SET_FLUSH_ZERO_MODE</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>See <a href="fn._mm_setcsr.html"><code>_mm_setcsr</code></a></p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._MM_SET_ROUNDING_MODE.html" title='core::arch::x86::_MM_SET_ROUNDING_MODE fn'>_MM_SET_ROUNDING_MODE</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>See <a href="fn._mm_setcsr.html"><code>_mm_setcsr</code></a></p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._MM_TRANSPOSE4_PS.html" title='core::arch::x86::_MM_TRANSPOSE4_PS fn'>_MM_TRANSPOSE4_PS</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Transpose the 4x4 matrix formed by 4 rows of __m128 in place.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn.__cpuid.html" title='core::arch::x86::__cpuid fn'>__cpuid</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86</span><p>See <a href="fn.__cpuid_count.html"><code>__cpuid_count</code></a>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn.__cpuid_count.html" title='core::arch::x86::__cpuid_count fn'>__cpuid_count</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Returns the result of the <code>cpuid</code> instruction for a given <code>leaf</code> (<code>EAX</code>)
and
<code>sub_leaf</code> (<code>ECX</code>).</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn.__get_cpuid_max.html" title='core::arch::x86::__get_cpuid_max fn'>__get_cpuid_max</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Returns the highest-supported <code>leaf</code> (<code>EAX</code>) and sub-leaf (<code>ECX</code>) <code>cpuid</code>
values.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn.__rdtscp.html" title='core::arch::x86::__rdtscp fn'>__rdtscp</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Reads the current value of the processor’s time-stamp counter and
the <code>IA32_TSC_AUX MSR</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._addcarry_u32.html" title='core::arch::x86::_addcarry_u32 fn'>_addcarry_u32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Adds unsigned 32-bit integers <code>a</code> and <code>b</code> with unsigned 8-bit carry-in <code>c_in</code>
(carry flag), and store the unsigned 32-bit result in <code>out</code>, and the carry-out
is returned (carry or overflow flag).</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._addcarryx_u32.html" title='core::arch::x86::_addcarryx_u32 fn'>_addcarryx_u32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>adx</code></span><p>Adds unsigned 32-bit integers <code>a</code> and <code>b</code> with unsigned 8-bit carry-in <code>c_in</code>
(carry or overflow flag), and store the unsigned 32-bit result in <code>out</code>, and
the carry-out is returned (carry or overflow flag).</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._andn_u32.html" title='core::arch::x86::_andn_u32 fn'>_andn_u32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>bmi1</code></span><p>Bitwise logical <code>AND</code> of inverted <code>a</code> with <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._bextr2_u32.html" title='core::arch::x86::_bextr2_u32 fn'>_bextr2_u32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>bmi1</code></span><p>Extracts bits of <code>a</code> specified by <code>control</code> into
the least significant bits of the result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._bextr_u32.html" title='core::arch::x86::_bextr_u32 fn'>_bextr_u32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>bmi1</code></span><p>Extracts bits in range [<code>start</code>, <code>start</code> + <code>length</code>) from <code>a</code> into
the least significant bits of the result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._blcfill_u32.html" title='core::arch::x86::_blcfill_u32 fn'>_blcfill_u32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>tbm</code></span><p>Clears all bits below the least significant zero bit of <code>x</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._blcfill_u64.html" title='core::arch::x86::_blcfill_u64 fn'>_blcfill_u64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>tbm</code></span><p>Clears all bits below the least significant zero bit of <code>x</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._blci_u32.html" title='core::arch::x86::_blci_u32 fn'>_blci_u32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>tbm</code></span><p>Sets all bits of <code>x</code> to 1 except for the least significant zero bit.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._blci_u64.html" title='core::arch::x86::_blci_u64 fn'>_blci_u64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>tbm</code></span><p>Sets all bits of <code>x</code> to 1 except for the least significant zero bit.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._blcic_u32.html" title='core::arch::x86::_blcic_u32 fn'>_blcic_u32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>tbm</code></span><p>Sets the least significant zero bit of <code>x</code> and clears all other bits.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._blcic_u64.html" title='core::arch::x86::_blcic_u64 fn'>_blcic_u64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>tbm</code></span><p>Sets the least significant zero bit of <code>x</code> and clears all other bits.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._blcmsk_u32.html" title='core::arch::x86::_blcmsk_u32 fn'>_blcmsk_u32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>tbm</code></span><p>Sets the least significant zero bit of <code>x</code> and clears all bits above
that bit.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._blcmsk_u64.html" title='core::arch::x86::_blcmsk_u64 fn'>_blcmsk_u64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>tbm</code></span><p>Sets the least significant zero bit of <code>x</code> and clears all bits above
that bit.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._blcs_u32.html" title='core::arch::x86::_blcs_u32 fn'>_blcs_u32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>tbm</code></span><p>Sets the least significant zero bit of <code>x</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._blcs_u64.html" title='core::arch::x86::_blcs_u64 fn'>_blcs_u64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>tbm</code></span><p>Sets the least significant zero bit of <code>x</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._blsfill_u32.html" title='core::arch::x86::_blsfill_u32 fn'>_blsfill_u32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>tbm</code></span><p>Sets all bits of <code>x</code> below the least significant one.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._blsfill_u64.html" title='core::arch::x86::_blsfill_u64 fn'>_blsfill_u64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>tbm</code></span><p>Sets all bits of <code>x</code> below the least significant one.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._blsi_u32.html" title='core::arch::x86::_blsi_u32 fn'>_blsi_u32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>bmi1</code></span><p>Extracts lowest set isolated bit.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._blsic_u32.html" title='core::arch::x86::_blsic_u32 fn'>_blsic_u32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>tbm</code></span><p>Clears least significant bit and sets all other bits.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._blsic_u64.html" title='core::arch::x86::_blsic_u64 fn'>_blsic_u64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>tbm</code></span><p>Clears least significant bit and sets all other bits.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._blsmsk_u32.html" title='core::arch::x86::_blsmsk_u32 fn'>_blsmsk_u32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>bmi1</code></span><p>Gets mask up to lowest set bit.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._blsr_u32.html" title='core::arch::x86::_blsr_u32 fn'>_blsr_u32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>bmi1</code></span><p>Resets the lowest set bit of <code>x</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._bswap.html" title='core::arch::x86::_bswap fn'>_bswap</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Returns an integer with the reversed byte order of x</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._bzhi_u32.html" title='core::arch::x86::_bzhi_u32 fn'>_bzhi_u32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>bmi2</code></span><p>Zeroes higher bits of <code>a</code> &gt;= <code>index</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._fxrstor.html" title='core::arch::x86::_fxrstor fn'>_fxrstor</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>fxsr</code></span><p>Restores the <code>XMM</code>, <code>MMX</code>, <code>MXCSR</code>, and <code>x87</code> FPU registers from the
512-byte-long 16-byte-aligned memory region <code>mem_addr</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._fxsave.html" title='core::arch::x86::_fxsave fn'>_fxsave</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>fxsr</code></span><p>Saves the <code>x87</code> FPU, <code>MMX</code> technology, <code>XMM</code>, and <code>MXCSR</code> registers to the
512-byte-long 16-byte-aligned memory region <code>mem_addr</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._lzcnt_u32.html" title='core::arch::x86::_lzcnt_u32 fn'>_lzcnt_u32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>lzcnt</code></span><p>Counts the leading most significant zero bits.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_add_pd.html" title='core::arch::x86::_mm256_add_pd fn'>_mm256_add_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Adds packed double-precision (64-bit) floating-point elements
in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_add_ps.html" title='core::arch::x86::_mm256_add_ps fn'>_mm256_add_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Adds packed single-precision (32-bit) floating-point elements in <code>a</code> and
<code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_and_pd.html" title='core::arch::x86::_mm256_and_pd fn'>_mm256_and_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Computes the bitwise AND of a packed double-precision (64-bit)
floating-point elements in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_and_ps.html" title='core::arch::x86::_mm256_and_ps fn'>_mm256_and_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Computes the bitwise AND of packed single-precision (32-bit) floating-point
elements in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_or_pd.html" title='core::arch::x86::_mm256_or_pd fn'>_mm256_or_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Computes the bitwise OR packed double-precision (64-bit) floating-point
elements in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_or_ps.html" title='core::arch::x86::_mm256_or_ps fn'>_mm256_or_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Computes the bitwise OR packed single-precision (32-bit) floating-point
elements in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_shuffle_pd.html" title='core::arch::x86::_mm256_shuffle_pd fn'>_mm256_shuffle_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Shuffles double-precision (64-bit) floating-point elements within 128-bit
lanes using the control in <code>imm8</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_shuffle_ps.html" title='core::arch::x86::_mm256_shuffle_ps fn'>_mm256_shuffle_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Shuffles single-precision (32-bit) floating-point elements in <code>a</code> within
128-bit lanes using the control in <code>imm8</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_andnot_pd.html" title='core::arch::x86::_mm256_andnot_pd fn'>_mm256_andnot_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Computes the bitwise NOT of packed double-precision (64-bit) floating-point
elements in <code>a</code>, and then AND with <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_andnot_ps.html" title='core::arch::x86::_mm256_andnot_ps fn'>_mm256_andnot_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Computes the bitwise NOT of packed single-precision (32-bit) floating-point
elements in <code>a</code>
and then AND with <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_max_pd.html" title='core::arch::x86::_mm256_max_pd fn'>_mm256_max_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Compares packed double-precision (64-bit) floating-point elements
in <code>a</code> and <code>b</code>, and returns packed maximum values</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_max_ps.html" title='core::arch::x86::_mm256_max_ps fn'>_mm256_max_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Compares packed single-precision (32-bit) floating-point elements in <code>a</code>
and <code>b</code>, and returns packed maximum values</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_min_pd.html" title='core::arch::x86::_mm256_min_pd fn'>_mm256_min_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Compares packed double-precision (64-bit) floating-point elements
in <code>a</code> and <code>b</code>, and returns packed minimum values</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_min_ps.html" title='core::arch::x86::_mm256_min_ps fn'>_mm256_min_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Compares packed single-precision (32-bit) floating-point elements in <code>a</code>
and <code>b</code>, and returns packed minimum values</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_mul_pd.html" title='core::arch::x86::_mm256_mul_pd fn'>_mm256_mul_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Multiplies packed double-precision (64-bit) floating-point elements
in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_mul_ps.html" title='core::arch::x86::_mm256_mul_ps fn'>_mm256_mul_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Multiplies packed single-precision (32-bit) floating-point elements in <code>a</code> and
<code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_addsub_pd.html" title='core::arch::x86::_mm256_addsub_pd fn'>_mm256_addsub_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Alternatively adds and subtracts packed double-precision (64-bit)
floating-point elements in <code>a</code> to/from packed elements in <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_addsub_ps.html" title='core::arch::x86::_mm256_addsub_ps fn'>_mm256_addsub_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Alternatively adds and subtracts packed single-precision (32-bit)
floating-point elements in <code>a</code> to/from packed elements in <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_sub_pd.html" title='core::arch::x86::_mm256_sub_pd fn'>_mm256_sub_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Subtracts packed double-precision (64-bit) floating-point elements in <code>b</code>
from packed elements in <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_sub_ps.html" title='core::arch::x86::_mm256_sub_ps fn'>_mm256_sub_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Subtracts packed single-precision (32-bit) floating-point elements in <code>b</code>
from packed elements in <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_div_ps.html" title='core::arch::x86::_mm256_div_ps fn'>_mm256_div_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Computes the division of each of the 8 packed 32-bit floating-point elements
in <code>a</code> by the corresponding packed elements in <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_div_pd.html" title='core::arch::x86::_mm256_div_pd fn'>_mm256_div_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Computes the division of each of the 4 packed 64-bit floating-point elements
in <code>a</code> by the corresponding packed elements in <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_round_pd.html" title='core::arch::x86::_mm256_round_pd fn'>_mm256_round_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Rounds packed double-precision (64-bit) floating point elements in <code>a</code>
according to the flag <code>b</code>. The value of <code>b</code> may be as follows:</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_ceil_pd.html" title='core::arch::x86::_mm256_ceil_pd fn'>_mm256_ceil_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Rounds packed double-precision (64-bit) floating point elements in <code>a</code>
toward positive infinity.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_floor_pd.html" title='core::arch::x86::_mm256_floor_pd fn'>_mm256_floor_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Rounds packed double-precision (64-bit) floating point elements in <code>a</code>
toward negative infinity.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_round_ps.html" title='core::arch::x86::_mm256_round_ps fn'>_mm256_round_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Rounds packed single-precision (32-bit) floating point elements in <code>a</code>
according to the flag <code>b</code>. The value of <code>b</code> may be as follows:</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_ceil_ps.html" title='core::arch::x86::_mm256_ceil_ps fn'>_mm256_ceil_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Rounds packed single-precision (32-bit) floating point elements in <code>a</code>
toward positive infinity.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_floor_ps.html" title='core::arch::x86::_mm256_floor_ps fn'>_mm256_floor_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Rounds packed single-precision (32-bit) floating point elements in <code>a</code>
toward negative infinity.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_sqrt_ps.html" title='core::arch::x86::_mm256_sqrt_ps fn'>_mm256_sqrt_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Returns the square root of packed single-precision (32-bit) floating point
elements in <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_sqrt_pd.html" title='core::arch::x86::_mm256_sqrt_pd fn'>_mm256_sqrt_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Returns the square root of packed double-precision (64-bit) floating point
elements in <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_blend_pd.html" title='core::arch::x86::_mm256_blend_pd fn'>_mm256_blend_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Blends packed double-precision (64-bit) floating-point elements from
<code>a</code> and <code>b</code> using control mask <code>imm8</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_blend_ps.html" title='core::arch::x86::_mm256_blend_ps fn'>_mm256_blend_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Blends packed single-precision (32-bit) floating-point elements from
<code>a</code> and <code>b</code> using control mask <code>imm8</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_blendv_pd.html" title='core::arch::x86::_mm256_blendv_pd fn'>_mm256_blendv_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Blends packed double-precision (64-bit) floating-point elements from
<code>a</code> and <code>b</code> using <code>c</code> as a mask.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_blendv_ps.html" title='core::arch::x86::_mm256_blendv_ps fn'>_mm256_blendv_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Blends packed single-precision (32-bit) floating-point elements from
<code>a</code> and <code>b</code> using <code>c</code> as a mask.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_dp_ps.html" title='core::arch::x86::_mm256_dp_ps fn'>_mm256_dp_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Conditionally multiplies the packed single-precision (32-bit) floating-point
elements in <code>a</code> and <code>b</code> using the high 4 bits in <code>imm8</code>,
sum the four products, and conditionally return the sum
using the low 4 bits of <code>imm8</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_hadd_pd.html" title='core::arch::x86::_mm256_hadd_pd fn'>_mm256_hadd_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Horizontal addition of adjacent pairs in the two packed vectors
of 4 64-bit floating points <code>a</code> and <code>b</code>.
In the result, sums of elements from <code>a</code> are returned in even locations,
while sums of elements from <code>b</code> are returned in odd locations.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_hadd_ps.html" title='core::arch::x86::_mm256_hadd_ps fn'>_mm256_hadd_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Horizontal addition of adjacent pairs in the two packed vectors
of 8 32-bit floating points <code>a</code> and <code>b</code>.
In the result, sums of elements from <code>a</code> are returned in locations of
indices 0, 1, 4, 5; while sums of elements from <code>b</code> are locations
2, 3, 6, 7.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_hsub_pd.html" title='core::arch::x86::_mm256_hsub_pd fn'>_mm256_hsub_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Horizontal subtraction of adjacent pairs in the two packed vectors
of 4 64-bit floating points <code>a</code> and <code>b</code>.
In the result, sums of elements from <code>a</code> are returned in even locations,
while sums of elements from <code>b</code> are returned in odd locations.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_hsub_ps.html" title='core::arch::x86::_mm256_hsub_ps fn'>_mm256_hsub_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Horizontal subtraction of adjacent pairs in the two packed vectors
of 8 32-bit floating points <code>a</code> and <code>b</code>.
In the result, sums of elements from <code>a</code> are returned in locations of
indices 0, 1, 4, 5; while sums of elements from <code>b</code> are locations
2, 3, 6, 7.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_xor_pd.html" title='core::arch::x86::_mm256_xor_pd fn'>_mm256_xor_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Computes the bitwise XOR of packed double-precision (64-bit) floating-point
elements in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_xor_ps.html" title='core::arch::x86::_mm256_xor_ps fn'>_mm256_xor_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Computes the bitwise XOR of packed single-precision (32-bit) floating-point
elements in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_cmp_pd.html" title='core::arch::x86::_mm256_cmp_pd fn'>_mm256_cmp_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Compares packed double-precision (64-bit) floating-point
elements in <code>a</code> and <code>b</code> based on the comparison operand
specified by <code>imm8</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_cmp_ps.html" title='core::arch::x86::_mm256_cmp_ps fn'>_mm256_cmp_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Compares packed single-precision (32-bit) floating-point
elements in <code>a</code> and <code>b</code> based on the comparison operand
specified by <code>imm8</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_cvtpd_ps.html" title='core::arch::x86::_mm256_cvtpd_ps fn'>_mm256_cvtpd_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Converts packed double-precision (64-bit) floating-point elements in <code>a</code>
to packed single-precision (32-bit) floating-point elements.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_cvtps_pd.html" title='core::arch::x86::_mm256_cvtps_pd fn'>_mm256_cvtps_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Converts packed single-precision (32-bit) floating-point elements in <code>a</code>
to packed double-precision (64-bit) floating-point elements.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_zeroall.html" title='core::arch::x86::_mm256_zeroall fn'>_mm256_zeroall</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Zeroes the contents of all XMM or YMM registers.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_zeroupper.html" title='core::arch::x86::_mm256_zeroupper fn'>_mm256_zeroupper</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Zeroes the upper 128 bits of all YMM registers;
the lower 128-bits of the registers are unmodified.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_permutevar_ps.html" title='core::arch::x86::_mm256_permutevar_ps fn'>_mm256_permutevar_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Shuffles single-precision (32-bit) floating-point elements in <code>a</code>
within 128-bit lanes using the control in <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_permute_ps.html" title='core::arch::x86::_mm256_permute_ps fn'>_mm256_permute_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Shuffles single-precision (32-bit) floating-point elements in <code>a</code>
within 128-bit lanes using the control in <code>imm8</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_permutevar_pd.html" title='core::arch::x86::_mm256_permutevar_pd fn'>_mm256_permutevar_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Shuffles double-precision (64-bit) floating-point elements in <code>a</code>
within 256-bit lanes using the control in <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_permute_pd.html" title='core::arch::x86::_mm256_permute_pd fn'>_mm256_permute_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Shuffles double-precision (64-bit) floating-point elements in <code>a</code>
within 128-bit lanes using the control in <code>imm8</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_broadcast_ss.html" title='core::arch::x86::_mm256_broadcast_ss fn'>_mm256_broadcast_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Broadcasts a single-precision (32-bit) floating-point element from memory
to all elements of the returned vector.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_broadcast_sd.html" title='core::arch::x86::_mm256_broadcast_sd fn'>_mm256_broadcast_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Broadcasts a double-precision (64-bit) floating-point element from memory
to all elements of the returned vector.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_broadcast_ps.html" title='core::arch::x86::_mm256_broadcast_ps fn'>_mm256_broadcast_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Broadcasts 128 bits from memory (composed of 4 packed single-precision
(32-bit) floating-point elements) to all elements of the returned vector.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_broadcast_pd.html" title='core::arch::x86::_mm256_broadcast_pd fn'>_mm256_broadcast_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Broadcasts 128 bits from memory (composed of 2 packed double-precision
(64-bit) floating-point elements) to all elements of the returned vector.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_load_pd.html" title='core::arch::x86::_mm256_load_pd fn'>_mm256_load_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Loads 256-bits (composed of 4 packed double-precision (64-bit)
floating-point elements) from memory into result.
<code>mem_addr</code> must be aligned on a 32-byte boundary or a
general-protection exception may be generated.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_store_pd.html" title='core::arch::x86::_mm256_store_pd fn'>_mm256_store_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Stores 256-bits (composed of 4 packed double-precision (64-bit)
floating-point elements) from <code>a</code> into memory.
<code>mem_addr</code> must be aligned on a 32-byte boundary or a
general-protection exception may be generated.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_load_ps.html" title='core::arch::x86::_mm256_load_ps fn'>_mm256_load_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Loads 256-bits (composed of 8 packed single-precision (32-bit)
floating-point elements) from memory into result.
<code>mem_addr</code> must be aligned on a 32-byte boundary or a
general-protection exception may be generated.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_store_ps.html" title='core::arch::x86::_mm256_store_ps fn'>_mm256_store_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Stores 256-bits (composed of 8 packed single-precision (32-bit)
floating-point elements) from <code>a</code> into memory.
<code>mem_addr</code> must be aligned on a 32-byte boundary or a
general-protection exception may be generated.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_loadu_pd.html" title='core::arch::x86::_mm256_loadu_pd fn'>_mm256_loadu_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Loads 256-bits (composed of 4 packed double-precision (64-bit)
floating-point elements) from memory into result.
<code>mem_addr</code> does not need to be aligned on any particular boundary.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_storeu_pd.html" title='core::arch::x86::_mm256_storeu_pd fn'>_mm256_storeu_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Stores 256-bits (composed of 4 packed double-precision (64-bit)
floating-point elements) from <code>a</code> into memory.
<code>mem_addr</code> does not need to be aligned on any particular boundary.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_loadu_ps.html" title='core::arch::x86::_mm256_loadu_ps fn'>_mm256_loadu_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Loads 256-bits (composed of 8 packed single-precision (32-bit)
floating-point elements) from memory into result.
<code>mem_addr</code> does not need to be aligned on any particular boundary.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_storeu_ps.html" title='core::arch::x86::_mm256_storeu_ps fn'>_mm256_storeu_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Stores 256-bits (composed of 8 packed single-precision (32-bit)
floating-point elements) from <code>a</code> into memory.
<code>mem_addr</code> does not need to be aligned on any particular boundary.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_maskload_pd.html" title='core::arch::x86::_mm256_maskload_pd fn'>_mm256_maskload_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Loads packed double-precision (64-bit) floating-point elements from memory
into result using <code>mask</code> (elements are zeroed out when the high bit of the
corresponding element is not set).</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_maskstore_pd.html" title='core::arch::x86::_mm256_maskstore_pd fn'>_mm256_maskstore_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Stores packed double-precision (64-bit) floating-point elements from <code>a</code>
into memory using <code>mask</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_maskload_ps.html" title='core::arch::x86::_mm256_maskload_ps fn'>_mm256_maskload_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Loads packed single-precision (32-bit) floating-point elements from memory
into result using <code>mask</code> (elements are zeroed out when the high bit of the
corresponding element is not set).</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_maskstore_ps.html" title='core::arch::x86::_mm256_maskstore_ps fn'>_mm256_maskstore_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Stores packed single-precision (32-bit) floating-point elements from <code>a</code>
into memory using <code>mask</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_movehdup_ps.html" title='core::arch::x86::_mm256_movehdup_ps fn'>_mm256_movehdup_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Duplicate odd-indexed single-precision (32-bit) floating-point elements
from <code>a</code>, and returns the results.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_moveldup_ps.html" title='core::arch::x86::_mm256_moveldup_ps fn'>_mm256_moveldup_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Duplicate even-indexed single-precision (32-bit) floating-point elements
from <code>a</code>, and returns the results.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_movedup_pd.html" title='core::arch::x86::_mm256_movedup_pd fn'>_mm256_movedup_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Duplicate even-indexed double-precision (64-bit) floating-point elements
from &quot;a&quot;, and returns the results.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_stream_pd.html" title='core::arch::x86::_mm256_stream_pd fn'>_mm256_stream_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Moves double-precision values from a 256-bit vector of <code>[4 x double]</code>
to a 32-byte aligned memory location. To minimize caching, the data is
flagged as non-temporal (unlikely to be used again soon).</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_stream_ps.html" title='core::arch::x86::_mm256_stream_ps fn'>_mm256_stream_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Moves single-precision floating point values from a 256-bit vector
of <code>[8 x float]</code> to a 32-byte aligned memory location. To minimize
caching, the data is flagged as non-temporal (unlikely to be used again
soon).</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_rcp_ps.html" title='core::arch::x86::_mm256_rcp_ps fn'>_mm256_rcp_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Computes the approximate reciprocal of packed single-precision (32-bit)
floating-point elements in <code>a</code>, and returns the results. The maximum
relative error for this approximation is less than 1.5*2^-12.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_rsqrt_ps.html" title='core::arch::x86::_mm256_rsqrt_ps fn'>_mm256_rsqrt_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Computes the approximate reciprocal square root of packed single-precision
(32-bit) floating-point elements in <code>a</code>, and returns the results.
The maximum relative error for this approximation is less than 1.5*2^-12.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_unpackhi_pd.html" title='core::arch::x86::_mm256_unpackhi_pd fn'>_mm256_unpackhi_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Unpacks and interleave double-precision (64-bit) floating-point elements
from the high half of each 128-bit lane in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_unpackhi_ps.html" title='core::arch::x86::_mm256_unpackhi_ps fn'>_mm256_unpackhi_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Unpacks and interleave single-precision (32-bit) floating-point elements
from the high half of each 128-bit lane in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_unpacklo_pd.html" title='core::arch::x86::_mm256_unpacklo_pd fn'>_mm256_unpacklo_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Unpacks and interleave double-precision (64-bit) floating-point elements
from the low half of each 128-bit lane in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_unpacklo_ps.html" title='core::arch::x86::_mm256_unpacklo_ps fn'>_mm256_unpacklo_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Unpacks and interleave single-precision (32-bit) floating-point elements
from the low half of each 128-bit lane in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_testz_pd.html" title='core::arch::x86::_mm256_testz_pd fn'>_mm256_testz_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Computes the bitwise AND of 256 bits (representing double-precision (64-bit)
floating-point elements) in <code>a</code> and <code>b</code>, producing an intermediate 256-bit
value, and set <code>ZF</code> to 1 if the sign bit of each 64-bit element in the
intermediate value is zero, otherwise set <code>ZF</code> to 0. Compute the bitwise
NOT of <code>a</code> and then AND with <code>b</code>, producing an intermediate value, and set
<code>CF</code> to 1 if the sign bit of each 64-bit element in the intermediate value
is zero, otherwise set <code>CF</code> to 0. Return the <code>ZF</code> value.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_testc_pd.html" title='core::arch::x86::_mm256_testc_pd fn'>_mm256_testc_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Computes the bitwise AND of 256 bits (representing double-precision (64-bit)
floating-point elements) in <code>a</code> and <code>b</code>, producing an intermediate 256-bit
value, and set <code>ZF</code> to 1 if the sign bit of each 64-bit element in the
intermediate value is zero, otherwise set <code>ZF</code> to 0. Compute the bitwise
NOT of <code>a</code> and then AND with <code>b</code>, producing an intermediate value, and set
<code>CF</code> to 1 if the sign bit of each 64-bit element in the intermediate value
is zero, otherwise set <code>CF</code> to 0. Return the <code>CF</code> value.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_testnzc_pd.html" title='core::arch::x86::_mm256_testnzc_pd fn'>_mm256_testnzc_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Computes the bitwise AND of 256 bits (representing double-precision (64-bit)
floating-point elements) in <code>a</code> and <code>b</code>, producing an intermediate 256-bit
value, and set <code>ZF</code> to 1 if the sign bit of each 64-bit element in the
intermediate value is zero, otherwise set <code>ZF</code> to 0. Compute the bitwise
NOT of <code>a</code> and then AND with <code>b</code>, producing an intermediate value, and set
<code>CF</code> to 1 if the sign bit of each 64-bit element in the intermediate value
is zero, otherwise set <code>CF</code> to 0. Return 1 if both the <code>ZF</code> and <code>CF</code> values
are zero, otherwise return 0.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_testz_ps.html" title='core::arch::x86::_mm256_testz_ps fn'>_mm256_testz_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Computes the bitwise AND of 256 bits (representing single-precision (32-bit)
floating-point elements) in <code>a</code> and <code>b</code>, producing an intermediate 256-bit
value, and set <code>ZF</code> to 1 if the sign bit of each 32-bit element in the
intermediate value is zero, otherwise set <code>ZF</code> to 0. Compute the bitwise
NOT of <code>a</code> and then AND with <code>b</code>, producing an intermediate value, and set
<code>CF</code> to 1 if the sign bit of each 32-bit element in the intermediate value
is zero, otherwise set <code>CF</code> to 0. Return the <code>ZF</code> value.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_testc_ps.html" title='core::arch::x86::_mm256_testc_ps fn'>_mm256_testc_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Computes the bitwise AND of 256 bits (representing single-precision (32-bit)
floating-point elements) in <code>a</code> and <code>b</code>, producing an intermediate 256-bit
value, and set <code>ZF</code> to 1 if the sign bit of each 32-bit element in the
intermediate value is zero, otherwise set <code>ZF</code> to 0. Compute the bitwise
NOT of <code>a</code> and then AND with <code>b</code>, producing an intermediate value, and set
<code>CF</code> to 1 if the sign bit of each 32-bit element in the intermediate value
is zero, otherwise set <code>CF</code> to 0. Return the <code>CF</code> value.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_testnzc_ps.html" title='core::arch::x86::_mm256_testnzc_ps fn'>_mm256_testnzc_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Computes the bitwise AND of 256 bits (representing single-precision (32-bit)
floating-point elements) in <code>a</code> and <code>b</code>, producing an intermediate 256-bit
value, and set <code>ZF</code> to 1 if the sign bit of each 32-bit element in the
intermediate value is zero, otherwise set <code>ZF</code> to 0. Compute the bitwise
NOT of <code>a</code> and then AND with <code>b</code>, producing an intermediate value, and set
<code>CF</code> to 1 if the sign bit of each 32-bit element in the intermediate value
is zero, otherwise set <code>CF</code> to 0. Return 1 if both the <code>ZF</code> and <code>CF</code> values
are zero, otherwise return 0.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_movemask_pd.html" title='core::arch::x86::_mm256_movemask_pd fn'>_mm256_movemask_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Sets each bit of the returned mask based on the most significant bit of the
corresponding packed double-precision (64-bit) floating-point element in
<code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_movemask_ps.html" title='core::arch::x86::_mm256_movemask_ps fn'>_mm256_movemask_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Sets each bit of the returned mask based on the most significant bit of the
corresponding packed single-precision (32-bit) floating-point element in
<code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_setzero_pd.html" title='core::arch::x86::_mm256_setzero_pd fn'>_mm256_setzero_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Returns vector of type __m256d with all elements set to zero.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_setzero_ps.html" title='core::arch::x86::_mm256_setzero_ps fn'>_mm256_setzero_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Returns vector of type __m256 with all elements set to zero.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_set_pd.html" title='core::arch::x86::_mm256_set_pd fn'>_mm256_set_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Sets packed double-precision (64-bit) floating-point elements in returned
vector with the supplied values.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_set_ps.html" title='core::arch::x86::_mm256_set_ps fn'>_mm256_set_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Sets packed single-precision (32-bit) floating-point elements in returned
vector with the supplied values.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_setr_pd.html" title='core::arch::x86::_mm256_setr_pd fn'>_mm256_setr_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Sets packed double-precision (64-bit) floating-point elements in returned
vector with the supplied values in reverse order.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_setr_ps.html" title='core::arch::x86::_mm256_setr_ps fn'>_mm256_setr_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Sets packed single-precision (32-bit) floating-point elements in returned
vector with the supplied values in reverse order.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_castpd_ps.html" title='core::arch::x86::_mm256_castpd_ps fn'>_mm256_castpd_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Cast vector of type __m256d to type __m256.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_castps_pd.html" title='core::arch::x86::_mm256_castps_pd fn'>_mm256_castps_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Cast vector of type __m256 to type __m256d.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_undefined_ps.html" title='core::arch::x86::_mm256_undefined_ps fn'>_mm256_undefined_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Returns vector of type <code>__m256</code> with undefined elements.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_undefined_pd.html" title='core::arch::x86::_mm256_undefined_pd fn'>_mm256_undefined_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Returns vector of type <code>__m256d</code> with undefined elements.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_broadcastsd_pd.html" title='core::arch::x86::_mm256_broadcastsd_pd fn'>_mm256_broadcastsd_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Broadcasts the low double-precision (64-bit) floating-point element
from <code>a</code> to all elements of the 256-bit returned value.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_broadcastss_ps.html" title='core::arch::x86::_mm256_broadcastss_ps fn'>_mm256_broadcastss_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Broadcasts the low single-precision (32-bit) floating-point element
from <code>a</code> to all elements of the 256-bit returned value.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_fmadd_pd.html" title='core::arch::x86::_mm256_fmadd_pd fn'>_mm256_fmadd_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>fma</code></span><p>Multiplies packed double-precision (64-bit) floating-point elements in <code>a</code>
and <code>b</code>, and add the intermediate result to packed elements in <code>c</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_fmadd_ps.html" title='core::arch::x86::_mm256_fmadd_ps fn'>_mm256_fmadd_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>fma</code></span><p>Multiplies packed single-precision (32-bit) floating-point elements in <code>a</code>
and <code>b</code>, and add the intermediate result to packed elements in <code>c</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_fmaddsub_pd.html" title='core::arch::x86::_mm256_fmaddsub_pd fn'>_mm256_fmaddsub_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>fma</code></span><p>Multiplies packed double-precision (64-bit) floating-point elements in <code>a</code>
and <code>b</code>, and alternatively add and subtract packed elements in <code>c</code> to/from
the intermediate result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_fmaddsub_ps.html" title='core::arch::x86::_mm256_fmaddsub_ps fn'>_mm256_fmaddsub_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>fma</code></span><p>Multiplies packed single-precision (32-bit) floating-point elements in <code>a</code>
and <code>b</code>, and alternatively add and subtract packed elements in <code>c</code> to/from
the intermediate result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_fmsub_pd.html" title='core::arch::x86::_mm256_fmsub_pd fn'>_mm256_fmsub_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>fma</code></span><p>Multiplies packed double-precision (64-bit) floating-point elements in <code>a</code>
and <code>b</code>, and subtract packed elements in <code>c</code> from the intermediate result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_fmsub_ps.html" title='core::arch::x86::_mm256_fmsub_ps fn'>_mm256_fmsub_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>fma</code></span><p>Multiplies packed single-precision (32-bit) floating-point elements in <code>a</code>
and <code>b</code>, and subtract packed elements in <code>c</code> from the intermediate result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_fmsubadd_pd.html" title='core::arch::x86::_mm256_fmsubadd_pd fn'>_mm256_fmsubadd_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>fma</code></span><p>Multiplies packed double-precision (64-bit) floating-point elements in <code>a</code>
and <code>b</code>, and alternatively subtract and add packed elements in <code>c</code> from/to
the intermediate result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_fmsubadd_ps.html" title='core::arch::x86::_mm256_fmsubadd_ps fn'>_mm256_fmsubadd_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>fma</code></span><p>Multiplies packed single-precision (32-bit) floating-point elements in <code>a</code>
and <code>b</code>, and alternatively subtract and add packed elements in <code>c</code> from/to
the intermediate result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_fnmadd_pd.html" title='core::arch::x86::_mm256_fnmadd_pd fn'>_mm256_fnmadd_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>fma</code></span><p>Multiplies packed double-precision (64-bit) floating-point elements in <code>a</code>
and <code>b</code>, and add the negated intermediate result to packed elements in <code>c</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_fnmadd_ps.html" title='core::arch::x86::_mm256_fnmadd_ps fn'>_mm256_fnmadd_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>fma</code></span><p>Multiplies packed single-precision (32-bit) floating-point elements in <code>a</code>
and <code>b</code>, and add the negated intermediate result to packed elements in <code>c</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_fnmsub_pd.html" title='core::arch::x86::_mm256_fnmsub_pd fn'>_mm256_fnmsub_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>fma</code></span><p>Multiplies packed double-precision (64-bit) floating-point elements in <code>a</code>
and <code>b</code>, and subtract packed elements in <code>c</code> from the negated intermediate
result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_fnmsub_ps.html" title='core::arch::x86::_mm256_fnmsub_ps fn'>_mm256_fnmsub_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>fma</code></span><p>Multiplies packed single-precision (32-bit) floating-point elements in <code>a</code>
and <code>b</code>, and subtract packed elements in <code>c</code> from the negated intermediate
result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_abs_epi8.html" title='core::arch::x86::_mm256_abs_epi8 fn'>_mm256_abs_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Computes the absolute values of packed 8-bit integers in <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_abs_epi16.html" title='core::arch::x86::_mm256_abs_epi16 fn'>_mm256_abs_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Computes the absolute values of packed 16-bit integers in <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_abs_epi32.html" title='core::arch::x86::_mm256_abs_epi32 fn'>_mm256_abs_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Computes the absolute values of packed 32-bit integers in <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_add_epi8.html" title='core::arch::x86::_mm256_add_epi8 fn'>_mm256_add_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Adds packed 8-bit integers in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_add_epi16.html" title='core::arch::x86::_mm256_add_epi16 fn'>_mm256_add_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Adds packed 16-bit integers in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_add_epi32.html" title='core::arch::x86::_mm256_add_epi32 fn'>_mm256_add_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Adds packed 32-bit integers in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_add_epi64.html" title='core::arch::x86::_mm256_add_epi64 fn'>_mm256_add_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Adds packed 64-bit integers in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_adds_epi8.html" title='core::arch::x86::_mm256_adds_epi8 fn'>_mm256_adds_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Adds packed 8-bit integers in <code>a</code> and <code>b</code> using saturation.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_adds_epi16.html" title='core::arch::x86::_mm256_adds_epi16 fn'>_mm256_adds_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Adds packed 16-bit integers in <code>a</code> and <code>b</code> using saturation.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_adds_epu8.html" title='core::arch::x86::_mm256_adds_epu8 fn'>_mm256_adds_epu8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Adds packed unsigned 8-bit integers in <code>a</code> and <code>b</code> using saturation.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_adds_epu16.html" title='core::arch::x86::_mm256_adds_epu16 fn'>_mm256_adds_epu16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Adds packed unsigned 16-bit integers in <code>a</code> and <code>b</code> using saturation.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_alignr_epi8.html" title='core::arch::x86::_mm256_alignr_epi8 fn'>_mm256_alignr_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Concatenates pairs of 16-byte blocks in <code>a</code> and <code>b</code> into a 32-byte temporary
result, shifts the result right by <code>n</code> bytes, and returns the low 16 bytes.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_and_si256.html" title='core::arch::x86::_mm256_and_si256 fn'>_mm256_and_si256</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Computes the bitwise AND of 256 bits (representing integer data)
in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_andnot_si256.html" title='core::arch::x86::_mm256_andnot_si256 fn'>_mm256_andnot_si256</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Computes the bitwise NOT of 256 bits (representing integer data)
in <code>a</code> and then AND with <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_avg_epu8.html" title='core::arch::x86::_mm256_avg_epu8 fn'>_mm256_avg_epu8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Averages packed unsigned 8-bit integers in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_avg_epu16.html" title='core::arch::x86::_mm256_avg_epu16 fn'>_mm256_avg_epu16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Averages packed unsigned 16-bit integers in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_blend_epi16.html" title='core::arch::x86::_mm256_blend_epi16 fn'>_mm256_blend_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Blends packed 16-bit integers from <code>a</code> and <code>b</code> using control mask <code>imm8</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_blend_epi32.html" title='core::arch::x86::_mm256_blend_epi32 fn'>_mm256_blend_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Blends packed 32-bit integers from <code>a</code> and <code>b</code> using control mask <code>imm8</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_blendv_epi8.html" title='core::arch::x86::_mm256_blendv_epi8 fn'>_mm256_blendv_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Blends packed 8-bit integers from <code>a</code> and <code>b</code> using <code>mask</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_broadcastb_epi8.html" title='core::arch::x86::_mm256_broadcastb_epi8 fn'>_mm256_broadcastb_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Broadcasts the low packed 8-bit integer from <code>a</code> to all elements of
the 256-bit returned value.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_broadcastd_epi32.html" title='core::arch::x86::_mm256_broadcastd_epi32 fn'>_mm256_broadcastd_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Broadcasts the low packed 32-bit integer from <code>a</code> to all elements of
the 256-bit returned value.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_broadcastq_epi64.html" title='core::arch::x86::_mm256_broadcastq_epi64 fn'>_mm256_broadcastq_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Broadcasts the low packed 64-bit integer from <code>a</code> to all elements of
the 256-bit returned value.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_broadcastsi128_si256.html" title='core::arch::x86::_mm256_broadcastsi128_si256 fn'>_mm256_broadcastsi128_si256</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Broadcasts 128 bits of integer data from a to all 128-bit lanes in
the 256-bit returned value.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_broadcastw_epi16.html" title='core::arch::x86::_mm256_broadcastw_epi16 fn'>_mm256_broadcastw_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Broadcasts the low packed 16-bit integer from a to all elements of
the 256-bit returned value</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_bslli_epi128.html" title='core::arch::x86::_mm256_bslli_epi128 fn'>_mm256_bslli_epi128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Shifts 128-bit lanes in <code>a</code> left by <code>imm8</code> bytes while shifting in zeros.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_bsrli_epi128.html" title='core::arch::x86::_mm256_bsrli_epi128 fn'>_mm256_bsrli_epi128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Shifts 128-bit lanes in <code>a</code> right by <code>imm8</code> bytes while shifting in zeros.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_castpd128_pd256.html" title='core::arch::x86::_mm256_castpd128_pd256 fn'>_mm256_castpd128_pd256</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Casts vector of type __m128d to type __m256d;
the upper 128 bits of the result are undefined.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_castpd256_pd128.html" title='core::arch::x86::_mm256_castpd256_pd128 fn'>_mm256_castpd256_pd128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Casts vector of type __m256d to type __m128d.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_castpd_si256.html" title='core::arch::x86::_mm256_castpd_si256 fn'>_mm256_castpd_si256</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Casts vector of type __m256d to type __m256i.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_castps128_ps256.html" title='core::arch::x86::_mm256_castps128_ps256 fn'>_mm256_castps128_ps256</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Casts vector of type __m128 to type __m256;
the upper 128 bits of the result are undefined.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_castps256_ps128.html" title='core::arch::x86::_mm256_castps256_ps128 fn'>_mm256_castps256_ps128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Casts vector of type __m256 to type __m128.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_castps_si256.html" title='core::arch::x86::_mm256_castps_si256 fn'>_mm256_castps_si256</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Casts vector of type __m256 to type __m256i.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_castsi256_ps.html" title='core::arch::x86::_mm256_castsi256_ps fn'>_mm256_castsi256_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Casts vector of type __m256i to type __m256.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_castsi256_pd.html" title='core::arch::x86::_mm256_castsi256_pd fn'>_mm256_castsi256_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Casts vector of type __m256i to type __m256d.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_castsi128_si256.html" title='core::arch::x86::_mm256_castsi128_si256 fn'>_mm256_castsi128_si256</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Casts vector of type __m128i to type __m256i;
the upper 128 bits of the result are undefined.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_castsi256_si128.html" title='core::arch::x86::_mm256_castsi256_si128 fn'>_mm256_castsi256_si128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Casts vector of type __m256i to type __m128i.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_cmpeq_epi8.html" title='core::arch::x86::_mm256_cmpeq_epi8 fn'>_mm256_cmpeq_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Compares packed 8-bit integers in <code>a</code> and <code>b</code> for equality.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_cmpeq_epi16.html" title='core::arch::x86::_mm256_cmpeq_epi16 fn'>_mm256_cmpeq_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Compares packed 16-bit integers in <code>a</code> and <code>b</code> for equality.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_cmpeq_epi32.html" title='core::arch::x86::_mm256_cmpeq_epi32 fn'>_mm256_cmpeq_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Compares packed 32-bit integers in <code>a</code> and <code>b</code> for equality.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_cmpeq_epi64.html" title='core::arch::x86::_mm256_cmpeq_epi64 fn'>_mm256_cmpeq_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Compares packed 64-bit integers in <code>a</code> and <code>b</code> for equality.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_cmpgt_epi8.html" title='core::arch::x86::_mm256_cmpgt_epi8 fn'>_mm256_cmpgt_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Compares packed 8-bit integers in <code>a</code> and <code>b</code> for greater-than.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_cmpgt_epi16.html" title='core::arch::x86::_mm256_cmpgt_epi16 fn'>_mm256_cmpgt_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Compares packed 16-bit integers in <code>a</code> and <code>b</code> for greater-than.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_cmpgt_epi32.html" title='core::arch::x86::_mm256_cmpgt_epi32 fn'>_mm256_cmpgt_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Compares packed 32-bit integers in <code>a</code> and <code>b</code> for greater-than.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_cmpgt_epi64.html" title='core::arch::x86::_mm256_cmpgt_epi64 fn'>_mm256_cmpgt_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Compares packed 64-bit integers in <code>a</code> and <code>b</code> for greater-than.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_cvtepi32_pd.html" title='core::arch::x86::_mm256_cvtepi32_pd fn'>_mm256_cvtepi32_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Converts packed 32-bit integers in <code>a</code> to packed double-precision (64-bit)
floating-point elements.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_cvtepi32_ps.html" title='core::arch::x86::_mm256_cvtepi32_ps fn'>_mm256_cvtepi32_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Converts packed 32-bit integers in <code>a</code> to packed single-precision (32-bit)
floating-point elements.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_cvtepi16_epi32.html" title='core::arch::x86::_mm256_cvtepi16_epi32 fn'>_mm256_cvtepi16_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Sign-extend 16-bit integers to 32-bit integers.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_cvtepi16_epi64.html" title='core::arch::x86::_mm256_cvtepi16_epi64 fn'>_mm256_cvtepi16_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Sign-extend 16-bit integers to 64-bit integers.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_cvtepi32_epi64.html" title='core::arch::x86::_mm256_cvtepi32_epi64 fn'>_mm256_cvtepi32_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Sign-extend 32-bit integers to 64-bit integers.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_cvtepi8_epi16.html" title='core::arch::x86::_mm256_cvtepi8_epi16 fn'>_mm256_cvtepi8_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Sign-extend 8-bit integers to 16-bit integers.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_cvtepi8_epi32.html" title='core::arch::x86::_mm256_cvtepi8_epi32 fn'>_mm256_cvtepi8_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Sign-extend 8-bit integers to 32-bit integers.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_cvtepi8_epi64.html" title='core::arch::x86::_mm256_cvtepi8_epi64 fn'>_mm256_cvtepi8_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Sign-extend 8-bit integers to 64-bit integers.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_cvtepu16_epi32.html" title='core::arch::x86::_mm256_cvtepu16_epi32 fn'>_mm256_cvtepu16_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Zeroes extend packed unsigned 16-bit integers in <code>a</code> to packed 32-bit
integers, and stores the results in <code>dst</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_cvtepu16_epi64.html" title='core::arch::x86::_mm256_cvtepu16_epi64 fn'>_mm256_cvtepu16_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Zero-extend the lower four unsigned 16-bit integers in <code>a</code> to 64-bit
integers. The upper four elements of <code>a</code> are unused.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_cvtepu32_epi64.html" title='core::arch::x86::_mm256_cvtepu32_epi64 fn'>_mm256_cvtepu32_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Zero-extend unsigned 32-bit integers in <code>a</code> to 64-bit integers.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_cvtepu8_epi16.html" title='core::arch::x86::_mm256_cvtepu8_epi16 fn'>_mm256_cvtepu8_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Zero-extend unsigned 8-bit integers in <code>a</code> to 16-bit integers.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_cvtepu8_epi32.html" title='core::arch::x86::_mm256_cvtepu8_epi32 fn'>_mm256_cvtepu8_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Zero-extend the lower eight unsigned 8-bit integers in <code>a</code> to 32-bit
integers. The upper eight elements of <code>a</code> are unused.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_cvtepu8_epi64.html" title='core::arch::x86::_mm256_cvtepu8_epi64 fn'>_mm256_cvtepu8_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Zero-extend the lower four unsigned 8-bit integers in <code>a</code> to 64-bit
integers. The upper twelve elements of <code>a</code> are unused.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_cvtpd_epi32.html" title='core::arch::x86::_mm256_cvtpd_epi32 fn'>_mm256_cvtpd_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Converts packed double-precision (64-bit) floating-point elements in <code>a</code>
to packed 32-bit integers.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_cvtps_epi32.html" title='core::arch::x86::_mm256_cvtps_epi32 fn'>_mm256_cvtps_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Converts packed single-precision (32-bit) floating-point elements in <code>a</code>
to packed 32-bit integers.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_cvtsd_f64.html" title='core::arch::x86::_mm256_cvtsd_f64 fn'>_mm256_cvtsd_f64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Returns the first element of the input vector of <code>[4 x double]</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_cvtsi256_si32.html" title='core::arch::x86::_mm256_cvtsi256_si32 fn'>_mm256_cvtsi256_si32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Returns the first element of the input vector of <code>[8 x i32]</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_cvtss_f32.html" title='core::arch::x86::_mm256_cvtss_f32 fn'>_mm256_cvtss_f32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Returns the first element of the input vector of <code>[8 x float]</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_cvttpd_epi32.html" title='core::arch::x86::_mm256_cvttpd_epi32 fn'>_mm256_cvttpd_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Converts packed double-precision (64-bit) floating-point elements in <code>a</code>
to packed 32-bit integers with truncation.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_cvttps_epi32.html" title='core::arch::x86::_mm256_cvttps_epi32 fn'>_mm256_cvttps_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Converts packed single-precision (32-bit) floating-point elements in <code>a</code>
to packed 32-bit integers with truncation.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_extract_epi8.html" title='core::arch::x86::_mm256_extract_epi8 fn'>_mm256_extract_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Extracts an 8-bit integer from <code>a</code>, selected with <code>imm8</code>. Returns a 32-bit
integer containing the zero-extended integer data.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_extract_epi16.html" title='core::arch::x86::_mm256_extract_epi16 fn'>_mm256_extract_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Extracts a 16-bit integer from <code>a</code>, selected with <code>imm8</code>. Returns a 32-bit
integer containing the zero-extended integer data.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_extract_epi32.html" title='core::arch::x86::_mm256_extract_epi32 fn'>_mm256_extract_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Extracts a 32-bit integer from <code>a</code>, selected with <code>imm8</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_extractf128_ps.html" title='core::arch::x86::_mm256_extractf128_ps fn'>_mm256_extractf128_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Extracts 128 bits (composed of 4 packed single-precision (32-bit)
floating-point elements) from <code>a</code>, selected with <code>imm8</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_extractf128_pd.html" title='core::arch::x86::_mm256_extractf128_pd fn'>_mm256_extractf128_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Extracts 128 bits (composed of 2 packed double-precision (64-bit)
floating-point elements) from <code>a</code>, selected with <code>imm8</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_extractf128_si256.html" title='core::arch::x86::_mm256_extractf128_si256 fn'>_mm256_extractf128_si256</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Extracts 128 bits (composed of integer data) from <code>a</code>, selected with <code>imm8</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_extracti128_si256.html" title='core::arch::x86::_mm256_extracti128_si256 fn'>_mm256_extracti128_si256</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Extracts 128 bits (of integer data) from <code>a</code> selected with <code>imm8</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_hadd_epi16.html" title='core::arch::x86::_mm256_hadd_epi16 fn'>_mm256_hadd_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Horizontally adds adjacent pairs of 16-bit integers in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_hadd_epi32.html" title='core::arch::x86::_mm256_hadd_epi32 fn'>_mm256_hadd_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Horizontally adds adjacent pairs of 32-bit integers in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_hadds_epi16.html" title='core::arch::x86::_mm256_hadds_epi16 fn'>_mm256_hadds_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Horizontally adds adjacent pairs of 16-bit integers in <code>a</code> and <code>b</code>
using saturation.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_hsub_epi16.html" title='core::arch::x86::_mm256_hsub_epi16 fn'>_mm256_hsub_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Horizontally subtract adjacent pairs of 16-bit integers in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_hsub_epi32.html" title='core::arch::x86::_mm256_hsub_epi32 fn'>_mm256_hsub_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Horizontally subtract adjacent pairs of 32-bit integers in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_hsubs_epi16.html" title='core::arch::x86::_mm256_hsubs_epi16 fn'>_mm256_hsubs_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Horizontally subtract adjacent pairs of 16-bit integers in <code>a</code> and <code>b</code>
using saturation.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_i32gather_ps.html" title='core::arch::x86::_mm256_i32gather_ps fn'>_mm256_i32gather_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Returns values from <code>slice</code> at offsets determined by <code>offsets * scale</code>,
where
<code>scale</code> is between 1 and 8.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_i32gather_pd.html" title='core::arch::x86::_mm256_i32gather_pd fn'>_mm256_i32gather_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Returns values from <code>slice</code> at offsets determined by <code>offsets * scale</code>,
where
<code>scale</code> is between 1 and 8.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_i64gather_ps.html" title='core::arch::x86::_mm256_i64gather_ps fn'>_mm256_i64gather_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Returns values from <code>slice</code> at offsets determined by <code>offsets * scale</code>,
where
<code>scale</code> is between 1 and 8.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_i64gather_pd.html" title='core::arch::x86::_mm256_i64gather_pd fn'>_mm256_i64gather_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Returns values from <code>slice</code> at offsets determined by <code>offsets * scale</code>,
where
<code>scale</code> is between 1 and 8.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_i32gather_epi32.html" title='core::arch::x86::_mm256_i32gather_epi32 fn'>_mm256_i32gather_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Returns values from <code>slice</code> at offsets determined by <code>offsets * scale</code>,
where
<code>scale</code> is between 1 and 8.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_i32gather_epi64.html" title='core::arch::x86::_mm256_i32gather_epi64 fn'>_mm256_i32gather_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Returns values from <code>slice</code> at offsets determined by <code>offsets * scale</code>,
where
<code>scale</code> is between 1 and 8.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_i64gather_epi32.html" title='core::arch::x86::_mm256_i64gather_epi32 fn'>_mm256_i64gather_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Returns values from <code>slice</code> at offsets determined by <code>offsets * scale</code>,
where
<code>scale</code> is between 1 and 8.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_i64gather_epi64.html" title='core::arch::x86::_mm256_i64gather_epi64 fn'>_mm256_i64gather_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Returns values from <code>slice</code> at offsets determined by <code>offsets * scale</code>,
where
<code>scale</code> is between 1 and 8.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_insert_epi8.html" title='core::arch::x86::_mm256_insert_epi8 fn'>_mm256_insert_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Copies <code>a</code> to result, and inserts the 8-bit integer <code>i</code> into result
at the location specified by <code>index</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_insert_epi16.html" title='core::arch::x86::_mm256_insert_epi16 fn'>_mm256_insert_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Copies <code>a</code> to result, and inserts the 16-bit integer <code>i</code> into result
at the location specified by <code>index</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_insert_epi32.html" title='core::arch::x86::_mm256_insert_epi32 fn'>_mm256_insert_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Copies <code>a</code> to result, and inserts the 32-bit integer <code>i</code> into result
at the location specified by <code>index</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_insertf128_ps.html" title='core::arch::x86::_mm256_insertf128_ps fn'>_mm256_insertf128_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Copies <code>a</code> to result, then inserts 128 bits (composed of 4 packed
single-precision (32-bit) floating-point elements) from <code>b</code> into result
at the location specified by <code>imm8</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_insertf128_pd.html" title='core::arch::x86::_mm256_insertf128_pd fn'>_mm256_insertf128_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Copies <code>a</code> to result, then inserts 128 bits (composed of 2 packed
double-precision (64-bit) floating-point elements) from <code>b</code> into result
at the location specified by <code>imm8</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_insertf128_si256.html" title='core::arch::x86::_mm256_insertf128_si256 fn'>_mm256_insertf128_si256</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Copies <code>a</code> to result, then inserts 128 bits from <code>b</code> into result
at the location specified by <code>imm8</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_inserti128_si256.html" title='core::arch::x86::_mm256_inserti128_si256 fn'>_mm256_inserti128_si256</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Copies <code>a</code> to <code>dst</code>, then insert 128 bits (of integer data) from <code>b</code> at the
location specified by <code>imm8</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_lddqu_si256.html" title='core::arch::x86::_mm256_lddqu_si256 fn'>_mm256_lddqu_si256</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Loads 256-bits of integer data from unaligned memory into result.
This intrinsic may perform better than <code>_mm256_loadu_si256</code> when the
data crosses a cache line boundary.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_load_si256.html" title='core::arch::x86::_mm256_load_si256 fn'>_mm256_load_si256</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Loads 256-bits of integer data from memory into result.
<code>mem_addr</code> must be aligned on a 32-byte boundary or a
general-protection exception may be generated.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_loadu2_m128.html" title='core::arch::x86::_mm256_loadu2_m128 fn'>_mm256_loadu2_m128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx,sse</code></span><p>Loads two 128-bit values (composed of 4 packed single-precision (32-bit)
floating-point elements) from memory, and combine them into a 256-bit
value.
<code>hiaddr</code> and <code>loaddr</code> do not need to be aligned on any particular boundary.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_loadu2_m128d.html" title='core::arch::x86::_mm256_loadu2_m128d fn'>_mm256_loadu2_m128d</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx,sse2</code></span><p>Loads two 128-bit values (composed of 2 packed double-precision (64-bit)
floating-point elements) from memory, and combine them into a 256-bit
value.
<code>hiaddr</code> and <code>loaddr</code> do not need to be aligned on any particular boundary.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_loadu2_m128i.html" title='core::arch::x86::_mm256_loadu2_m128i fn'>_mm256_loadu2_m128i</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx,sse2</code></span><p>Loads two 128-bit values (composed of integer data) from memory, and combine
them into a 256-bit value.
<code>hiaddr</code> and <code>loaddr</code> do not need to be aligned on any particular boundary.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_loadu_si256.html" title='core::arch::x86::_mm256_loadu_si256 fn'>_mm256_loadu_si256</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Loads 256-bits of integer data from memory into result.
<code>mem_addr</code> does not need to be aligned on any particular boundary.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_madd_epi16.html" title='core::arch::x86::_mm256_madd_epi16 fn'>_mm256_madd_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Multiplies packed signed 16-bit integers in <code>a</code> and <code>b</code>, producing
intermediate signed 32-bit integers. Horizontally add adjacent pairs
of intermediate 32-bit integers.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_maddubs_epi16.html" title='core::arch::x86::_mm256_maddubs_epi16 fn'>_mm256_maddubs_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Vertically multiplies each unsigned 8-bit integer from <code>a</code> with the
corresponding signed 8-bit integer from <code>b</code>, producing intermediate
signed 16-bit integers. Horizontally add adjacent pairs of intermediate
signed 16-bit integers</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_mask_i32gather_ps.html" title='core::arch::x86::_mm256_mask_i32gather_ps fn'>_mm256_mask_i32gather_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Returns values from <code>slice</code> at offsets determined by <code>offsets * scale</code>,
where
<code>scale</code> is between 1 and 8. If mask is set, load the value from <code>src</code> in
that position instead.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_mask_i32gather_pd.html" title='core::arch::x86::_mm256_mask_i32gather_pd fn'>_mm256_mask_i32gather_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Returns values from <code>slice</code> at offsets determined by <code>offsets * scale</code>,
where
<code>scale</code> is between 1 and 8. If mask is set, load the value from <code>src</code> in
that position instead.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_mask_i64gather_ps.html" title='core::arch::x86::_mm256_mask_i64gather_ps fn'>_mm256_mask_i64gather_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Returns values from <code>slice</code> at offsets determined by <code>offsets * scale</code>,
where
<code>scale</code> is between 1 and 8. If mask is set, load the value from <code>src</code> in
that position instead.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_mask_i64gather_pd.html" title='core::arch::x86::_mm256_mask_i64gather_pd fn'>_mm256_mask_i64gather_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Returns values from <code>slice</code> at offsets determined by <code>offsets * scale</code>,
where
<code>scale</code> is between 1 and 8. If mask is set, load the value from <code>src</code> in
that position instead.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_mask_i32gather_epi32.html" title='core::arch::x86::_mm256_mask_i32gather_epi32 fn'>_mm256_mask_i32gather_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Returns values from <code>slice</code> at offsets determined by <code>offsets * scale</code>,
where
<code>scale</code> is between 1 and 8. If mask is set, load the value from <code>src</code> in
that position instead.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_mask_i32gather_epi64.html" title='core::arch::x86::_mm256_mask_i32gather_epi64 fn'>_mm256_mask_i32gather_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Returns values from <code>slice</code> at offsets determined by <code>offsets * scale</code>,
where
<code>scale</code> is between 1 and 8. If mask is set, load the value from <code>src</code> in
that position instead.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_mask_i64gather_epi32.html" title='core::arch::x86::_mm256_mask_i64gather_epi32 fn'>_mm256_mask_i64gather_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Returns values from <code>slice</code> at offsets determined by <code>offsets * scale</code>,
where
<code>scale</code> is between 1 and 8. If mask is set, load the value from <code>src</code> in
that position instead.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_mask_i64gather_epi64.html" title='core::arch::x86::_mm256_mask_i64gather_epi64 fn'>_mm256_mask_i64gather_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Returns values from <code>slice</code> at offsets determined by <code>offsets * scale</code>,
where
<code>scale</code> is between 1 and 8. If mask is set, load the value from <code>src</code> in
that position instead.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_maskload_epi32.html" title='core::arch::x86::_mm256_maskload_epi32 fn'>_mm256_maskload_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Loads packed 32-bit integers from memory pointed by <code>mem_addr</code> using <code>mask</code>
(elements are zeroed out when the highest bit is not set in the
corresponding element).</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_maskload_epi64.html" title='core::arch::x86::_mm256_maskload_epi64 fn'>_mm256_maskload_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Loads packed 64-bit integers from memory pointed by <code>mem_addr</code> using <code>mask</code>
(elements are zeroed out when the highest bit is not set in the
corresponding element).</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_maskstore_epi32.html" title='core::arch::x86::_mm256_maskstore_epi32 fn'>_mm256_maskstore_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Stores packed 32-bit integers from <code>a</code> into memory pointed by <code>mem_addr</code>
using <code>mask</code> (elements are not stored when the highest bit is not set
in the corresponding element).</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_maskstore_epi64.html" title='core::arch::x86::_mm256_maskstore_epi64 fn'>_mm256_maskstore_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Stores packed 64-bit integers from <code>a</code> into memory pointed by <code>mem_addr</code>
using <code>mask</code> (elements are not stored when the highest bit is not set
in the corresponding element).</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_max_epi8.html" title='core::arch::x86::_mm256_max_epi8 fn'>_mm256_max_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Compares packed 8-bit integers in <code>a</code> and <code>b</code>, and returns the packed
maximum values.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_max_epi16.html" title='core::arch::x86::_mm256_max_epi16 fn'>_mm256_max_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Compares packed 16-bit integers in <code>a</code> and <code>b</code>, and returns the packed
maximum values.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_max_epi32.html" title='core::arch::x86::_mm256_max_epi32 fn'>_mm256_max_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Compares packed 32-bit integers in <code>a</code> and <code>b</code>, and returns the packed
maximum values.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_max_epu8.html" title='core::arch::x86::_mm256_max_epu8 fn'>_mm256_max_epu8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Compares packed unsigned 8-bit integers in <code>a</code> and <code>b</code>, and returns
the packed maximum values.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_max_epu16.html" title='core::arch::x86::_mm256_max_epu16 fn'>_mm256_max_epu16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Compares packed unsigned 16-bit integers in <code>a</code> and <code>b</code>, and returns
the packed maximum values.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_max_epu32.html" title='core::arch::x86::_mm256_max_epu32 fn'>_mm256_max_epu32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Compares packed unsigned 32-bit integers in <code>a</code> and <code>b</code>, and returns
the packed maximum values.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_min_epi8.html" title='core::arch::x86::_mm256_min_epi8 fn'>_mm256_min_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Compares packed 8-bit integers in <code>a</code> and <code>b</code>, and returns the packed
minimum values.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_min_epi16.html" title='core::arch::x86::_mm256_min_epi16 fn'>_mm256_min_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Compares packed 16-bit integers in <code>a</code> and <code>b</code>, and returns the packed
minimum values.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_min_epi32.html" title='core::arch::x86::_mm256_min_epi32 fn'>_mm256_min_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Compares packed 32-bit integers in <code>a</code> and <code>b</code>, and returns the packed
minimum values.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_min_epu8.html" title='core::arch::x86::_mm256_min_epu8 fn'>_mm256_min_epu8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Compares packed unsigned 8-bit integers in <code>a</code> and <code>b</code>, and returns
the packed minimum values.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_min_epu16.html" title='core::arch::x86::_mm256_min_epu16 fn'>_mm256_min_epu16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Compares packed unsigned 16-bit integers in <code>a</code> and <code>b</code>, and returns
the packed minimum values.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_min_epu32.html" title='core::arch::x86::_mm256_min_epu32 fn'>_mm256_min_epu32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Compares packed unsigned 32-bit integers in <code>a</code> and <code>b</code>, and returns
the packed minimum values.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_movemask_epi8.html" title='core::arch::x86::_mm256_movemask_epi8 fn'>_mm256_movemask_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Creates mask from the most significant bit of each 8-bit element in <code>a</code>,
return the result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_mpsadbw_epu8.html" title='core::arch::x86::_mm256_mpsadbw_epu8 fn'>_mm256_mpsadbw_epu8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Computes the sum of absolute differences (SADs) of quadruplets of unsigned
8-bit integers in <code>a</code> compared to those in <code>b</code>, and stores the 16-bit
results in dst. Eight SADs are performed for each 128-bit lane using one
quadruplet from <code>b</code> and eight quadruplets from <code>a</code>. One quadruplet is
selected from <code>b</code> starting at on the offset specified in <code>imm8</code>. Eight
quadruplets are formed from sequential 8-bit integers selected from <code>a</code>
starting at the offset specified in <code>imm8</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_mul_epi32.html" title='core::arch::x86::_mm256_mul_epi32 fn'>_mm256_mul_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Multiplies the low 32-bit integers from each packed 64-bit element in
<code>a</code> and <code>b</code></p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_mul_epu32.html" title='core::arch::x86::_mm256_mul_epu32 fn'>_mm256_mul_epu32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Multiplies the low unsigned 32-bit integers from each packed 64-bit
element in <code>a</code> and <code>b</code></p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_mulhi_epi16.html" title='core::arch::x86::_mm256_mulhi_epi16 fn'>_mm256_mulhi_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Multiplies the packed 16-bit integers in <code>a</code> and <code>b</code>, producing
intermediate 32-bit integers and returning the high 16 bits of the
intermediate integers.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_mulhi_epu16.html" title='core::arch::x86::_mm256_mulhi_epu16 fn'>_mm256_mulhi_epu16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Multiplies the packed unsigned 16-bit integers in <code>a</code> and <code>b</code>, producing
intermediate 32-bit integers and returning the high 16 bits of the
intermediate integers.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_mulhrs_epi16.html" title='core::arch::x86::_mm256_mulhrs_epi16 fn'>_mm256_mulhrs_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Multiplies packed 16-bit integers in <code>a</code> and <code>b</code>, producing
intermediate signed 32-bit integers. Truncate each intermediate
integer to the 18 most significant bits, round by adding 1, and
return bits <code>[16:1]</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_mullo_epi16.html" title='core::arch::x86::_mm256_mullo_epi16 fn'>_mm256_mullo_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Multiplies the packed 16-bit integers in <code>a</code> and <code>b</code>, producing
intermediate 32-bit integers, and returns the low 16 bits of the
intermediate integers</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_mullo_epi32.html" title='core::arch::x86::_mm256_mullo_epi32 fn'>_mm256_mullo_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Multiplies the packed 32-bit integers in <code>a</code> and <code>b</code>, producing
intermediate 64-bit integers, and returns the low 16 bits of the
intermediate integers</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_or_si256.html" title='core::arch::x86::_mm256_or_si256 fn'>_mm256_or_si256</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Computes the bitwise OR of 256 bits (representing integer data) in <code>a</code>
and <code>b</code></p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_packs_epi16.html" title='core::arch::x86::_mm256_packs_epi16 fn'>_mm256_packs_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Converts packed 16-bit integers from <code>a</code> and <code>b</code> to packed 8-bit integers
using signed saturation</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_packs_epi32.html" title='core::arch::x86::_mm256_packs_epi32 fn'>_mm256_packs_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Converts packed 32-bit integers from <code>a</code> and <code>b</code> to packed 16-bit integers
using signed saturation</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_packus_epi16.html" title='core::arch::x86::_mm256_packus_epi16 fn'>_mm256_packus_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Converts packed 16-bit integers from <code>a</code> and <code>b</code> to packed 8-bit integers
using unsigned saturation</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_packus_epi32.html" title='core::arch::x86::_mm256_packus_epi32 fn'>_mm256_packus_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Converts packed 32-bit integers from <code>a</code> and <code>b</code> to packed 16-bit integers
using unsigned saturation</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_permute2f128_ps.html" title='core::arch::x86::_mm256_permute2f128_ps fn'>_mm256_permute2f128_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Shuffles 256 bits (composed of 8 packed single-precision (32-bit)
floating-point elements) selected by <code>imm8</code> from <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_permute2f128_pd.html" title='core::arch::x86::_mm256_permute2f128_pd fn'>_mm256_permute2f128_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Shuffles 256 bits (composed of 4 packed double-precision (64-bit)
floating-point elements) selected by <code>imm8</code> from <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_permute2f128_si256.html" title='core::arch::x86::_mm256_permute2f128_si256 fn'>_mm256_permute2f128_si256</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Shuffles 258-bits (composed of integer data) selected by <code>imm8</code>
from <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_permute2x128_si256.html" title='core::arch::x86::_mm256_permute2x128_si256 fn'>_mm256_permute2x128_si256</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Shuffles 128-bits of integer data selected by <code>imm8</code> from <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_permute4x64_pd.html" title='core::arch::x86::_mm256_permute4x64_pd fn'>_mm256_permute4x64_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Shuffles 64-bit floating-point elements in <code>a</code> across lanes using the
control in <code>imm8</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_permute4x64_epi64.html" title='core::arch::x86::_mm256_permute4x64_epi64 fn'>_mm256_permute4x64_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Permutes 64-bit integers from <code>a</code> using control mask <code>imm8</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_permutevar8x32_ps.html" title='core::arch::x86::_mm256_permutevar8x32_ps fn'>_mm256_permutevar8x32_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Shuffles eight 32-bit foating-point elements in <code>a</code> across lanes using
the corresponding 32-bit integer index in <code>idx</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_permutevar8x32_epi32.html" title='core::arch::x86::_mm256_permutevar8x32_epi32 fn'>_mm256_permutevar8x32_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Permutes packed 32-bit integers from <code>a</code> according to the content of <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_sad_epu8.html" title='core::arch::x86::_mm256_sad_epu8 fn'>_mm256_sad_epu8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Computes the absolute differences of packed unsigned 8-bit integers in <code>a</code>
and <code>b</code>, then horizontally sum each consecutive 8 differences to
produce four unsigned 16-bit integers, and pack these unsigned 16-bit
integers in the low 16 bits of the 64-bit return value</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_set1_pd.html" title='core::arch::x86::_mm256_set1_pd fn'>_mm256_set1_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Broadcasts double-precision (64-bit) floating-point value <code>a</code> to all
elements of returned vector.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_set1_ps.html" title='core::arch::x86::_mm256_set1_ps fn'>_mm256_set1_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Broadcasts single-precision (32-bit) floating-point value <code>a</code> to all
elements of returned vector.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_set1_epi8.html" title='core::arch::x86::_mm256_set1_epi8 fn'>_mm256_set1_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Broadcasts 8-bit integer <code>a</code> to all elements of returned vector.
This intrinsic may generate the <code>vpbroadcastb</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_set1_epi16.html" title='core::arch::x86::_mm256_set1_epi16 fn'>_mm256_set1_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Broadcasts 16-bit integer <code>a</code> to all all elements of returned vector.
This intrinsic may generate the <code>vpbroadcastw</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_set1_epi32.html" title='core::arch::x86::_mm256_set1_epi32 fn'>_mm256_set1_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Broadcasts 32-bit integer <code>a</code> to all elements of returned vector.
This intrinsic may generate the <code>vpbroadcastd</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_set1_epi64x.html" title='core::arch::x86::_mm256_set1_epi64x fn'>_mm256_set1_epi64x</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Broadcasts 64-bit integer <code>a</code> to all elements of returned vector.
This intrinsic may generate the <code>vpbroadcastq</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_set_epi8.html" title='core::arch::x86::_mm256_set_epi8 fn'>_mm256_set_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Sets packed 8-bit integers in returned vector with the supplied values in
reverse order.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_set_epi16.html" title='core::arch::x86::_mm256_set_epi16 fn'>_mm256_set_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Sets packed 16-bit integers in returned vector with the supplied values.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_set_epi32.html" title='core::arch::x86::_mm256_set_epi32 fn'>_mm256_set_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Sets packed 32-bit integers in returned vector with the supplied values.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_set_epi64x.html" title='core::arch::x86::_mm256_set_epi64x fn'>_mm256_set_epi64x</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Sets packed 64-bit integers in returned vector with the supplied values.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_set_m128.html" title='core::arch::x86::_mm256_set_m128 fn'>_mm256_set_m128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Sets packed __m256 returned vector with the supplied values.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_set_m128d.html" title='core::arch::x86::_mm256_set_m128d fn'>_mm256_set_m128d</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Sets packed __m256d returned vector with the supplied values.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_set_m128i.html" title='core::arch::x86::_mm256_set_m128i fn'>_mm256_set_m128i</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Sets packed __m256i returned vector with the supplied values.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_setr_epi8.html" title='core::arch::x86::_mm256_setr_epi8 fn'>_mm256_setr_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Sets packed 8-bit integers in returned vector with the supplied values in
reverse order.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_setr_epi16.html" title='core::arch::x86::_mm256_setr_epi16 fn'>_mm256_setr_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Sets packed 16-bit integers in returned vector with the supplied values in
reverse order.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_setr_epi32.html" title='core::arch::x86::_mm256_setr_epi32 fn'>_mm256_setr_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Sets packed 32-bit integers in returned vector with the supplied values in
reverse order.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_setr_epi64x.html" title='core::arch::x86::_mm256_setr_epi64x fn'>_mm256_setr_epi64x</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Sets packed 64-bit integers in returned vector with the supplied values in
reverse order.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_setr_m128.html" title='core::arch::x86::_mm256_setr_m128 fn'>_mm256_setr_m128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Sets packed __m256 returned vector with the supplied values.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_setr_m128d.html" title='core::arch::x86::_mm256_setr_m128d fn'>_mm256_setr_m128d</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Sets packed __m256d returned vector with the supplied values.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_setr_m128i.html" title='core::arch::x86::_mm256_setr_m128i fn'>_mm256_setr_m128i</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Sets packed __m256i returned vector with the supplied values.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_setzero_si256.html" title='core::arch::x86::_mm256_setzero_si256 fn'>_mm256_setzero_si256</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Returns vector of type __m256i with all elements set to zero.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_shuffle_epi8.html" title='core::arch::x86::_mm256_shuffle_epi8 fn'>_mm256_shuffle_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Shuffles bytes from <code>a</code> according to the content of <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_shuffle_epi32.html" title='core::arch::x86::_mm256_shuffle_epi32 fn'>_mm256_shuffle_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Shuffles 32-bit integers in 128-bit lanes of <code>a</code> using the control in
<code>imm8</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_shufflehi_epi16.html" title='core::arch::x86::_mm256_shufflehi_epi16 fn'>_mm256_shufflehi_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Shuffles 16-bit integers in the high 64 bits of 128-bit lanes of <code>a</code> using
the control in <code>imm8</code>. The low 64 bits of 128-bit lanes of <code>a</code> are copied
to the output.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_shufflelo_epi16.html" title='core::arch::x86::_mm256_shufflelo_epi16 fn'>_mm256_shufflelo_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Shuffles 16-bit integers in the low 64 bits of 128-bit lanes of <code>a</code> using
the control in <code>imm8</code>. The high 64 bits of 128-bit lanes of <code>a</code> are copied
to the output.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_sign_epi8.html" title='core::arch::x86::_mm256_sign_epi8 fn'>_mm256_sign_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Negates packed 8-bit integers in <code>a</code> when the corresponding signed
8-bit integer in <code>b</code> is negative, and returns the results.
Results are zeroed out when the corresponding element in <code>b</code> is zero.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_sign_epi16.html" title='core::arch::x86::_mm256_sign_epi16 fn'>_mm256_sign_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Negates packed 16-bit integers in <code>a</code> when the corresponding signed
16-bit integer in <code>b</code> is negative, and returns the results.
Results are zeroed out when the corresponding element in <code>b</code> is zero.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_sign_epi32.html" title='core::arch::x86::_mm256_sign_epi32 fn'>_mm256_sign_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Negates packed 32-bit integers in <code>a</code> when the corresponding signed
32-bit integer in <code>b</code> is negative, and returns the results.
Results are zeroed out when the corresponding element in <code>b</code> is zero.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_sll_epi16.html" title='core::arch::x86::_mm256_sll_epi16 fn'>_mm256_sll_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Shifts packed 16-bit integers in <code>a</code> left by <code>count</code> while
shifting in zeros, and returns the result</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_sll_epi32.html" title='core::arch::x86::_mm256_sll_epi32 fn'>_mm256_sll_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Shifts packed 32-bit integers in <code>a</code> left by <code>count</code> while
shifting in zeros, and returns the result</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_sll_epi64.html" title='core::arch::x86::_mm256_sll_epi64 fn'>_mm256_sll_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Shifts packed 64-bit integers in <code>a</code> left by <code>count</code> while
shifting in zeros, and returns the result</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_slli_epi16.html" title='core::arch::x86::_mm256_slli_epi16 fn'>_mm256_slli_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Shifts packed 16-bit integers in <code>a</code> left by <code>imm8</code> while
shifting in zeros, return the results;</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_slli_epi32.html" title='core::arch::x86::_mm256_slli_epi32 fn'>_mm256_slli_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Shifts packed 32-bit integers in <code>a</code> left by <code>imm8</code> while
shifting in zeros, return the results;</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_slli_epi64.html" title='core::arch::x86::_mm256_slli_epi64 fn'>_mm256_slli_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Shifts packed 64-bit integers in <code>a</code> left by <code>imm8</code> while
shifting in zeros, return the results;</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_slli_si256.html" title='core::arch::x86::_mm256_slli_si256 fn'>_mm256_slli_si256</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Shifts 128-bit lanes in <code>a</code> left by <code>imm8</code> bytes while shifting in zeros.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_sllv_epi32.html" title='core::arch::x86::_mm256_sllv_epi32 fn'>_mm256_sllv_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Shifts packed 32-bit integers in <code>a</code> left by the amount
specified by the corresponding element in <code>count</code> while
shifting in zeros, and returns the result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_sllv_epi64.html" title='core::arch::x86::_mm256_sllv_epi64 fn'>_mm256_sllv_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Shifts packed 64-bit integers in <code>a</code> left by the amount
specified by the corresponding element in <code>count</code> while
shifting in zeros, and returns the result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_sra_epi16.html" title='core::arch::x86::_mm256_sra_epi16 fn'>_mm256_sra_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Shifts packed 16-bit integers in <code>a</code> right by <code>count</code> while
shifting in sign bits.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_sra_epi32.html" title='core::arch::x86::_mm256_sra_epi32 fn'>_mm256_sra_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Shifts packed 32-bit integers in <code>a</code> right by <code>count</code> while
shifting in sign bits.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_srai_epi16.html" title='core::arch::x86::_mm256_srai_epi16 fn'>_mm256_srai_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Shifts packed 16-bit integers in <code>a</code> right by <code>imm8</code> while
shifting in sign bits.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_srai_epi32.html" title='core::arch::x86::_mm256_srai_epi32 fn'>_mm256_srai_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Shifts packed 32-bit integers in <code>a</code> right by <code>imm8</code> while
shifting in sign bits.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_srav_epi32.html" title='core::arch::x86::_mm256_srav_epi32 fn'>_mm256_srav_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Shifts packed 32-bit integers in <code>a</code> right by the amount specified by the
corresponding element in <code>count</code> while shifting in sign bits.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_srl_epi16.html" title='core::arch::x86::_mm256_srl_epi16 fn'>_mm256_srl_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Shifts packed 16-bit integers in <code>a</code> right by <code>count</code> while shifting in
zeros.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_srl_epi32.html" title='core::arch::x86::_mm256_srl_epi32 fn'>_mm256_srl_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Shifts packed 32-bit integers in <code>a</code> right by <code>count</code> while shifting in
zeros.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_srl_epi64.html" title='core::arch::x86::_mm256_srl_epi64 fn'>_mm256_srl_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Shifts packed 64-bit integers in <code>a</code> right by <code>count</code> while shifting in
zeros.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_srli_epi16.html" title='core::arch::x86::_mm256_srli_epi16 fn'>_mm256_srli_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Shifts packed 16-bit integers in <code>a</code> right by <code>imm8</code> while shifting in
zeros</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_srli_epi32.html" title='core::arch::x86::_mm256_srli_epi32 fn'>_mm256_srli_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Shifts packed 32-bit integers in <code>a</code> right by <code>imm8</code> while shifting in
zeros</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_srli_epi64.html" title='core::arch::x86::_mm256_srli_epi64 fn'>_mm256_srli_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Shifts packed 64-bit integers in <code>a</code> right by <code>imm8</code> while shifting in
zeros</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_srli_si256.html" title='core::arch::x86::_mm256_srli_si256 fn'>_mm256_srli_si256</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Shifts 128-bit lanes in <code>a</code> right by <code>imm8</code> bytes while shifting in zeros.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_srlv_epi32.html" title='core::arch::x86::_mm256_srlv_epi32 fn'>_mm256_srlv_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Shifts packed 32-bit integers in <code>a</code> right by the amount specified by
the corresponding element in <code>count</code> while shifting in zeros,</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_srlv_epi64.html" title='core::arch::x86::_mm256_srlv_epi64 fn'>_mm256_srlv_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Shifts packed 64-bit integers in <code>a</code> right by the amount specified by
the corresponding element in <code>count</code> while shifting in zeros,</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_store_si256.html" title='core::arch::x86::_mm256_store_si256 fn'>_mm256_store_si256</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Stores 256-bits of integer data from <code>a</code> into memory.
<code>mem_addr</code> must be aligned on a 32-byte boundary or a
general-protection exception may be generated.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_storeu2_m128.html" title='core::arch::x86::_mm256_storeu2_m128 fn'>_mm256_storeu2_m128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx,sse</code></span><p>Stores the high and low 128-bit halves (each composed of 4 packed
single-precision (32-bit) floating-point elements) from <code>a</code> into memory two
different 128-bit locations.
<code>hiaddr</code> and <code>loaddr</code> do not need to be aligned on any particular boundary.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_storeu2_m128d.html" title='core::arch::x86::_mm256_storeu2_m128d fn'>_mm256_storeu2_m128d</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx,sse2</code></span><p>Stores the high and low 128-bit halves (each composed of 2 packed
double-precision (64-bit) floating-point elements) from <code>a</code> into memory two
different 128-bit locations.
<code>hiaddr</code> and <code>loaddr</code> do not need to be aligned on any particular boundary.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_storeu2_m128i.html" title='core::arch::x86::_mm256_storeu2_m128i fn'>_mm256_storeu2_m128i</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx,sse2</code></span><p>Stores the high and low 128-bit halves (each composed of integer data) from
<code>a</code> into memory two different 128-bit locations.
<code>hiaddr</code> and <code>loaddr</code> do not need to be aligned on any particular boundary.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_storeu_si256.html" title='core::arch::x86::_mm256_storeu_si256 fn'>_mm256_storeu_si256</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Stores 256-bits of integer data from <code>a</code> into memory.
<code>mem_addr</code> does not need to be aligned on any particular boundary.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_stream_si256.html" title='core::arch::x86::_mm256_stream_si256 fn'>_mm256_stream_si256</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Moves integer data from a 256-bit integer vector to a 32-byte
aligned memory location. To minimize caching, the data is flagged as
non-temporal (unlikely to be used again soon)</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_sub_epi8.html" title='core::arch::x86::_mm256_sub_epi8 fn'>_mm256_sub_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Subtract packed 8-bit integers in <code>b</code> from packed 16-bit integers in <code>a</code></p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_sub_epi16.html" title='core::arch::x86::_mm256_sub_epi16 fn'>_mm256_sub_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Subtract packed 16-bit integers in <code>b</code> from packed 16-bit integers in <code>a</code></p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_sub_epi32.html" title='core::arch::x86::_mm256_sub_epi32 fn'>_mm256_sub_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Subtract packed 32-bit integers in <code>b</code> from packed 16-bit integers in <code>a</code></p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_sub_epi64.html" title='core::arch::x86::_mm256_sub_epi64 fn'>_mm256_sub_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Subtract packed 64-bit integers in <code>b</code> from packed 16-bit integers in <code>a</code></p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_subs_epi8.html" title='core::arch::x86::_mm256_subs_epi8 fn'>_mm256_subs_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Subtract packed 8-bit integers in <code>b</code> from packed 8-bit integers in
<code>a</code> using saturation.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_subs_epi16.html" title='core::arch::x86::_mm256_subs_epi16 fn'>_mm256_subs_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Subtract packed 16-bit integers in <code>b</code> from packed 16-bit integers in
<code>a</code> using saturation.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_subs_epu8.html" title='core::arch::x86::_mm256_subs_epu8 fn'>_mm256_subs_epu8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Subtract packed unsigned 8-bit integers in <code>b</code> from packed 8-bit
integers in <code>a</code> using saturation.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_subs_epu16.html" title='core::arch::x86::_mm256_subs_epu16 fn'>_mm256_subs_epu16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Subtract packed unsigned 16-bit integers in <code>b</code> from packed 16-bit
integers in <code>a</code> using saturation.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_testc_si256.html" title='core::arch::x86::_mm256_testc_si256 fn'>_mm256_testc_si256</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Computes the bitwise AND of 256 bits (representing integer data) in <code>a</code> and
<code>b</code>, and set <code>ZF</code> to 1 if the result is zero, otherwise set <code>ZF</code> to 0.
Computes the bitwise NOT of <code>a</code> and then AND with <code>b</code>, and set <code>CF</code> to 1 if
the result is zero, otherwise set <code>CF</code> to 0. Return the <code>CF</code> value.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_testnzc_si256.html" title='core::arch::x86::_mm256_testnzc_si256 fn'>_mm256_testnzc_si256</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Computes the bitwise AND of 256 bits (representing integer data) in <code>a</code> and
<code>b</code>, and set <code>ZF</code> to 1 if the result is zero, otherwise set <code>ZF</code> to 0.
Computes the bitwise NOT of <code>a</code> and then AND with <code>b</code>, and set <code>CF</code> to 1 if
the result is zero, otherwise set <code>CF</code> to 0. Return 1 if both the <code>ZF</code> and
<code>CF</code> values are zero, otherwise return 0.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_testz_si256.html" title='core::arch::x86::_mm256_testz_si256 fn'>_mm256_testz_si256</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Computes the bitwise AND of 256 bits (representing integer data) in <code>a</code> and
<code>b</code>, and set <code>ZF</code> to 1 if the result is zero, otherwise set <code>ZF</code> to 0.
Computes the bitwise NOT of <code>a</code> and then AND with <code>b</code>, and set <code>CF</code> to 1 if
the result is zero, otherwise set <code>CF</code> to 0. Return the <code>ZF</code> value.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_undefined_si256.html" title='core::arch::x86::_mm256_undefined_si256 fn'>_mm256_undefined_si256</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Returns vector of type __m256i with undefined elements.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_unpackhi_epi8.html" title='core::arch::x86::_mm256_unpackhi_epi8 fn'>_mm256_unpackhi_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Unpacks and interleave 8-bit integers from the high half of each
128-bit lane in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_unpackhi_epi16.html" title='core::arch::x86::_mm256_unpackhi_epi16 fn'>_mm256_unpackhi_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Unpacks and interleave 16-bit integers from the high half of each
128-bit lane of <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_unpackhi_epi32.html" title='core::arch::x86::_mm256_unpackhi_epi32 fn'>_mm256_unpackhi_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Unpacks and interleave 32-bit integers from the high half of each
128-bit lane of <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_unpackhi_epi64.html" title='core::arch::x86::_mm256_unpackhi_epi64 fn'>_mm256_unpackhi_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Unpacks and interleave 64-bit integers from the high half of each
128-bit lane of <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_unpacklo_epi8.html" title='core::arch::x86::_mm256_unpacklo_epi8 fn'>_mm256_unpacklo_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Unpacks and interleave 8-bit integers from the low half of each
128-bit lane of <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_unpacklo_epi16.html" title='core::arch::x86::_mm256_unpacklo_epi16 fn'>_mm256_unpacklo_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Unpacks and interleave 16-bit integers from the low half of each
128-bit lane of <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_unpacklo_epi32.html" title='core::arch::x86::_mm256_unpacklo_epi32 fn'>_mm256_unpacklo_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Unpacks and interleave 32-bit integers from the low half of each
128-bit lane of <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_unpacklo_epi64.html" title='core::arch::x86::_mm256_unpacklo_epi64 fn'>_mm256_unpacklo_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Unpacks and interleave 64-bit integers from the low half of each
128-bit lane of <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_xor_si256.html" title='core::arch::x86::_mm256_xor_si256 fn'>_mm256_xor_si256</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Computes the bitwise XOR of 256 bits (representing integer data)
in <code>a</code> and <code>b</code></p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_zextpd128_pd256.html" title='core::arch::x86::_mm256_zextpd128_pd256 fn'>_mm256_zextpd128_pd256</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx,sse2</code></span><p>Constructs a 256-bit floating-point vector of <code>[4 x double]</code> from a
128-bit floating-point vector of <code>[2 x double]</code>. The lower 128 bits
contain the value of the source vector. The upper 128 bits are set
to zero.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_zextps128_ps256.html" title='core::arch::x86::_mm256_zextps128_ps256 fn'>_mm256_zextps128_ps256</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx,sse</code></span><p>Constructs a 256-bit floating-point vector of <code>[8 x float]</code> from a
128-bit floating-point vector of <code>[4 x float]</code>. The lower 128 bits contain
the value of the source vector. The upper 128 bits are set to zero.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm256_zextsi128_si256.html" title='core::arch::x86::_mm256_zextsi128_si256 fn'>_mm256_zextsi128_si256</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx,sse2</code></span><p>Constructs a 256-bit integer vector from a 128-bit integer vector.
The lower 128 bits contain the value of the source vector. The upper
128 bits are set to zero.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_abs_epi8.html" title='core::arch::x86::_mm_abs_epi8 fn'>_mm_abs_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>ssse3</code></span><p>Computes the absolute value of packed 8-bit signed integers in <code>a</code> and
return the unsigned results.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_abs_epi16.html" title='core::arch::x86::_mm_abs_epi16 fn'>_mm_abs_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>ssse3</code></span><p>Computes the absolute value of each of the packed 16-bit signed integers in
<code>a</code> and
return the 16-bit unsigned integer</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_abs_epi32.html" title='core::arch::x86::_mm_abs_epi32 fn'>_mm_abs_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>ssse3</code></span><p>Computes the absolute value of each of the packed 32-bit signed integers in
<code>a</code> and
return the 32-bit unsigned integer</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_add_epi8.html" title='core::arch::x86::_mm_add_epi8 fn'>_mm_add_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Adds packed 8-bit integers in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_add_epi16.html" title='core::arch::x86::_mm_add_epi16 fn'>_mm_add_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Adds packed 16-bit integers in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_add_epi32.html" title='core::arch::x86::_mm_add_epi32 fn'>_mm_add_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Adds packed 32-bit integers in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_add_epi64.html" title='core::arch::x86::_mm_add_epi64 fn'>_mm_add_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Adds packed 64-bit integers in <code>a</code> and &quot;b`.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_add_pd.html" title='core::arch::x86::_mm_add_pd fn'>_mm_add_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Adds packed double-precision (64-bit) floating-point elements in <code>a</code> and
<code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_add_ps.html" title='core::arch::x86::_mm_add_ps fn'>_mm_add_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Adds __m128 vectors.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_add_sd.html" title='core::arch::x86::_mm_add_sd fn'>_mm_add_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Returns a new vector with the low element of <code>a</code> replaced by the sum of the
low elements of <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_add_ss.html" title='core::arch::x86::_mm_add_ss fn'>_mm_add_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Adds the first component of <code>a</code> and <code>b</code>, the other components are copied
from <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_adds_epi8.html" title='core::arch::x86::_mm_adds_epi8 fn'>_mm_adds_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Adds packed 8-bit integers in <code>a</code> and <code>b</code> using saturation.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_adds_epi16.html" title='core::arch::x86::_mm_adds_epi16 fn'>_mm_adds_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Adds packed 16-bit integers in <code>a</code> and <code>b</code> using saturation.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_adds_epu8.html" title='core::arch::x86::_mm_adds_epu8 fn'>_mm_adds_epu8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Adds packed unsigned 8-bit integers in <code>a</code> and <code>b</code> using saturation.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_adds_epu16.html" title='core::arch::x86::_mm_adds_epu16 fn'>_mm_adds_epu16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Adds packed unsigned 16-bit integers in <code>a</code> and <code>b</code> using saturation.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_addsub_pd.html" title='core::arch::x86::_mm_addsub_pd fn'>_mm_addsub_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse3</code></span><p>Alternatively add and subtract packed double-precision (64-bit)
floating-point elements in <code>a</code> to/from packed elements in <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_addsub_ps.html" title='core::arch::x86::_mm_addsub_ps fn'>_mm_addsub_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse3</code></span><p>Alternatively add and subtract packed single-precision (32-bit)
floating-point elements in <code>a</code> to/from packed elements in <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_aesdec_si128.html" title='core::arch::x86::_mm_aesdec_si128 fn'>_mm_aesdec_si128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>aes</code></span><p>Performs one round of an AES decryption flow on data (state) in <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_aesdeclast_si128.html" title='core::arch::x86::_mm_aesdeclast_si128 fn'>_mm_aesdeclast_si128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>aes</code></span><p>Performs the last round of an AES decryption flow on data (state) in <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_aesenc_si128.html" title='core::arch::x86::_mm_aesenc_si128 fn'>_mm_aesenc_si128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>aes</code></span><p>Performs one round of an AES encryption flow on data (state) in <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_aesenclast_si128.html" title='core::arch::x86::_mm_aesenclast_si128 fn'>_mm_aesenclast_si128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>aes</code></span><p>Performs the last round of an AES encryption flow on data (state) in <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_aesimc_si128.html" title='core::arch::x86::_mm_aesimc_si128 fn'>_mm_aesimc_si128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>aes</code></span><p>Performs the <code>InvMixColumns</code> transformation on <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_aeskeygenassist_si128.html" title='core::arch::x86::_mm_aeskeygenassist_si128 fn'>_mm_aeskeygenassist_si128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>aes</code></span><p>Assist in expanding the AES cipher key.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_alignr_epi8.html" title='core::arch::x86::_mm_alignr_epi8 fn'>_mm_alignr_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>ssse3</code></span><p>Concatenate 16-byte blocks in <code>a</code> and <code>b</code> into a 32-byte temporary result,
shift the result right by <code>n</code> bytes, and returns the low 16 bytes.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_and_pd.html" title='core::arch::x86::_mm_and_pd fn'>_mm_and_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Computes the bitwise AND of packed double-precision (64-bit) floating-point
elements in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_and_ps.html" title='core::arch::x86::_mm_and_ps fn'>_mm_and_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Bitwise AND of packed single-precision (32-bit) floating-point elements.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_and_si128.html" title='core::arch::x86::_mm_and_si128 fn'>_mm_and_si128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Computes the bitwise AND of 128 bits (representing integer data) in <code>a</code> and
<code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_andnot_pd.html" title='core::arch::x86::_mm_andnot_pd fn'>_mm_andnot_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Computes the bitwise NOT of <code>a</code> and then AND with <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_andnot_ps.html" title='core::arch::x86::_mm_andnot_ps fn'>_mm_andnot_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Bitwise AND-NOT of packed single-precision (32-bit) floating-point
elements.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_andnot_si128.html" title='core::arch::x86::_mm_andnot_si128 fn'>_mm_andnot_si128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Computes the bitwise NOT of 128 bits (representing integer data) in <code>a</code> and
then AND with <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_avg_epu8.html" title='core::arch::x86::_mm_avg_epu8 fn'>_mm_avg_epu8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Averages packed unsigned 8-bit integers in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_avg_epu16.html" title='core::arch::x86::_mm_avg_epu16 fn'>_mm_avg_epu16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Averages packed unsigned 16-bit integers in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_blend_epi16.html" title='core::arch::x86::_mm_blend_epi16 fn'>_mm_blend_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Blend packed 16-bit integers from <code>a</code> and <code>b</code> using the mask <code>imm8</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_blend_epi32.html" title='core::arch::x86::_mm_blend_epi32 fn'>_mm_blend_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Blends packed 32-bit integers from <code>a</code> and <code>b</code> using control mask <code>imm8</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_blend_pd.html" title='core::arch::x86::_mm_blend_pd fn'>_mm_blend_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Blend packed double-precision (64-bit) floating-point elements from <code>a</code>
and <code>b</code> using control mask <code>imm2</code></p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_blend_ps.html" title='core::arch::x86::_mm_blend_ps fn'>_mm_blend_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Blend packed single-precision (32-bit) floating-point elements from <code>a</code>
and <code>b</code> using mask <code>imm4</code></p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_blendv_epi8.html" title='core::arch::x86::_mm_blendv_epi8 fn'>_mm_blendv_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Blend packed 8-bit integers from <code>a</code> and <code>b</code> using <code>mask</code></p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_blendv_pd.html" title='core::arch::x86::_mm_blendv_pd fn'>_mm_blendv_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Blend packed double-precision (64-bit) floating-point elements from <code>a</code>
and <code>b</code> using <code>mask</code></p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_blendv_ps.html" title='core::arch::x86::_mm_blendv_ps fn'>_mm_blendv_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Blend packed single-precision (32-bit) floating-point elements from <code>a</code>
and <code>b</code> using <code>mask</code></p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_broadcast_ss.html" title='core::arch::x86::_mm_broadcast_ss fn'>_mm_broadcast_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Broadcasts a single-precision (32-bit) floating-point element from memory
to all elements of the returned vector.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_broadcastb_epi8.html" title='core::arch::x86::_mm_broadcastb_epi8 fn'>_mm_broadcastb_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Broadcasts the low packed 8-bit integer from <code>a</code> to all elements of
the 128-bit returned value.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_broadcastd_epi32.html" title='core::arch::x86::_mm_broadcastd_epi32 fn'>_mm_broadcastd_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Broadcasts the low packed 32-bit integer from <code>a</code> to all elements of
the 128-bit returned value.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_broadcastq_epi64.html" title='core::arch::x86::_mm_broadcastq_epi64 fn'>_mm_broadcastq_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Broadcasts the low packed 64-bit integer from <code>a</code> to all elements of
the 128-bit returned value.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_broadcastsd_pd.html" title='core::arch::x86::_mm_broadcastsd_pd fn'>_mm_broadcastsd_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Broadcasts the low double-precision (64-bit) floating-point element
from <code>a</code> to all elements of the 128-bit returned value.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_broadcastss_ps.html" title='core::arch::x86::_mm_broadcastss_ps fn'>_mm_broadcastss_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Broadcasts the low single-precision (32-bit) floating-point element
from <code>a</code> to all elements of the 128-bit returned value.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_broadcastw_epi16.html" title='core::arch::x86::_mm_broadcastw_epi16 fn'>_mm_broadcastw_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Broadcasts the low packed 16-bit integer from a to all elements of
the 128-bit returned value</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_bslli_si128.html" title='core::arch::x86::_mm_bslli_si128 fn'>_mm_bslli_si128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Shifts <code>a</code> left by <code>imm8</code> bytes while shifting in zeros.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_bsrli_si128.html" title='core::arch::x86::_mm_bsrli_si128 fn'>_mm_bsrli_si128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Shifts <code>a</code> right by <code>imm8</code> bytes while shifting in zeros.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_castpd_ps.html" title='core::arch::x86::_mm_castpd_ps fn'>_mm_castpd_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Casts a 128-bit floating-point vector of <code>[2 x double]</code> into a 128-bit
floating-point vector of <code>[4 x float]</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_castpd_si128.html" title='core::arch::x86::_mm_castpd_si128 fn'>_mm_castpd_si128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Casts a 128-bit floating-point vector of <code>[2 x double]</code> into a 128-bit
integer vector.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_castps_pd.html" title='core::arch::x86::_mm_castps_pd fn'>_mm_castps_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Casts a 128-bit floating-point vector of <code>[4 x float]</code> into a 128-bit
floating-point vector of <code>[2 x double]</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_castps_si128.html" title='core::arch::x86::_mm_castps_si128 fn'>_mm_castps_si128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Casts a 128-bit floating-point vector of <code>[4 x float]</code> into a 128-bit
integer vector.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_castsi128_pd.html" title='core::arch::x86::_mm_castsi128_pd fn'>_mm_castsi128_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Casts a 128-bit integer vector into a 128-bit floating-point vector
of <code>[2 x double]</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_castsi128_ps.html" title='core::arch::x86::_mm_castsi128_ps fn'>_mm_castsi128_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Casts a 128-bit integer vector into a 128-bit floating-point vector
of <code>[4 x float]</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_ceil_pd.html" title='core::arch::x86::_mm_ceil_pd fn'>_mm_ceil_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Round the packed double-precision (64-bit) floating-point elements in <code>a</code>
up to an integer value, and stores the results as packed double-precision
floating-point elements.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_ceil_ps.html" title='core::arch::x86::_mm_ceil_ps fn'>_mm_ceil_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Round the packed single-precision (32-bit) floating-point elements in <code>a</code>
up to an integer value, and stores the results as packed single-precision
floating-point elements.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_ceil_sd.html" title='core::arch::x86::_mm_ceil_sd fn'>_mm_ceil_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Round the lower double-precision (64-bit) floating-point element in <code>b</code>
up to an integer value, store the result as a double-precision
floating-point element in the lower element of the intrisic result,
and copies the upper element from <code>a</code> to the upper element
of the intrinsic result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_ceil_ss.html" title='core::arch::x86::_mm_ceil_ss fn'>_mm_ceil_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Round the lower single-precision (32-bit) floating-point element in <code>b</code>
up to an integer value, store the result as a single-precision
floating-point element in the lower element of the intrinsic result,
and copies the upper 3 packed elements from <code>a</code> to the upper elements
of the intrinsic result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_clflush.html" title='core::arch::x86::_mm_clflush fn'>_mm_clflush</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Invalidates and flushes the cache line that contains <code>p</code> from all levels of
the cache hierarchy.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_clmulepi64_si128.html" title='core::arch::x86::_mm_clmulepi64_si128 fn'>_mm_clmulepi64_si128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>pclmulqdq</code></span><p>Performs a carry-less multiplication of two 64-bit polynomials over the
finite field GF(2^k).</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmp_pd.html" title='core::arch::x86::_mm_cmp_pd fn'>_mm_cmp_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx,sse2</code></span><p>Compares packed double-precision (64-bit) floating-point
elements in <code>a</code> and <code>b</code> based on the comparison operand
specified by <code>imm8</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmp_ps.html" title='core::arch::x86::_mm_cmp_ps fn'>_mm_cmp_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx,sse</code></span><p>Compares packed single-precision (32-bit) floating-point
elements in <code>a</code> and <code>b</code> based on the comparison operand
specified by <code>imm8</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmp_sd.html" title='core::arch::x86::_mm_cmp_sd fn'>_mm_cmp_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx,sse2</code></span><p>Compares the lower double-precision (64-bit) floating-point element in
<code>a</code> and <code>b</code> based on the comparison operand specified by <code>imm8</code>,
store the result in the lower element of returned vector,
and copies the upper element from <code>a</code> to the upper element of returned
vector.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmp_ss.html" title='core::arch::x86::_mm_cmp_ss fn'>_mm_cmp_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx,sse</code></span><p>Compares the lower single-precision (32-bit) floating-point element in
<code>a</code> and <code>b</code> based on the comparison operand specified by <code>imm8</code>,
store the result in the lower element of returned vector,
and copies the upper 3 packed elements from <code>a</code> to the upper elements of
returned vector.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpeq_epi8.html" title='core::arch::x86::_mm_cmpeq_epi8 fn'>_mm_cmpeq_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Compares packed 8-bit integers in <code>a</code> and <code>b</code> for equality.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpeq_epi16.html" title='core::arch::x86::_mm_cmpeq_epi16 fn'>_mm_cmpeq_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Compares packed 16-bit integers in <code>a</code> and <code>b</code> for equality.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpeq_epi32.html" title='core::arch::x86::_mm_cmpeq_epi32 fn'>_mm_cmpeq_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Compares packed 32-bit integers in <code>a</code> and <code>b</code> for equality.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpeq_epi64.html" title='core::arch::x86::_mm_cmpeq_epi64 fn'>_mm_cmpeq_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Compares packed 64-bit integers in <code>a</code> and <code>b</code> for equality</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpeq_pd.html" title='core::arch::x86::_mm_cmpeq_pd fn'>_mm_cmpeq_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Compares corresponding elements in <code>a</code> and <code>b</code> for equality.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpeq_ps.html" title='core::arch::x86::_mm_cmpeq_ps fn'>_mm_cmpeq_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Compares each of the four floats in <code>a</code> to the corresponding element in <code>b</code>.
The result in the output vector will be <code>0xffffffff</code> if the input elements
were equal, or <code>0</code> otherwise.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpeq_sd.html" title='core::arch::x86::_mm_cmpeq_sd fn'>_mm_cmpeq_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Returns a new vector with the low element of <code>a</code> replaced by the equality
comparison of the lower elements of <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpeq_ss.html" title='core::arch::x86::_mm_cmpeq_ss fn'>_mm_cmpeq_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Compares the lowest <code>f32</code> of both inputs for equality. The lowest 32 bits of
the result will be <code>0xffffffff</code> if the two inputs are equal, or <code>0</code>
otherwise. The upper 96 bits of the result are the upper 96 bits of <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpestra.html" title='core::arch::x86::_mm_cmpestra fn'>_mm_cmpestra</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.2</code></span><p>Compares packed strings in <code>a</code> and <code>b</code> with lengths <code>la</code> and <code>lb</code>
using the control in <code>imm8</code>, and return <code>1</code> if <code>b</code> did not
contain a null character and the resulting mask was zero, and <code>0</code>
otherwise.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpestrc.html" title='core::arch::x86::_mm_cmpestrc fn'>_mm_cmpestrc</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.2</code></span><p>Compares packed strings in <code>a</code> and <code>b</code> with lengths <code>la</code> and <code>lb</code>
using the control in <code>imm8</code>, and return <code>1</code> if the resulting mask
was non-zero, and <code>0</code> otherwise.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpestri.html" title='core::arch::x86::_mm_cmpestri fn'>_mm_cmpestri</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.2</code></span><p>Compares packed strings <code>a</code> and <code>b</code> with lengths <code>la</code> and <code>lb</code> using the
control in <code>imm8</code> and return the generated index. Similar to
<a href="fn._mm_cmpistri.html"><code>_mm_cmpistri</code></a> with the exception that <a href="fn._mm_cmpistri.html"><code>_mm_cmpistri</code></a> implicitly
determines the length of <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpestrm.html" title='core::arch::x86::_mm_cmpestrm fn'>_mm_cmpestrm</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.2</code></span><p>Compares packed strings in <code>a</code> and <code>b</code> with lengths <code>la</code> and <code>lb</code>
using the control in <code>imm8</code>, and return the generated mask.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpestro.html" title='core::arch::x86::_mm_cmpestro fn'>_mm_cmpestro</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.2</code></span><p>Compares packed strings in <code>a</code> and <code>b</code> with lengths <code>la</code> and <code>lb</code>
using the control in <code>imm8</code>, and return bit <code>0</code> of the resulting
bit mask.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpestrs.html" title='core::arch::x86::_mm_cmpestrs fn'>_mm_cmpestrs</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.2</code></span><p>Compares packed strings in <code>a</code> and <code>b</code> with lengths <code>la</code> and <code>lb</code>
using the control in <code>imm8</code>, and return <code>1</code> if any character in
a was null, and <code>0</code> otherwise.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpestrz.html" title='core::arch::x86::_mm_cmpestrz fn'>_mm_cmpestrz</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.2</code></span><p>Compares packed strings in <code>a</code> and <code>b</code> with lengths <code>la</code> and <code>lb</code>
using the control in <code>imm8</code>, and return <code>1</code> if any character in
<code>b</code> was null, and <code>0</code> otherwise.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpge_pd.html" title='core::arch::x86::_mm_cmpge_pd fn'>_mm_cmpge_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Compares corresponding elements in <code>a</code> and <code>b</code> for greater-than-or-equal.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpge_ps.html" title='core::arch::x86::_mm_cmpge_ps fn'>_mm_cmpge_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Compares each of the four floats in <code>a</code> to the corresponding element in <code>b</code>.
The result in the output vector will be <code>0xffffffff</code> if the input element
in <code>a</code> is greater than or equal to the corresponding element in <code>b</code>, or <code>0</code>
otherwise.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpge_sd.html" title='core::arch::x86::_mm_cmpge_sd fn'>_mm_cmpge_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Returns a new vector with the low element of <code>a</code> replaced by the
greater-than-or-equal comparison of the lower elements of <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpge_ss.html" title='core::arch::x86::_mm_cmpge_ss fn'>_mm_cmpge_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Compares the lowest <code>f32</code> of both inputs for greater than or equal. The
lowest 32 bits of the result will be <code>0xffffffff</code> if <code>a.extract(0)</code> is
greater than or equal <code>b.extract(0)</code>, or <code>0</code> otherwise. The upper 96 bits
of the result are the upper 96 bits of <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpgt_epi8.html" title='core::arch::x86::_mm_cmpgt_epi8 fn'>_mm_cmpgt_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Compares packed 8-bit integers in <code>a</code> and <code>b</code> for greater-than.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpgt_epi16.html" title='core::arch::x86::_mm_cmpgt_epi16 fn'>_mm_cmpgt_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Compares packed 16-bit integers in <code>a</code> and <code>b</code> for greater-than.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpgt_epi32.html" title='core::arch::x86::_mm_cmpgt_epi32 fn'>_mm_cmpgt_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Compares packed 32-bit integers in <code>a</code> and <code>b</code> for greater-than.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpgt_epi64.html" title='core::arch::x86::_mm_cmpgt_epi64 fn'>_mm_cmpgt_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.2</code></span><p>Compares packed 64-bit integers in <code>a</code> and <code>b</code> for greater-than,
return the results.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpgt_pd.html" title='core::arch::x86::_mm_cmpgt_pd fn'>_mm_cmpgt_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Compares corresponding elements in <code>a</code> and <code>b</code> for greater-than.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpgt_ps.html" title='core::arch::x86::_mm_cmpgt_ps fn'>_mm_cmpgt_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Compares each of the four floats in <code>a</code> to the corresponding element in <code>b</code>.
The result in the output vector will be <code>0xffffffff</code> if the input element
in <code>a</code> is greater than the corresponding element in <code>b</code>, or <code>0</code> otherwise.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpgt_sd.html" title='core::arch::x86::_mm_cmpgt_sd fn'>_mm_cmpgt_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Returns a new vector with the low element of <code>a</code> replaced by the
greater-than comparison of the lower elements of <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpgt_ss.html" title='core::arch::x86::_mm_cmpgt_ss fn'>_mm_cmpgt_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Compares the lowest <code>f32</code> of both inputs for greater than. The lowest 32
bits of the result will be <code>0xffffffff</code> if <code>a.extract(0)</code> is greater
than <code>b.extract(0)</code>, or <code>0</code> otherwise. The upper 96 bits of the result
are the upper 96 bits of <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpistra.html" title='core::arch::x86::_mm_cmpistra fn'>_mm_cmpistra</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.2</code></span><p>Compares packed strings with implicit lengths in <code>a</code> and <code>b</code> using the
control in <code>imm8</code>, and return <code>1</code> if <code>b</code> did not contain a null
character and the resulting mask was zero, and <code>0</code> otherwise.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpistrc.html" title='core::arch::x86::_mm_cmpistrc fn'>_mm_cmpistrc</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.2</code></span><p>Compares packed strings with implicit lengths in <code>a</code> and <code>b</code> using the
control in <code>imm8</code>, and return <code>1</code> if the resulting mask was non-zero,
and <code>0</code> otherwise.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpistri.html" title='core::arch::x86::_mm_cmpistri fn'>_mm_cmpistri</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.2</code></span><p>Compares packed strings with implicit lengths in <code>a</code> and <code>b</code> using the
control in <code>imm8</code> and return the generated index. Similar to
<a href="fn._mm_cmpestri.html"><code>_mm_cmpestri</code></a> with the exception that <a href="fn._mm_cmpestri.html"><code>_mm_cmpestri</code></a> requires the
lengths of <code>a</code> and <code>b</code> to be explicitly specified.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpistrm.html" title='core::arch::x86::_mm_cmpistrm fn'>_mm_cmpistrm</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.2</code></span><p>Compares packed strings with implicit lengths in <code>a</code> and <code>b</code> using the
control in <code>imm8</code>, and return the generated mask.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpistro.html" title='core::arch::x86::_mm_cmpistro fn'>_mm_cmpistro</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.2</code></span><p>Compares packed strings with implicit lengths in <code>a</code> and <code>b</code> using the
control in <code>imm8</code>, and return bit <code>0</code> of the resulting bit mask.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpistrs.html" title='core::arch::x86::_mm_cmpistrs fn'>_mm_cmpistrs</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.2</code></span><p>Compares packed strings with implicit lengths in <code>a</code> and <code>b</code> using the
control in <code>imm8</code>, and returns <code>1</code> if any character in <code>a</code> was null,
and <code>0</code> otherwise.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpistrz.html" title='core::arch::x86::_mm_cmpistrz fn'>_mm_cmpistrz</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.2</code></span><p>Compares packed strings with implicit lengths in <code>a</code> and <code>b</code> using the
control in <code>imm8</code>, and return <code>1</code> if any character in <code>b</code> was null.
and <code>0</code> otherwise.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmple_pd.html" title='core::arch::x86::_mm_cmple_pd fn'>_mm_cmple_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Compares corresponding elements in <code>a</code> and <code>b</code> for less-than-or-equal</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmple_ps.html" title='core::arch::x86::_mm_cmple_ps fn'>_mm_cmple_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Compares each of the four floats in <code>a</code> to the corresponding element in <code>b</code>.
The result in the output vector will be <code>0xffffffff</code> if the input element
in <code>a</code> is less than or equal to the corresponding element in <code>b</code>, or <code>0</code>
otherwise.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmple_sd.html" title='core::arch::x86::_mm_cmple_sd fn'>_mm_cmple_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Returns a new vector with the low element of <code>a</code> replaced by the
less-than-or-equal comparison of the lower elements of <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmple_ss.html" title='core::arch::x86::_mm_cmple_ss fn'>_mm_cmple_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Compares the lowest <code>f32</code> of both inputs for less than or equal. The lowest
32 bits of the result will be <code>0xffffffff</code> if <code>a.extract(0)</code> is less than
or equal <code>b.extract(0)</code>, or <code>0</code> otherwise. The upper 96 bits of the result
are the upper 96 bits of <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmplt_epi8.html" title='core::arch::x86::_mm_cmplt_epi8 fn'>_mm_cmplt_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Compares packed 8-bit integers in <code>a</code> and <code>b</code> for less-than.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmplt_epi16.html" title='core::arch::x86::_mm_cmplt_epi16 fn'>_mm_cmplt_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Compares packed 16-bit integers in <code>a</code> and <code>b</code> for less-than.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmplt_epi32.html" title='core::arch::x86::_mm_cmplt_epi32 fn'>_mm_cmplt_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Compares packed 32-bit integers in <code>a</code> and <code>b</code> for less-than.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmplt_pd.html" title='core::arch::x86::_mm_cmplt_pd fn'>_mm_cmplt_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Compares corresponding elements in <code>a</code> and <code>b</code> for less-than.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmplt_ps.html" title='core::arch::x86::_mm_cmplt_ps fn'>_mm_cmplt_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Compares each of the four floats in <code>a</code> to the corresponding element in <code>b</code>.
The result in the output vector will be <code>0xffffffff</code> if the input element
in <code>a</code> is less than the corresponding element in <code>b</code>, or <code>0</code> otherwise.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmplt_sd.html" title='core::arch::x86::_mm_cmplt_sd fn'>_mm_cmplt_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Returns a new vector with the low element of <code>a</code> replaced by the less-than
comparison of the lower elements of <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmplt_ss.html" title='core::arch::x86::_mm_cmplt_ss fn'>_mm_cmplt_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Compares the lowest <code>f32</code> of both inputs for less than. The lowest 32 bits
of the result will be <code>0xffffffff</code> if <code>a.extract(0)</code> is less than
<code>b.extract(0)</code>, or <code>0</code> otherwise. The upper 96 bits of the result are the
upper 96 bits of <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpneq_pd.html" title='core::arch::x86::_mm_cmpneq_pd fn'>_mm_cmpneq_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Compares corresponding elements in <code>a</code> and <code>b</code> for not-equal.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpneq_ps.html" title='core::arch::x86::_mm_cmpneq_ps fn'>_mm_cmpneq_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Compares each of the four floats in <code>a</code> to the corresponding element in <code>b</code>.
The result in the output vector will be <code>0xffffffff</code> if the input elements
are <strong>not</strong> equal, or <code>0</code> otherwise.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpneq_sd.html" title='core::arch::x86::_mm_cmpneq_sd fn'>_mm_cmpneq_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Returns a new vector with the low element of <code>a</code> replaced by the not-equal
comparison of the lower elements of <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpneq_ss.html" title='core::arch::x86::_mm_cmpneq_ss fn'>_mm_cmpneq_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Compares the lowest <code>f32</code> of both inputs for inequality. The lowest 32 bits
of the result will be <code>0xffffffff</code> if <code>a.extract(0)</code> is not equal to
<code>b.extract(0)</code>, or <code>0</code> otherwise. The upper 96 bits of the result are the
upper 96 bits of <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpnge_pd.html" title='core::arch::x86::_mm_cmpnge_pd fn'>_mm_cmpnge_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Compares corresponding elements in <code>a</code> and <code>b</code> for
not-greater-than-or-equal.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpnge_ps.html" title='core::arch::x86::_mm_cmpnge_ps fn'>_mm_cmpnge_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Compares each of the four floats in <code>a</code> to the corresponding element in <code>b</code>.
The result in the output vector will be <code>0xffffffff</code> if the input element
in <code>a</code> is <strong>not</strong> greater than or equal to the corresponding element in <code>b</code>,
or <code>0</code> otherwise.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpnge_sd.html" title='core::arch::x86::_mm_cmpnge_sd fn'>_mm_cmpnge_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Returns a new vector with the low element of <code>a</code> replaced by the
not-greater-than-or-equal comparison of the lower elements of <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpnge_ss.html" title='core::arch::x86::_mm_cmpnge_ss fn'>_mm_cmpnge_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Compares the lowest <code>f32</code> of both inputs for not-greater-than-or-equal. The
lowest 32 bits of the result will be <code>0xffffffff</code> if <code>a.extract(0)</code> is not
greater than or equal to <code>b.extract(0)</code>, or <code>0</code> otherwise. The upper 96
bits of the result are the upper 96 bits of <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpngt_pd.html" title='core::arch::x86::_mm_cmpngt_pd fn'>_mm_cmpngt_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Compares corresponding elements in <code>a</code> and <code>b</code> for not-greater-than.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpngt_ps.html" title='core::arch::x86::_mm_cmpngt_ps fn'>_mm_cmpngt_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Compares each of the four floats in <code>a</code> to the corresponding element in <code>b</code>.
The result in the output vector will be <code>0xffffffff</code> if the input element
in <code>a</code> is <strong>not</strong> greater than the corresponding element in <code>b</code>, or <code>0</code>
otherwise.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpngt_sd.html" title='core::arch::x86::_mm_cmpngt_sd fn'>_mm_cmpngt_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Returns a new vector with the low element of <code>a</code> replaced by the
not-greater-than comparison of the lower elements of <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpngt_ss.html" title='core::arch::x86::_mm_cmpngt_ss fn'>_mm_cmpngt_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Compares the lowest <code>f32</code> of both inputs for not-greater-than. The lowest 32
bits of the result will be <code>0xffffffff</code> if <code>a.extract(0)</code> is not greater
than <code>b.extract(0)</code>, or <code>0</code> otherwise. The upper 96 bits of the result are
the upper 96 bits of <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpnle_pd.html" title='core::arch::x86::_mm_cmpnle_pd fn'>_mm_cmpnle_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Compares corresponding elements in <code>a</code> and <code>b</code> for not-less-than-or-equal.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpnle_ps.html" title='core::arch::x86::_mm_cmpnle_ps fn'>_mm_cmpnle_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Compares each of the four floats in <code>a</code> to the corresponding element in <code>b</code>.
The result in the output vector will be <code>0xffffffff</code> if the input element
in <code>a</code> is <strong>not</strong> less than or equal to the corresponding element in <code>b</code>, or
<code>0</code> otherwise.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpnle_sd.html" title='core::arch::x86::_mm_cmpnle_sd fn'>_mm_cmpnle_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Returns a new vector with the low element of <code>a</code> replaced by the
not-less-than-or-equal comparison of the lower elements of <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpnle_ss.html" title='core::arch::x86::_mm_cmpnle_ss fn'>_mm_cmpnle_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Compares the lowest <code>f32</code> of both inputs for not-less-than-or-equal. The
lowest 32 bits of the result will be <code>0xffffffff</code> if <code>a.extract(0)</code> is not
less than or equal to <code>b.extract(0)</code>, or <code>0</code> otherwise. The upper 96 bits
of the result are the upper 96 bits of <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpnlt_pd.html" title='core::arch::x86::_mm_cmpnlt_pd fn'>_mm_cmpnlt_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Compares corresponding elements in <code>a</code> and <code>b</code> for not-less-than.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpnlt_ps.html" title='core::arch::x86::_mm_cmpnlt_ps fn'>_mm_cmpnlt_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Compares each of the four floats in <code>a</code> to the corresponding element in <code>b</code>.
The result in the output vector will be <code>0xffffffff</code> if the input element
in <code>a</code> is <strong>not</strong> less than the corresponding element in <code>b</code>, or <code>0</code>
otherwise.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpnlt_sd.html" title='core::arch::x86::_mm_cmpnlt_sd fn'>_mm_cmpnlt_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Returns a new vector with the low element of <code>a</code> replaced by the
not-less-than comparison of the lower elements of <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpnlt_ss.html" title='core::arch::x86::_mm_cmpnlt_ss fn'>_mm_cmpnlt_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Compares the lowest <code>f32</code> of both inputs for not-less-than. The lowest 32
bits of the result will be <code>0xffffffff</code> if <code>a.extract(0)</code> is not less than
<code>b.extract(0)</code>, or <code>0</code> otherwise. The upper 96 bits of the result are the
upper 96 bits of <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpord_pd.html" title='core::arch::x86::_mm_cmpord_pd fn'>_mm_cmpord_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Compares corresponding elements in <code>a</code> and <code>b</code> to see if neither is <code>NaN</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpord_ps.html" title='core::arch::x86::_mm_cmpord_ps fn'>_mm_cmpord_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Compares each of the four floats in <code>a</code> to the corresponding element in <code>b</code>.
Returns four floats that have one of two possible bit patterns. The element
in the output vector will be <code>0xffffffff</code> if the input elements in <code>a</code> and
<code>b</code> are ordered (i.e., neither of them is a NaN), or 0 otherwise.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpord_sd.html" title='core::arch::x86::_mm_cmpord_sd fn'>_mm_cmpord_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Returns a new vector with the low element of <code>a</code> replaced by the result
of comparing both of the lower elements of <code>a</code> and <code>b</code> to <code>NaN</code>. If
neither are equal to <code>NaN</code> then <code>0xFFFFFFFFFFFFFFFF</code> is used and <code>0</code>
otherwise.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpord_ss.html" title='core::arch::x86::_mm_cmpord_ss fn'>_mm_cmpord_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Checks if the lowest <code>f32</code> of both inputs are ordered. The lowest 32 bits of
the result will be <code>0xffffffff</code> if neither of <code>a.extract(0)</code> or
<code>b.extract(0)</code> is a NaN, or <code>0</code> otherwise. The upper 96 bits of the result
are the upper 96 bits of <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpunord_pd.html" title='core::arch::x86::_mm_cmpunord_pd fn'>_mm_cmpunord_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Compares corresponding elements in <code>a</code> and <code>b</code> to see if either is <code>NaN</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpunord_ps.html" title='core::arch::x86::_mm_cmpunord_ps fn'>_mm_cmpunord_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Compares each of the four floats in <code>a</code> to the corresponding element in <code>b</code>.
Returns four floats that have one of two possible bit patterns. The element
in the output vector will be <code>0xffffffff</code> if the input elements in <code>a</code> and
<code>b</code> are unordered (i.e., at least on of them is a NaN), or 0 otherwise.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpunord_sd.html" title='core::arch::x86::_mm_cmpunord_sd fn'>_mm_cmpunord_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Returns a new vector with the low element of <code>a</code> replaced by the result of
comparing both of the lower elements of <code>a</code> and <code>b</code> to <code>NaN</code>. If either is
equal to <code>NaN</code> then <code>0xFFFFFFFFFFFFFFFF</code> is used and <code>0</code> otherwise.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cmpunord_ss.html" title='core::arch::x86::_mm_cmpunord_ss fn'>_mm_cmpunord_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Checks if the lowest <code>f32</code> of both inputs are unordered. The lowest 32 bits
of the result will be <code>0xffffffff</code> if any of <code>a.extract(0)</code> or
<code>b.extract(0)</code> is a NaN, or <code>0</code> otherwise. The upper 96 bits of the result
are the upper 96 bits of <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_comieq_sd.html" title='core::arch::x86::_mm_comieq_sd fn'>_mm_comieq_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Compares the lower element of <code>a</code> and <code>b</code> for equality.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_comieq_ss.html" title='core::arch::x86::_mm_comieq_ss fn'>_mm_comieq_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Compares two 32-bit floats from the low-order bits of <code>a</code> and <code>b</code>. Returns
<code>1</code> if they are equal, or <code>0</code> otherwise.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_comige_sd.html" title='core::arch::x86::_mm_comige_sd fn'>_mm_comige_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Compares the lower element of <code>a</code> and <code>b</code> for greater-than-or-equal.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_comige_ss.html" title='core::arch::x86::_mm_comige_ss fn'>_mm_comige_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Compares two 32-bit floats from the low-order bits of <code>a</code> and <code>b</code>. Returns
<code>1</code> if the value from <code>a</code> is greater than or equal to the one from <code>b</code>, or
<code>0</code> otherwise.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_comigt_sd.html" title='core::arch::x86::_mm_comigt_sd fn'>_mm_comigt_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Compares the lower element of <code>a</code> and <code>b</code> for greater-than.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_comigt_ss.html" title='core::arch::x86::_mm_comigt_ss fn'>_mm_comigt_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Compares two 32-bit floats from the low-order bits of <code>a</code> and <code>b</code>. Returns
<code>1</code> if the value from <code>a</code> is greater than the one from <code>b</code>, or <code>0</code>
otherwise.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_comile_sd.html" title='core::arch::x86::_mm_comile_sd fn'>_mm_comile_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Compares the lower element of <code>a</code> and <code>b</code> for less-than-or-equal.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_comile_ss.html" title='core::arch::x86::_mm_comile_ss fn'>_mm_comile_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Compares two 32-bit floats from the low-order bits of <code>a</code> and <code>b</code>. Returns
<code>1</code> if the value from <code>a</code> is less than or equal to the one from <code>b</code>, or <code>0</code>
otherwise.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_comilt_sd.html" title='core::arch::x86::_mm_comilt_sd fn'>_mm_comilt_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Compares the lower element of <code>a</code> and <code>b</code> for less-than.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_comilt_ss.html" title='core::arch::x86::_mm_comilt_ss fn'>_mm_comilt_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Compares two 32-bit floats from the low-order bits of <code>a</code> and <code>b</code>. Returns
<code>1</code> if the value from <code>a</code> is less than the one from <code>b</code>, or <code>0</code> otherwise.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_comineq_sd.html" title='core::arch::x86::_mm_comineq_sd fn'>_mm_comineq_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Compares the lower element of <code>a</code> and <code>b</code> for not-equal.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_comineq_ss.html" title='core::arch::x86::_mm_comineq_ss fn'>_mm_comineq_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Compares two 32-bit floats from the low-order bits of <code>a</code> and <code>b</code>. Returns
<code>1</code> if they are <strong>not</strong> equal, or <code>0</code> otherwise.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_crc32_u8.html" title='core::arch::x86::_mm_crc32_u8 fn'>_mm_crc32_u8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.2</code></span><p>Starting with the initial value in <code>crc</code>, return the accumulated
CRC32 value for unsigned 8-bit integer <code>v</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_crc32_u16.html" title='core::arch::x86::_mm_crc32_u16 fn'>_mm_crc32_u16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.2</code></span><p>Starting with the initial value in <code>crc</code>, return the accumulated
CRC32 value for unsigned 16-bit integer <code>v</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_crc32_u32.html" title='core::arch::x86::_mm_crc32_u32 fn'>_mm_crc32_u32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.2</code></span><p>Starting with the initial value in <code>crc</code>, return the accumulated
CRC32 value for unsigned 32-bit integer <code>v</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cvt_si2ss.html" title='core::arch::x86::_mm_cvt_si2ss fn'>_mm_cvt_si2ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Alias for <a href="fn._mm_cvtsi32_ss.html"><code>_mm_cvtsi32_ss</code></a>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cvt_ss2si.html" title='core::arch::x86::_mm_cvt_ss2si fn'>_mm_cvt_ss2si</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Alias for <a href="fn._mm_cvtss_si32.html"><code>_mm_cvtss_si32</code></a>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cvtepi32_pd.html" title='core::arch::x86::_mm_cvtepi32_pd fn'>_mm_cvtepi32_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Converts the lower two packed 32-bit integers in <code>a</code> to packed
double-precision (64-bit) floating-point elements.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cvtepi32_ps.html" title='core::arch::x86::_mm_cvtepi32_ps fn'>_mm_cvtepi32_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Converts packed 32-bit integers in <code>a</code> to packed single-precision (32-bit)
floating-point elements.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cvtepi16_epi32.html" title='core::arch::x86::_mm_cvtepi16_epi32 fn'>_mm_cvtepi16_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Sign extend packed 16-bit integers in <code>a</code> to packed 32-bit integers</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cvtepi16_epi64.html" title='core::arch::x86::_mm_cvtepi16_epi64 fn'>_mm_cvtepi16_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Sign extend packed 16-bit integers in <code>a</code> to packed 64-bit integers</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cvtepi32_epi64.html" title='core::arch::x86::_mm_cvtepi32_epi64 fn'>_mm_cvtepi32_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Sign extend packed 32-bit integers in <code>a</code> to packed 64-bit integers</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cvtepi8_epi16.html" title='core::arch::x86::_mm_cvtepi8_epi16 fn'>_mm_cvtepi8_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Sign extend packed 8-bit integers in <code>a</code> to packed 16-bit integers</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cvtepi8_epi32.html" title='core::arch::x86::_mm_cvtepi8_epi32 fn'>_mm_cvtepi8_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Sign extend packed 8-bit integers in <code>a</code> to packed 32-bit integers</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cvtepi8_epi64.html" title='core::arch::x86::_mm_cvtepi8_epi64 fn'>_mm_cvtepi8_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Sign extend packed 8-bit integers in the low 8 bytes of <code>a</code> to packed
64-bit integers</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cvtepu16_epi32.html" title='core::arch::x86::_mm_cvtepu16_epi32 fn'>_mm_cvtepu16_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Zeroes extend packed unsigned 16-bit integers in <code>a</code>
to packed 32-bit integers</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cvtepu16_epi64.html" title='core::arch::x86::_mm_cvtepu16_epi64 fn'>_mm_cvtepu16_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Zeroes extend packed unsigned 16-bit integers in <code>a</code>
to packed 64-bit integers</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cvtepu32_epi64.html" title='core::arch::x86::_mm_cvtepu32_epi64 fn'>_mm_cvtepu32_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Zeroes extend packed unsigned 32-bit integers in <code>a</code>
to packed 64-bit integers</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cvtepu8_epi16.html" title='core::arch::x86::_mm_cvtepu8_epi16 fn'>_mm_cvtepu8_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Zeroes extend packed unsigned 8-bit integers in <code>a</code> to packed 16-bit integers</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cvtepu8_epi32.html" title='core::arch::x86::_mm_cvtepu8_epi32 fn'>_mm_cvtepu8_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Zeroes extend packed unsigned 8-bit integers in <code>a</code> to packed 32-bit integers</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cvtepu8_epi64.html" title='core::arch::x86::_mm_cvtepu8_epi64 fn'>_mm_cvtepu8_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Zeroes extend packed unsigned 8-bit integers in <code>a</code> to packed 64-bit integers</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cvtpd_epi32.html" title='core::arch::x86::_mm_cvtpd_epi32 fn'>_mm_cvtpd_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Converts packed double-precision (64-bit) floating-point elements in <code>a</code> to
packed 32-bit integers.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cvtpd_ps.html" title='core::arch::x86::_mm_cvtpd_ps fn'>_mm_cvtpd_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Converts packed double-precision (64-bit) floating-point elements in &quot;a&quot; to
packed single-precision (32-bit) floating-point elements</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cvtps_epi32.html" title='core::arch::x86::_mm_cvtps_epi32 fn'>_mm_cvtps_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Converts packed single-precision (32-bit) floating-point elements in <code>a</code>
to packed 32-bit integers.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cvtps_pd.html" title='core::arch::x86::_mm_cvtps_pd fn'>_mm_cvtps_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Converts packed single-precision (32-bit) floating-point elements in <code>a</code> to
packed
double-precision (64-bit) floating-point elements.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cvtsd_f64.html" title='core::arch::x86::_mm_cvtsd_f64 fn'>_mm_cvtsd_f64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Returns the lower double-precision (64-bit) floating-point element of &quot;a&quot;.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cvtsd_si32.html" title='core::arch::x86::_mm_cvtsd_si32 fn'>_mm_cvtsd_si32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Converts the lower double-precision (64-bit) floating-point element in a to
a 32-bit integer.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cvtsd_ss.html" title='core::arch::x86::_mm_cvtsd_ss fn'>_mm_cvtsd_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Converts the lower double-precision (64-bit) floating-point element in <code>b</code>
to a single-precision (32-bit) floating-point element, store the result in
the lower element of the return value, and copies the upper element from <code>a</code>
to the upper element the return value.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cvtsi32_ss.html" title='core::arch::x86::_mm_cvtsi32_ss fn'>_mm_cvtsi32_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Converts a 32 bit integer to a 32 bit float. The result vector is the input
vector <code>a</code> with the lowest 32 bit float replaced by the converted integer.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cvtsi32_sd.html" title='core::arch::x86::_mm_cvtsi32_sd fn'>_mm_cvtsi32_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Returns <code>a</code> with its lower element replaced by <code>b</code> after converting it to
an <code>f64</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cvtsi128_si32.html" title='core::arch::x86::_mm_cvtsi128_si32 fn'>_mm_cvtsi128_si32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Returns the lowest element of <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cvtsi32_si128.html" title='core::arch::x86::_mm_cvtsi32_si128 fn'>_mm_cvtsi32_si128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Returns a vector whose lowest element is <code>a</code> and all higher elements are
<code>0</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cvtss_f32.html" title='core::arch::x86::_mm_cvtss_f32 fn'>_mm_cvtss_f32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Extracts the lowest 32 bit float from the input vector.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cvtss_sd.html" title='core::arch::x86::_mm_cvtss_sd fn'>_mm_cvtss_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Converts the lower single-precision (32-bit) floating-point element in <code>b</code>
to a double-precision (64-bit) floating-point element, store the result in
the lower element of the return value, and copies the upper element from <code>a</code>
to the upper element the return value.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cvtss_si32.html" title='core::arch::x86::_mm_cvtss_si32 fn'>_mm_cvtss_si32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Converts the lowest 32 bit float in the input vector to a 32 bit integer.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cvtt_ss2si.html" title='core::arch::x86::_mm_cvtt_ss2si fn'>_mm_cvtt_ss2si</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Alias for <a href="fn._mm_cvttss_si32.html"><code>_mm_cvttss_si32</code></a>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cvttpd_epi32.html" title='core::arch::x86::_mm_cvttpd_epi32 fn'>_mm_cvttpd_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Converts packed double-precision (64-bit) floating-point elements in <code>a</code> to
packed 32-bit integers with truncation.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cvttps_epi32.html" title='core::arch::x86::_mm_cvttps_epi32 fn'>_mm_cvttps_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Converts packed single-precision (32-bit) floating-point elements in <code>a</code> to
packed 32-bit integers with truncation.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cvttsd_si32.html" title='core::arch::x86::_mm_cvttsd_si32 fn'>_mm_cvttsd_si32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Converts the lower double-precision (64-bit) floating-point element in <code>a</code>
to a 32-bit integer with truncation.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_cvttss_si32.html" title='core::arch::x86::_mm_cvttss_si32 fn'>_mm_cvttss_si32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Converts the lowest 32 bit float in the input vector to a 32 bit integer
with
truncation.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_div_pd.html" title='core::arch::x86::_mm_div_pd fn'>_mm_div_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Divide packed double-precision (64-bit) floating-point elements in <code>a</code> by
packed elements in <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_div_ps.html" title='core::arch::x86::_mm_div_ps fn'>_mm_div_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Divides __m128 vectors.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_div_sd.html" title='core::arch::x86::_mm_div_sd fn'>_mm_div_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Returns a new vector with the low element of <code>a</code> replaced by the result of
diving the lower element of <code>a</code> by the lower element of <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_div_ss.html" title='core::arch::x86::_mm_div_ss fn'>_mm_div_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Divides the first component of <code>b</code> by <code>a</code>, the other components are
copied from <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_dp_pd.html" title='core::arch::x86::_mm_dp_pd fn'>_mm_dp_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Returns the dot product of two __m128d vectors.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_dp_ps.html" title='core::arch::x86::_mm_dp_ps fn'>_mm_dp_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Returns the dot product of two __m128 vectors.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_extract_epi8.html" title='core::arch::x86::_mm_extract_epi8 fn'>_mm_extract_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Extracts an 8-bit integer from <code>a</code>, selected with <code>imm8</code>. Returns a 32-bit
integer containing the zero-extended integer data.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_extract_epi16.html" title='core::arch::x86::_mm_extract_epi16 fn'>_mm_extract_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Returns the <code>imm8</code> element of <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_extract_epi32.html" title='core::arch::x86::_mm_extract_epi32 fn'>_mm_extract_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Extracts an 32-bit integer from <code>a</code> selected with <code>imm8</code></p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_extract_ps.html" title='core::arch::x86::_mm_extract_ps fn'>_mm_extract_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Extracts a single-precision (32-bit) floating-point element from <code>a</code>,
selected with <code>imm8</code></p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_extract_si64.html" title='core::arch::x86::_mm_extract_si64 fn'>_mm_extract_si64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4a</code></span><p>Extracts the bit range specified by <code>y</code> from the lower 64 bits of <code>x</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_floor_pd.html" title='core::arch::x86::_mm_floor_pd fn'>_mm_floor_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Round the packed double-precision (64-bit) floating-point elements in <code>a</code>
down to an integer value, and stores the results as packed double-precision
floating-point elements.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_floor_ps.html" title='core::arch::x86::_mm_floor_ps fn'>_mm_floor_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Round the packed single-precision (32-bit) floating-point elements in <code>a</code>
down to an integer value, and stores the results as packed single-precision
floating-point elements.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_floor_sd.html" title='core::arch::x86::_mm_floor_sd fn'>_mm_floor_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Round the lower double-precision (64-bit) floating-point element in <code>b</code>
down to an integer value, store the result as a double-precision
floating-point element in the lower element of the intrinsic result,
and copies the upper element from <code>a</code> to the upper element of the intrinsic
result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_floor_ss.html" title='core::arch::x86::_mm_floor_ss fn'>_mm_floor_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Round the lower single-precision (32-bit) floating-point element in <code>b</code>
down to an integer value, store the result as a single-precision
floating-point element in the lower element of the intrinsic result,
and copies the upper 3 packed elements from <code>a</code> to the upper elements
of the intrinsic result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_fmadd_pd.html" title='core::arch::x86::_mm_fmadd_pd fn'>_mm_fmadd_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>fma</code></span><p>Multiplies packed double-precision (64-bit) floating-point elements in <code>a</code>
and <code>b</code>, and add the intermediate result to packed elements in <code>c</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_fmadd_ps.html" title='core::arch::x86::_mm_fmadd_ps fn'>_mm_fmadd_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>fma</code></span><p>Multiplies packed single-precision (32-bit) floating-point elements in <code>a</code>
and <code>b</code>, and add the intermediate result to packed elements in <code>c</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_fmadd_sd.html" title='core::arch::x86::_mm_fmadd_sd fn'>_mm_fmadd_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>fma</code></span><p>Multiplies the lower double-precision (64-bit) floating-point elements in
<code>a</code> and <code>b</code>, and add the intermediate result to the lower element in <code>c</code>.
Stores the result in the lower element of the returned value, and copy the
upper element from <code>a</code> to the upper elements of the result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_fmadd_ss.html" title='core::arch::x86::_mm_fmadd_ss fn'>_mm_fmadd_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>fma</code></span><p>Multiplies the lower single-precision (32-bit) floating-point elements in
<code>a</code> and <code>b</code>, and add the intermediate result to the lower element in <code>c</code>.
Stores the result in the lower element of the returned value, and copy the
3 upper elements from <code>a</code> to the upper elements of the result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_fmaddsub_pd.html" title='core::arch::x86::_mm_fmaddsub_pd fn'>_mm_fmaddsub_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>fma</code></span><p>Multiplies packed double-precision (64-bit) floating-point elements in <code>a</code>
and <code>b</code>, and alternatively add and subtract packed elements in <code>c</code> to/from
the intermediate result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_fmaddsub_ps.html" title='core::arch::x86::_mm_fmaddsub_ps fn'>_mm_fmaddsub_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>fma</code></span><p>Multiplies packed single-precision (32-bit) floating-point elements in <code>a</code>
and <code>b</code>, and alternatively add and subtract packed elements in <code>c</code> to/from
the intermediate result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_fmsub_pd.html" title='core::arch::x86::_mm_fmsub_pd fn'>_mm_fmsub_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>fma</code></span><p>Multiplies packed double-precision (64-bit) floating-point elements in <code>a</code>
and <code>b</code>, and subtract packed elements in <code>c</code> from the intermediate result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_fmsub_ps.html" title='core::arch::x86::_mm_fmsub_ps fn'>_mm_fmsub_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>fma</code></span><p>Multiplies packed single-precision (32-bit) floating-point elements in <code>a</code>
and <code>b</code>, and subtract packed elements in <code>c</code> from the intermediate result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_fmsub_sd.html" title='core::arch::x86::_mm_fmsub_sd fn'>_mm_fmsub_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>fma</code></span><p>Multiplies the lower double-precision (64-bit) floating-point elements in
<code>a</code> and <code>b</code>, and subtract the lower element in <code>c</code> from the intermediate
result. Store the result in the lower element of the returned value, and
copy the upper element from <code>a</code> to the upper elements of the result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_fmsub_ss.html" title='core::arch::x86::_mm_fmsub_ss fn'>_mm_fmsub_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>fma</code></span><p>Multiplies the lower single-precision (32-bit) floating-point elements in
<code>a</code> and <code>b</code>,  and subtract the lower element in <code>c</code> from the intermediate
result. Store the result in the lower element of the returned value, and
copy the 3 upper elements from <code>a</code> to the upper elements of the result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_fmsubadd_pd.html" title='core::arch::x86::_mm_fmsubadd_pd fn'>_mm_fmsubadd_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>fma</code></span><p>Multiplies packed double-precision (64-bit) floating-point elements in <code>a</code>
and <code>b</code>, and alternatively subtract and add packed elements in <code>c</code> from/to
the intermediate result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_fmsubadd_ps.html" title='core::arch::x86::_mm_fmsubadd_ps fn'>_mm_fmsubadd_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>fma</code></span><p>Multiplies packed single-precision (32-bit) floating-point elements in <code>a</code>
and <code>b</code>, and alternatively subtract and add packed elements in <code>c</code> from/to
the intermediate result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_fnmadd_pd.html" title='core::arch::x86::_mm_fnmadd_pd fn'>_mm_fnmadd_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>fma</code></span><p>Multiplies packed double-precision (64-bit) floating-point elements in <code>a</code>
and <code>b</code>, and add the negated intermediate result to packed elements in <code>c</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_fnmadd_ps.html" title='core::arch::x86::_mm_fnmadd_ps fn'>_mm_fnmadd_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>fma</code></span><p>Multiplies packed single-precision (32-bit) floating-point elements in <code>a</code>
and <code>b</code>, and add the negated intermediate result to packed elements in <code>c</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_fnmadd_sd.html" title='core::arch::x86::_mm_fnmadd_sd fn'>_mm_fnmadd_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>fma</code></span><p>Multiplies the lower double-precision (64-bit) floating-point elements in
<code>a</code> and <code>b</code>, and add the negated intermediate result to the lower element
in <code>c</code>. Store the result in the lower element of the returned value, and
copy the upper element from <code>a</code> to the upper elements of the result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_fnmadd_ss.html" title='core::arch::x86::_mm_fnmadd_ss fn'>_mm_fnmadd_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>fma</code></span><p>Multiplies the lower single-precision (32-bit) floating-point elements in
<code>a</code> and <code>b</code>, and add the negated intermediate result to the lower element
in <code>c</code>. Store the result in the lower element of the returned value, and
copy the 3 upper elements from <code>a</code> to the upper elements of the result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_fnmsub_pd.html" title='core::arch::x86::_mm_fnmsub_pd fn'>_mm_fnmsub_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>fma</code></span><p>Multiplies packed double-precision (64-bit) floating-point elements in <code>a</code>
and <code>b</code>, and subtract packed elements in <code>c</code> from the negated intermediate
result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_fnmsub_ps.html" title='core::arch::x86::_mm_fnmsub_ps fn'>_mm_fnmsub_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>fma</code></span><p>Multiplies packed single-precision (32-bit) floating-point elements in <code>a</code>
and <code>b</code>, and subtract packed elements in <code>c</code> from the negated intermediate
result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_fnmsub_sd.html" title='core::arch::x86::_mm_fnmsub_sd fn'>_mm_fnmsub_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>fma</code></span><p>Multiplies the lower double-precision (64-bit) floating-point elements in
<code>a</code> and <code>b</code>, and subtract packed elements in <code>c</code> from the negated
intermediate result. Store the result in the lower element of the returned
value, and copy the upper element from <code>a</code> to the upper elements of the
result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_fnmsub_ss.html" title='core::arch::x86::_mm_fnmsub_ss fn'>_mm_fnmsub_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>fma</code></span><p>Multiplies the lower single-precision (32-bit) floating-point elements in
<code>a</code> and <code>b</code>, and subtract packed elements in <code>c</code> from the negated
intermediate result. Store the result in the lower element of the
returned value, and copy the 3 upper elements from <code>a</code> to the upper
elements of the result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_getcsr.html" title='core::arch::x86::_mm_getcsr fn'>_mm_getcsr</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Gets the unsigned 32-bit value of the MXCSR control and status register.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_hadd_epi16.html" title='core::arch::x86::_mm_hadd_epi16 fn'>_mm_hadd_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>ssse3</code></span><p>Horizontally adds the adjacent pairs of values contained in 2 packed
128-bit vectors of <code>[8 x i16]</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_hadd_epi32.html" title='core::arch::x86::_mm_hadd_epi32 fn'>_mm_hadd_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>ssse3</code></span><p>Horizontally adds the adjacent pairs of values contained in 2 packed
128-bit vectors of <code>[4 x i32]</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_hadd_pd.html" title='core::arch::x86::_mm_hadd_pd fn'>_mm_hadd_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse3</code></span><p>Horizontally adds adjacent pairs of double-precision (64-bit)
floating-point elements in <code>a</code> and <code>b</code>, and pack the results.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_hadd_ps.html" title='core::arch::x86::_mm_hadd_ps fn'>_mm_hadd_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse3</code></span><p>Horizontally adds adjacent pairs of single-precision (32-bit)
floating-point elements in <code>a</code> and <code>b</code>, and pack the results.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_hadds_epi16.html" title='core::arch::x86::_mm_hadds_epi16 fn'>_mm_hadds_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>ssse3</code></span><p>Horizontally adds the adjacent pairs of values contained in 2 packed
128-bit vectors of <code>[8 x i16]</code>. Positive sums greater than 7FFFh are
saturated to 7FFFh. Negative sums less than 8000h are saturated to 8000h.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_hsub_epi16.html" title='core::arch::x86::_mm_hsub_epi16 fn'>_mm_hsub_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>ssse3</code></span><p>Horizontally subtract the adjacent pairs of values contained in 2
packed 128-bit vectors of <code>[8 x i16]</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_hsub_epi32.html" title='core::arch::x86::_mm_hsub_epi32 fn'>_mm_hsub_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>ssse3</code></span><p>Horizontally subtract the adjacent pairs of values contained in 2
packed 128-bit vectors of <code>[4 x i32]</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_hsub_pd.html" title='core::arch::x86::_mm_hsub_pd fn'>_mm_hsub_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse3</code></span><p>Horizontally subtract adjacent pairs of double-precision (64-bit)
floating-point elements in <code>a</code> and <code>b</code>, and pack the results.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_hsub_ps.html" title='core::arch::x86::_mm_hsub_ps fn'>_mm_hsub_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse3</code></span><p>Horizontally adds adjacent pairs of single-precision (32-bit)
floating-point elements in <code>a</code> and <code>b</code>, and pack the results.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_hsubs_epi16.html" title='core::arch::x86::_mm_hsubs_epi16 fn'>_mm_hsubs_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>ssse3</code></span><p>Horizontally subtract the adjacent pairs of values contained in 2
packed 128-bit vectors of <code>[8 x i16]</code>. Positive differences greater than
7FFFh are saturated to 7FFFh. Negative differences less than 8000h are
saturated to 8000h.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_i32gather_ps.html" title='core::arch::x86::_mm_i32gather_ps fn'>_mm_i32gather_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Returns values from <code>slice</code> at offsets determined by <code>offsets * scale</code>,
where
<code>scale</code> is between 1 and 8.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_i32gather_pd.html" title='core::arch::x86::_mm_i32gather_pd fn'>_mm_i32gather_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Returns values from <code>slice</code> at offsets determined by <code>offsets * scale</code>,
where
<code>scale</code> is between 1 and 8.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_i64gather_ps.html" title='core::arch::x86::_mm_i64gather_ps fn'>_mm_i64gather_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Returns values from <code>slice</code> at offsets determined by <code>offsets * scale</code>,
where
<code>scale</code> is between 1 and 8.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_i64gather_pd.html" title='core::arch::x86::_mm_i64gather_pd fn'>_mm_i64gather_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Returns values from <code>slice</code> at offsets determined by <code>offsets * scale</code>,
where
<code>scale</code> is between 1 and 8.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_i32gather_epi32.html" title='core::arch::x86::_mm_i32gather_epi32 fn'>_mm_i32gather_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Returns values from <code>slice</code> at offsets determined by <code>offsets * scale</code>,
where
<code>scale</code> is between 1 and 8.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_i32gather_epi64.html" title='core::arch::x86::_mm_i32gather_epi64 fn'>_mm_i32gather_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Returns values from <code>slice</code> at offsets determined by <code>offsets * scale</code>,
where
<code>scale</code> is between 1 and 8.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_i64gather_epi32.html" title='core::arch::x86::_mm_i64gather_epi32 fn'>_mm_i64gather_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Returns values from <code>slice</code> at offsets determined by <code>offsets * scale</code>,
where
<code>scale</code> is between 1 and 8.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_i64gather_epi64.html" title='core::arch::x86::_mm_i64gather_epi64 fn'>_mm_i64gather_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Returns values from <code>slice</code> at offsets determined by <code>offsets * scale</code>,
where
<code>scale</code> is between 1 and 8.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_insert_epi8.html" title='core::arch::x86::_mm_insert_epi8 fn'>_mm_insert_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Returns a copy of <code>a</code> with the 8-bit integer from <code>i</code> inserted at a
location specified by <code>imm8</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_insert_epi16.html" title='core::arch::x86::_mm_insert_epi16 fn'>_mm_insert_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Returns a new vector where the <code>imm8</code> element of <code>a</code> is replaced with <code>i</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_insert_epi32.html" title='core::arch::x86::_mm_insert_epi32 fn'>_mm_insert_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Returns a copy of <code>a</code> with the 32-bit integer from <code>i</code> inserted at a
location specified by <code>imm8</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_insert_ps.html" title='core::arch::x86::_mm_insert_ps fn'>_mm_insert_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Select a single value in <code>a</code> to store at some position in <code>b</code>,
Then zero elements according to <code>imm8</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_insert_si64.html" title='core::arch::x86::_mm_insert_si64 fn'>_mm_insert_si64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4a</code></span><p>Inserts the <code>[length:0]</code> bits of <code>y</code> into <code>x</code> at <code>index</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_lddqu_si128.html" title='core::arch::x86::_mm_lddqu_si128 fn'>_mm_lddqu_si128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse3</code></span><p>Loads 128-bits of integer data from unaligned memory.
This intrinsic may perform better than <code>_mm_loadu_si128</code>
when the data crosses a cache line boundary.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_lfence.html" title='core::arch::x86::_mm_lfence fn'>_mm_lfence</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Performs a serializing operation on all load-from-memory instructions
that were issued prior to this instruction.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_load1_ps.html" title='core::arch::x86::_mm_load1_ps fn'>_mm_load1_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Construct a <code>__m128</code> by duplicating the value read from <code>p</code> into all
elements.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_load1_pd.html" title='core::arch::x86::_mm_load1_pd fn'>_mm_load1_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Loads a double-precision (64-bit) floating-point element from memory
into both elements of returned vector.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_load_pd.html" title='core::arch::x86::_mm_load_pd fn'>_mm_load_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Loads 128-bits (composed of 2 packed double-precision (64-bit)
floating-point elements) from memory into the returned vector.
<code>mem_addr</code> must be aligned on a 16-byte boundary or a general-protection
exception may be generated.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_load_pd1.html" title='core::arch::x86::_mm_load_pd1 fn'>_mm_load_pd1</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Loads a double-precision (64-bit) floating-point element from memory
into both elements of returned vector.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_load_ps.html" title='core::arch::x86::_mm_load_ps fn'>_mm_load_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Loads four <code>f32</code> values from <em>aligned</em> memory into a <code>__m128</code>. If the
pointer is not aligned to a 128-bit boundary (16 bytes) a general
protection fault will be triggered (fatal program crash).</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_load_ps1.html" title='core::arch::x86::_mm_load_ps1 fn'>_mm_load_ps1</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Alias for <a href="fn._mm_load1_ps.html"><code>_mm_load1_ps</code></a></p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_load_sd.html" title='core::arch::x86::_mm_load_sd fn'>_mm_load_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Loads a 64-bit double-precision value to the low element of a
128-bit integer vector and clears the upper element.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_load_si128.html" title='core::arch::x86::_mm_load_si128 fn'>_mm_load_si128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Loads 128-bits of integer data from memory into a new vector.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_load_ss.html" title='core::arch::x86::_mm_load_ss fn'>_mm_load_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Construct a <code>__m128</code> with the lowest element read from <code>p</code> and the other
elements set to zero.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_loaddup_pd.html" title='core::arch::x86::_mm_loaddup_pd fn'>_mm_loaddup_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse3</code></span><p>Loads a double-precision (64-bit) floating-point element from memory
into both elements of return vector.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_loadh_pd.html" title='core::arch::x86::_mm_loadh_pd fn'>_mm_loadh_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Loads a double-precision value into the high-order bits of a 128-bit
vector of <code>[2 x double]</code>. The low-order bits are copied from the low-order
bits of the first operand.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_loadl_epi64.html" title='core::arch::x86::_mm_loadl_epi64 fn'>_mm_loadl_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Loads 64-bit integer from memory into first element of returned vector.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_loadl_pd.html" title='core::arch::x86::_mm_loadl_pd fn'>_mm_loadl_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Loads a double-precision value into the low-order bits of a 128-bit
vector of <code>[2 x double]</code>. The high-order bits are copied from the
high-order bits of the first operand.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_loadr_pd.html" title='core::arch::x86::_mm_loadr_pd fn'>_mm_loadr_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Loads 2 double-precision (64-bit) floating-point elements from memory into
the returned vector in reverse order. <code>mem_addr</code> must be aligned on a
16-byte boundary or a general-protection exception may be generated.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_loadr_ps.html" title='core::arch::x86::_mm_loadr_ps fn'>_mm_loadr_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Loads four <code>f32</code> values from aligned memory into a <code>__m128</code> in reverse
order.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_loadu_pd.html" title='core::arch::x86::_mm_loadu_pd fn'>_mm_loadu_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Loads 128-bits (composed of 2 packed double-precision (64-bit)
floating-point elements) from memory into the returned vector.
<code>mem_addr</code> does not need to be aligned on any particular boundary.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_loadu_ps.html" title='core::arch::x86::_mm_loadu_ps fn'>_mm_loadu_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Loads four <code>f32</code> values from memory into a <code>__m128</code>. There are no
restrictions
on memory alignment. For aligned memory
<a href="fn._mm_load_ps.html"><code>_mm_load_ps</code></a>
may be faster.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_loadu_si128.html" title='core::arch::x86::_mm_loadu_si128 fn'>_mm_loadu_si128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Loads 128-bits of integer data from memory into a new vector.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_madd_epi16.html" title='core::arch::x86::_mm_madd_epi16 fn'>_mm_madd_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Multiplies and then horizontally add signed 16 bit integers in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_maddubs_epi16.html" title='core::arch::x86::_mm_maddubs_epi16 fn'>_mm_maddubs_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>ssse3</code></span><p>Multiplies corresponding pairs of packed 8-bit unsigned integer
values contained in the first source operand and packed 8-bit signed
integer values contained in the second source operand, add pairs of
contiguous products with signed saturation, and writes the 16-bit sums to
the corresponding bits in the destination.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_mask_i32gather_ps.html" title='core::arch::x86::_mm_mask_i32gather_ps fn'>_mm_mask_i32gather_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Returns values from <code>slice</code> at offsets determined by <code>offsets * scale</code>,
where
<code>scale</code> is between 1 and 8. If mask is set, load the value from <code>src</code> in
that position instead.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_mask_i32gather_pd.html" title='core::arch::x86::_mm_mask_i32gather_pd fn'>_mm_mask_i32gather_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Returns values from <code>slice</code> at offsets determined by <code>offsets * scale</code>,
where
<code>scale</code> is between 1 and 8. If mask is set, load the value from <code>src</code> in
that position instead.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_mask_i64gather_ps.html" title='core::arch::x86::_mm_mask_i64gather_ps fn'>_mm_mask_i64gather_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Returns values from <code>slice</code> at offsets determined by <code>offsets * scale</code>,
where
<code>scale</code> is between 1 and 8. If mask is set, load the value from <code>src</code> in
that position instead.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_mask_i64gather_pd.html" title='core::arch::x86::_mm_mask_i64gather_pd fn'>_mm_mask_i64gather_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Returns values from <code>slice</code> at offsets determined by <code>offsets * scale</code>,
where
<code>scale</code> is between 1 and 8. If mask is set, load the value from <code>src</code> in
that position instead.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_mask_i32gather_epi32.html" title='core::arch::x86::_mm_mask_i32gather_epi32 fn'>_mm_mask_i32gather_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Returns values from <code>slice</code> at offsets determined by <code>offsets * scale</code>,
where
<code>scale</code> is between 1 and 8. If mask is set, load the value from <code>src</code> in
that position instead.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_mask_i32gather_epi64.html" title='core::arch::x86::_mm_mask_i32gather_epi64 fn'>_mm_mask_i32gather_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Returns values from <code>slice</code> at offsets determined by <code>offsets * scale</code>,
where
<code>scale</code> is between 1 and 8. If mask is set, load the value from <code>src</code> in
that position instead.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_mask_i64gather_epi32.html" title='core::arch::x86::_mm_mask_i64gather_epi32 fn'>_mm_mask_i64gather_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Returns values from <code>slice</code> at offsets determined by <code>offsets * scale</code>,
where
<code>scale</code> is between 1 and 8. If mask is set, load the value from <code>src</code> in
that position instead.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_mask_i64gather_epi64.html" title='core::arch::x86::_mm_mask_i64gather_epi64 fn'>_mm_mask_i64gather_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Returns values from <code>slice</code> at offsets determined by <code>offsets * scale</code>,
where
<code>scale</code> is between 1 and 8. If mask is set, load the value from <code>src</code> in
that position instead.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_maskload_epi32.html" title='core::arch::x86::_mm_maskload_epi32 fn'>_mm_maskload_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Loads packed 32-bit integers from memory pointed by <code>mem_addr</code> using <code>mask</code>
(elements are zeroed out when the highest bit is not set in the
corresponding element).</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_maskload_epi64.html" title='core::arch::x86::_mm_maskload_epi64 fn'>_mm_maskload_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Loads packed 64-bit integers from memory pointed by <code>mem_addr</code> using <code>mask</code>
(elements are zeroed out when the highest bit is not set in the
corresponding element).</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_maskload_pd.html" title='core::arch::x86::_mm_maskload_pd fn'>_mm_maskload_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Loads packed double-precision (64-bit) floating-point elements from memory
into result using <code>mask</code> (elements are zeroed out when the high bit of the
corresponding element is not set).</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_maskload_ps.html" title='core::arch::x86::_mm_maskload_ps fn'>_mm_maskload_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Loads packed single-precision (32-bit) floating-point elements from memory
into result using <code>mask</code> (elements are zeroed out when the high bit of the
corresponding element is not set).</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_maskmoveu_si128.html" title='core::arch::x86::_mm_maskmoveu_si128 fn'>_mm_maskmoveu_si128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Conditionally store 8-bit integer elements from <code>a</code> into memory using
<code>mask</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_maskstore_epi32.html" title='core::arch::x86::_mm_maskstore_epi32 fn'>_mm_maskstore_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Stores packed 32-bit integers from <code>a</code> into memory pointed by <code>mem_addr</code>
using <code>mask</code> (elements are not stored when the highest bit is not set
in the corresponding element).</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_maskstore_epi64.html" title='core::arch::x86::_mm_maskstore_epi64 fn'>_mm_maskstore_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Stores packed 64-bit integers from <code>a</code> into memory pointed by <code>mem_addr</code>
using <code>mask</code> (elements are not stored when the highest bit is not set
in the corresponding element).</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_maskstore_pd.html" title='core::arch::x86::_mm_maskstore_pd fn'>_mm_maskstore_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Stores packed double-precision (64-bit) floating-point elements from <code>a</code>
into memory using <code>mask</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_maskstore_ps.html" title='core::arch::x86::_mm_maskstore_ps fn'>_mm_maskstore_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Stores packed single-precision (32-bit) floating-point elements from <code>a</code>
into memory using <code>mask</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_max_epi8.html" title='core::arch::x86::_mm_max_epi8 fn'>_mm_max_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Compares packed 8-bit integers in <code>a</code> and <code>b</code> and returns packed maximum
values in dst.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_max_epi16.html" title='core::arch::x86::_mm_max_epi16 fn'>_mm_max_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Compares packed 16-bit integers in <code>a</code> and <code>b</code>, and returns the packed
maximum values.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_max_epi32.html" title='core::arch::x86::_mm_max_epi32 fn'>_mm_max_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Compares packed 32-bit integers in <code>a</code> and <code>b</code>, and returns packed maximum
values.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_max_epu8.html" title='core::arch::x86::_mm_max_epu8 fn'>_mm_max_epu8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Compares packed unsigned 8-bit integers in <code>a</code> and <code>b</code>, and returns the
packed maximum values.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_max_epu16.html" title='core::arch::x86::_mm_max_epu16 fn'>_mm_max_epu16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Compares packed unsigned 16-bit integers in <code>a</code> and <code>b</code>, and returns packed
maximum.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_max_epu32.html" title='core::arch::x86::_mm_max_epu32 fn'>_mm_max_epu32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Compares packed unsigned 32-bit integers in <code>a</code> and <code>b</code>, and returns packed
maximum values.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_max_pd.html" title='core::arch::x86::_mm_max_pd fn'>_mm_max_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Returns a new vector with the maximum values from corresponding elements in
<code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_max_ps.html" title='core::arch::x86::_mm_max_ps fn'>_mm_max_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Compares packed single-precision (32-bit) floating-point elements in <code>a</code> and
<code>b</code>, and return the corresponding maximum values.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_max_sd.html" title='core::arch::x86::_mm_max_sd fn'>_mm_max_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Returns a new vector with the low element of <code>a</code> replaced by the maximum
of the lower elements of <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_max_ss.html" title='core::arch::x86::_mm_max_ss fn'>_mm_max_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Compares the first single-precision (32-bit) floating-point element of <code>a</code>
and <code>b</code>, and return the maximum value in the first element of the return
value, the other elements are copied from <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_mfence.html" title='core::arch::x86::_mm_mfence fn'>_mm_mfence</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Performs a serializing operation on all load-from-memory and store-to-memory
instructions that were issued prior to this instruction.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_min_epi8.html" title='core::arch::x86::_mm_min_epi8 fn'>_mm_min_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Compares packed 8-bit integers in <code>a</code> and <code>b</code> and returns packed minimum
values in dst.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_min_epi16.html" title='core::arch::x86::_mm_min_epi16 fn'>_mm_min_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Compares packed 16-bit integers in <code>a</code> and <code>b</code>, and returns the packed
minimum values.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_min_epi32.html" title='core::arch::x86::_mm_min_epi32 fn'>_mm_min_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Compares packed 32-bit integers in <code>a</code> and <code>b</code>, and returns packed minimum
values.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_min_epu8.html" title='core::arch::x86::_mm_min_epu8 fn'>_mm_min_epu8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Compares packed unsigned 8-bit integers in <code>a</code> and <code>b</code>, and returns the
packed minimum values.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_min_epu16.html" title='core::arch::x86::_mm_min_epu16 fn'>_mm_min_epu16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Compares packed unsigned 16-bit integers in <code>a</code> and <code>b</code>, and returns packed
minimum.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_min_epu32.html" title='core::arch::x86::_mm_min_epu32 fn'>_mm_min_epu32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Compares packed unsigned 32-bit integers in <code>a</code> and <code>b</code>, and returns packed
minimum values.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_min_pd.html" title='core::arch::x86::_mm_min_pd fn'>_mm_min_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Returns a new vector with the minimum values from corresponding elements in
<code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_min_ps.html" title='core::arch::x86::_mm_min_ps fn'>_mm_min_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Compares packed single-precision (32-bit) floating-point elements in <code>a</code> and
<code>b</code>, and return the corresponding minimum values.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_min_sd.html" title='core::arch::x86::_mm_min_sd fn'>_mm_min_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Returns a new vector with the low element of <code>a</code> replaced by the minimum
of the lower elements of <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_min_ss.html" title='core::arch::x86::_mm_min_ss fn'>_mm_min_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Compares the first single-precision (32-bit) floating-point element of <code>a</code>
and <code>b</code>, and return the minimum value in the first element of the return
value, the other elements are copied from <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_minpos_epu16.html" title='core::arch::x86::_mm_minpos_epu16 fn'>_mm_minpos_epu16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Finds the minimum unsigned 16-bit element in the 128-bit __m128i vector,
returning a vector containing its value in its first position, and its
index
in its second position; all other elements are set to zero.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_move_epi64.html" title='core::arch::x86::_mm_move_epi64 fn'>_mm_move_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Returns a vector where the low element is extracted from <code>a</code> and its upper
element is zero.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_move_sd.html" title='core::arch::x86::_mm_move_sd fn'>_mm_move_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Constructs a 128-bit floating-point vector of <code>[2 x double]</code>. The lower
64 bits are set to the lower 64 bits of the second parameter. The upper
64 bits are set to the upper 64 bits of the first parameter.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_move_ss.html" title='core::arch::x86::_mm_move_ss fn'>_mm_move_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Returns a <code>__m128</code> with the first component from <code>b</code> and the remaining
components from <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_movedup_pd.html" title='core::arch::x86::_mm_movedup_pd fn'>_mm_movedup_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse3</code></span><p>Duplicate the low double-precision (64-bit) floating-point element
from <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_movehdup_ps.html" title='core::arch::x86::_mm_movehdup_ps fn'>_mm_movehdup_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse3</code></span><p>Duplicate odd-indexed single-precision (32-bit) floating-point elements
from <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_movehl_ps.html" title='core::arch::x86::_mm_movehl_ps fn'>_mm_movehl_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Combine higher half of <code>a</code> and <code>b</code>. The highwe half of <code>b</code> occupies the
lower half of result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_moveldup_ps.html" title='core::arch::x86::_mm_moveldup_ps fn'>_mm_moveldup_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse3</code></span><p>Duplicate even-indexed single-precision (32-bit) floating-point elements
from <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_movelh_ps.html" title='core::arch::x86::_mm_movelh_ps fn'>_mm_movelh_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Combine lower half of <code>a</code> and <code>b</code>. The lower half of <code>b</code> occupies the
higher half of result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_movemask_epi8.html" title='core::arch::x86::_mm_movemask_epi8 fn'>_mm_movemask_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Returns a mask of the most significant bit of each element in <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_movemask_pd.html" title='core::arch::x86::_mm_movemask_pd fn'>_mm_movemask_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Returns a mask of the most significant bit of each element in <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_movemask_ps.html" title='core::arch::x86::_mm_movemask_ps fn'>_mm_movemask_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Returns a mask of the most significant bit of each element in <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_mpsadbw_epu8.html" title='core::arch::x86::_mm_mpsadbw_epu8 fn'>_mm_mpsadbw_epu8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Subtracts 8-bit unsigned integer values and computes the absolute
values of the differences to the corresponding bits in the destination.
Then sums of the absolute differences are returned according to the bit
fields in the immediate operand.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_mul_epi32.html" title='core::arch::x86::_mm_mul_epi32 fn'>_mm_mul_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Multiplies the low 32-bit integers from each packed 64-bit
element in <code>a</code> and <code>b</code>, and returns the signed 64-bit result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_mul_epu32.html" title='core::arch::x86::_mm_mul_epu32 fn'>_mm_mul_epu32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Multiplies the low unsigned 32-bit integers from each packed 64-bit element
in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_mul_pd.html" title='core::arch::x86::_mm_mul_pd fn'>_mm_mul_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Multiplies packed double-precision (64-bit) floating-point elements in <code>a</code>
and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_mul_ps.html" title='core::arch::x86::_mm_mul_ps fn'>_mm_mul_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Multiplies __m128 vectors.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_mul_sd.html" title='core::arch::x86::_mm_mul_sd fn'>_mm_mul_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Returns a new vector with the low element of <code>a</code> replaced by multiplying the
low elements of <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_mul_ss.html" title='core::arch::x86::_mm_mul_ss fn'>_mm_mul_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Multiplies the first component of <code>a</code> and <code>b</code>, the other components are
copied from <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_mulhi_epi16.html" title='core::arch::x86::_mm_mulhi_epi16 fn'>_mm_mulhi_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Multiplies the packed 16-bit integers in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_mulhi_epu16.html" title='core::arch::x86::_mm_mulhi_epu16 fn'>_mm_mulhi_epu16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Multiplies the packed unsigned 16-bit integers in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_mulhrs_epi16.html" title='core::arch::x86::_mm_mulhrs_epi16 fn'>_mm_mulhrs_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>ssse3</code></span><p>Multiplies packed 16-bit signed integer values, truncate the 32-bit
product to the 18 most significant bits by right-shifting, round the
truncated value by adding 1, and write bits <code>[16:1]</code> to the destination.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_mullo_epi16.html" title='core::arch::x86::_mm_mullo_epi16 fn'>_mm_mullo_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Multiplies the packed 16-bit integers in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_mullo_epi32.html" title='core::arch::x86::_mm_mullo_epi32 fn'>_mm_mullo_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Multiplies the packed 32-bit integers in <code>a</code> and <code>b</code>, producing intermediate
64-bit integers, and returns the lowest 32-bit, whatever they might be,
reinterpreted as a signed integer. While <code>pmulld __m128i::splat(2), __m128i::splat(2)</code> returns the obvious <code>__m128i::splat(4)</code>, due to wrapping
arithmetic <code>pmulld __m128i::splat(i32::MAX), __m128i::splat(2)</code> would
return a negative number.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_or_pd.html" title='core::arch::x86::_mm_or_pd fn'>_mm_or_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Computes the bitwise OR of <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_or_ps.html" title='core::arch::x86::_mm_or_ps fn'>_mm_or_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Bitwise OR of packed single-precision (32-bit) floating-point elements.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_or_si128.html" title='core::arch::x86::_mm_or_si128 fn'>_mm_or_si128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Computes the bitwise OR of 128 bits (representing integer data) in <code>a</code> and
<code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_packs_epi16.html" title='core::arch::x86::_mm_packs_epi16 fn'>_mm_packs_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Converts packed 16-bit integers from <code>a</code> and <code>b</code> to packed 8-bit integers
using signed saturation.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_packs_epi32.html" title='core::arch::x86::_mm_packs_epi32 fn'>_mm_packs_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Converts packed 32-bit integers from <code>a</code> and <code>b</code> to packed 16-bit integers
using signed saturation.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_packus_epi16.html" title='core::arch::x86::_mm_packus_epi16 fn'>_mm_packus_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Converts packed 16-bit integers from <code>a</code> and <code>b</code> to packed 8-bit integers
using unsigned saturation.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_packus_epi32.html" title='core::arch::x86::_mm_packus_epi32 fn'>_mm_packus_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Converts packed 32-bit integers from <code>a</code> and <code>b</code> to packed 16-bit integers
using unsigned saturation</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_pause.html" title='core::arch::x86::_mm_pause fn'>_mm_pause</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Provides a hint to the processor that the code sequence is a spin-wait loop.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_permute_pd.html" title='core::arch::x86::_mm_permute_pd fn'>_mm_permute_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx,sse2</code></span><p>Shuffles double-precision (64-bit) floating-point elements in <code>a</code>
using the control in <code>imm8</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_permute_ps.html" title='core::arch::x86::_mm_permute_ps fn'>_mm_permute_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx,sse</code></span><p>Shuffles single-precision (32-bit) floating-point elements in <code>a</code>
using the control in <code>imm8</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_permutevar_pd.html" title='core::arch::x86::_mm_permutevar_pd fn'>_mm_permutevar_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Shuffles double-precision (64-bit) floating-point elements in <code>a</code>
using the control in <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_permutevar_ps.html" title='core::arch::x86::_mm_permutevar_ps fn'>_mm_permutevar_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Shuffles single-precision (32-bit) floating-point elements in <code>a</code>
using the control in <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_prefetch.html" title='core::arch::x86::_mm_prefetch fn'>_mm_prefetch</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Fetch the cache line that contains address <code>p</code> using the given <code>strategy</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_rcp_ps.html" title='core::arch::x86::_mm_rcp_ps fn'>_mm_rcp_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Returns the approximate reciprocal of packed single-precision (32-bit)
floating-point elements in <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_rcp_ss.html" title='core::arch::x86::_mm_rcp_ss fn'>_mm_rcp_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Returns the approximate reciprocal of the first single-precision
(32-bit) floating-point element in <code>a</code>, the other elements are unchanged.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_round_pd.html" title='core::arch::x86::_mm_round_pd fn'>_mm_round_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Round the packed double-precision (64-bit) floating-point elements in <code>a</code>
using the <code>rounding</code> parameter, and stores the results as packed
double-precision floating-point elements.
Rounding is done according to the rounding parameter, which can be one of:</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_round_ps.html" title='core::arch::x86::_mm_round_ps fn'>_mm_round_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Round the packed single-precision (32-bit) floating-point elements in <code>a</code>
using the <code>rounding</code> parameter, and stores the results as packed
single-precision floating-point elements.
Rounding is done according to the rounding parameter, which can be one of:</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_round_sd.html" title='core::arch::x86::_mm_round_sd fn'>_mm_round_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Round the lower double-precision (64-bit) floating-point element in <code>b</code>
using the <code>rounding</code> parameter, store the result as a double-precision
floating-point element in the lower element of the intrinsic result,
and copies the upper element from <code>a</code> to the upper element of the intrinsic
result.
Rounding is done according to the rounding parameter, which can be one of:</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_round_ss.html" title='core::arch::x86::_mm_round_ss fn'>_mm_round_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Round the lower single-precision (32-bit) floating-point element in <code>b</code>
using the <code>rounding</code> parameter, store the result as a single-precision
floating-point element in the lower element of the intrinsic result,
and copies the upper 3 packed elements from <code>a</code> to the upper elements
of the instrinsic result.
Rounding is done according to the rounding parameter, which can be one of:</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_rsqrt_ps.html" title='core::arch::x86::_mm_rsqrt_ps fn'>_mm_rsqrt_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Returns the approximate reciprocal square root of packed single-precision
(32-bit) floating-point elements in <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_rsqrt_ss.html" title='core::arch::x86::_mm_rsqrt_ss fn'>_mm_rsqrt_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Returns the approximate reciprocal square root of the fist single-precision
(32-bit) floating-point elements in <code>a</code>, the other elements are unchanged.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_sad_epu8.html" title='core::arch::x86::_mm_sad_epu8 fn'>_mm_sad_epu8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Sum the absolute differences of packed unsigned 8-bit integers.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_set1_ps.html" title='core::arch::x86::_mm_set1_ps fn'>_mm_set1_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Construct a <code>__m128</code> with all element set to <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_set1_pd.html" title='core::arch::x86::_mm_set1_pd fn'>_mm_set1_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Broadcasts double-precision (64-bit) floating-point value a to all elements
of the return value.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_set1_epi8.html" title='core::arch::x86::_mm_set1_epi8 fn'>_mm_set1_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Broadcasts 8-bit integer <code>a</code> to all elements.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_set1_epi16.html" title='core::arch::x86::_mm_set1_epi16 fn'>_mm_set1_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Broadcasts 16-bit integer <code>a</code> to all elements.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_set1_epi32.html" title='core::arch::x86::_mm_set1_epi32 fn'>_mm_set1_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Broadcasts 32-bit integer <code>a</code> to all elements.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_set1_epi64x.html" title='core::arch::x86::_mm_set1_epi64x fn'>_mm_set1_epi64x</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Broadcasts 64-bit integer <code>a</code> to all elements.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_set_epi8.html" title='core::arch::x86::_mm_set_epi8 fn'>_mm_set_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Sets packed 8-bit integers with the supplied values.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_set_epi16.html" title='core::arch::x86::_mm_set_epi16 fn'>_mm_set_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Sets packed 16-bit integers with the supplied values.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_set_epi32.html" title='core::arch::x86::_mm_set_epi32 fn'>_mm_set_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Sets packed 32-bit integers with the supplied values.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_set_epi64x.html" title='core::arch::x86::_mm_set_epi64x fn'>_mm_set_epi64x</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Sets packed 64-bit integers with the supplied values, from highest to
lowest.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_set_pd.html" title='core::arch::x86::_mm_set_pd fn'>_mm_set_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Sets packed double-precision (64-bit) floating-point elements in the return
value with the supplied values.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_set_pd1.html" title='core::arch::x86::_mm_set_pd1 fn'>_mm_set_pd1</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Broadcasts double-precision (64-bit) floating-point value a to all elements
of the return value.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_set_ps.html" title='core::arch::x86::_mm_set_ps fn'>_mm_set_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Construct a <code>__m128</code> from four floating point values highest to lowest.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_set_ps1.html" title='core::arch::x86::_mm_set_ps1 fn'>_mm_set_ps1</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Alias for <a href="fn._mm_set1_ps.html"><code>_mm_set1_ps</code></a></p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_set_sd.html" title='core::arch::x86::_mm_set_sd fn'>_mm_set_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Copies double-precision (64-bit) floating-point element <code>a</code> to the lower
element of the packed 64-bit return value.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_set_ss.html" title='core::arch::x86::_mm_set_ss fn'>_mm_set_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Construct a <code>__m128</code> with the lowest element set to <code>a</code> and the rest set to
zero.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_setcsr.html" title='core::arch::x86::_mm_setcsr fn'>_mm_setcsr</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Sets the MXCSR register with the 32-bit unsigned integer value.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_setr_epi8.html" title='core::arch::x86::_mm_setr_epi8 fn'>_mm_setr_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Sets packed 8-bit integers with the supplied values in reverse order.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_setr_epi16.html" title='core::arch::x86::_mm_setr_epi16 fn'>_mm_setr_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Sets packed 16-bit integers with the supplied values in reverse order.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_setr_epi32.html" title='core::arch::x86::_mm_setr_epi32 fn'>_mm_setr_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Sets packed 32-bit integers with the supplied values in reverse order.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_setr_pd.html" title='core::arch::x86::_mm_setr_pd fn'>_mm_setr_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Sets packed double-precision (64-bit) floating-point elements in the return
value with the supplied values in reverse order.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_setr_ps.html" title='core::arch::x86::_mm_setr_ps fn'>_mm_setr_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Construct a <code>__m128</code> from four floating point values lowest to highest.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_setzero_pd.html" title='core::arch::x86::_mm_setzero_pd fn'>_mm_setzero_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Returns packed double-precision (64-bit) floating-point elements with all
zeros.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_setzero_ps.html" title='core::arch::x86::_mm_setzero_ps fn'>_mm_setzero_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Construct a <code>__m128</code> with all elements initialized to zero.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_setzero_si128.html" title='core::arch::x86::_mm_setzero_si128 fn'>_mm_setzero_si128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Returns a vector with all elements set to zero.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_sfence.html" title='core::arch::x86::_mm_sfence fn'>_mm_sfence</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Performs a serializing operation on all store-to-memory instructions that
were issued prior to this instruction.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_sha1msg1_epu32.html" title='core::arch::x86::_mm_sha1msg1_epu32 fn'>_mm_sha1msg1_epu32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sha</code></span><p>Performs an intermediate calculation for the next four SHA1 message values
(unsigned 32-bit integers) using previous message values from <code>a</code> and <code>b</code>,
and returning the result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_sha1msg2_epu32.html" title='core::arch::x86::_mm_sha1msg2_epu32 fn'>_mm_sha1msg2_epu32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sha</code></span><p>Performs the final calculation for the next four SHA1 message values
(unsigned 32-bit integers) using the intermediate result in <code>a</code> and the
previous message values in <code>b</code>, and returns the result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_sha1nexte_epu32.html" title='core::arch::x86::_mm_sha1nexte_epu32 fn'>_mm_sha1nexte_epu32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sha</code></span><p>Calculate SHA1 state variable E after four rounds of operation from the
current SHA1 state variable <code>a</code>, add that value to the scheduled values
(unsigned 32-bit integers) in <code>b</code>, and returns the result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_sha1rnds4_epu32.html" title='core::arch::x86::_mm_sha1rnds4_epu32 fn'>_mm_sha1rnds4_epu32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sha</code></span><p>Performs four rounds of SHA1 operation using an initial SHA1 state (A,B,C,D)
from <code>a</code> and some pre-computed sum of the next 4 round message values
(unsigned 32-bit integers), and state variable E from <code>b</code>, and return the
updated SHA1 state (A,B,C,D). <code>func</code> contains the logic functions and round
constants.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_sha256msg1_epu32.html" title='core::arch::x86::_mm_sha256msg1_epu32 fn'>_mm_sha256msg1_epu32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sha</code></span><p>Performs an intermediate calculation for the next four SHA256 message values
(unsigned 32-bit integers) using previous message values from <code>a</code> and <code>b</code>,
and return the result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_sha256msg2_epu32.html" title='core::arch::x86::_mm_sha256msg2_epu32 fn'>_mm_sha256msg2_epu32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sha</code></span><p>Performs the final calculation for the next four SHA256 message values
(unsigned 32-bit integers) using previous message values from <code>a</code> and <code>b</code>,
and return the result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_sha256rnds2_epu32.html" title='core::arch::x86::_mm_sha256rnds2_epu32 fn'>_mm_sha256rnds2_epu32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sha</code></span><p>Performs 2 rounds of SHA256 operation using an initial SHA256 state
(C,D,G,H) from <code>a</code>, an initial SHA256 state (A,B,E,F) from <code>b</code>, and a
pre-computed sum of the next 2 round message values (unsigned 32-bit
integers) and the corresponding round constants from <code>k</code>, and store the
updated SHA256 state (A,B,E,F) in dst.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_shuffle_epi8.html" title='core::arch::x86::_mm_shuffle_epi8 fn'>_mm_shuffle_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>ssse3</code></span><p>Shuffles bytes from <code>a</code> according to the content of <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_shuffle_epi32.html" title='core::arch::x86::_mm_shuffle_epi32 fn'>_mm_shuffle_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Shuffles 32-bit integers in <code>a</code> using the control in <code>imm8</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_shuffle_pd.html" title='core::arch::x86::_mm_shuffle_pd fn'>_mm_shuffle_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Constructs a 128-bit floating-point vector of <code>[2 x double]</code> from two
128-bit vector parameters of <code>[2 x double]</code>, using the immediate-value
parameter as a specifier.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_shuffle_ps.html" title='core::arch::x86::_mm_shuffle_ps fn'>_mm_shuffle_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Shuffles packed single-precision (32-bit) floating-point elements in <code>a</code> and
<code>b</code> using <code>mask</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_shufflehi_epi16.html" title='core::arch::x86::_mm_shufflehi_epi16 fn'>_mm_shufflehi_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Shuffles 16-bit integers in the high 64 bits of <code>a</code> using the control in
<code>imm8</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_shufflelo_epi16.html" title='core::arch::x86::_mm_shufflelo_epi16 fn'>_mm_shufflelo_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Shuffles 16-bit integers in the low 64 bits of <code>a</code> using the control in
<code>imm8</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_sign_epi8.html" title='core::arch::x86::_mm_sign_epi8 fn'>_mm_sign_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>ssse3</code></span><p>Negates packed 8-bit integers in <code>a</code> when the corresponding signed 8-bit
integer in <code>b</code> is negative, and returns the result.
Elements in result are zeroed out when the corresponding element in <code>b</code>
is zero.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_sign_epi16.html" title='core::arch::x86::_mm_sign_epi16 fn'>_mm_sign_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>ssse3</code></span><p>Negates packed 16-bit integers in <code>a</code> when the corresponding signed 16-bit
integer in <code>b</code> is negative, and returns the results.
Elements in result are zeroed out when the corresponding element in <code>b</code>
is zero.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_sign_epi32.html" title='core::arch::x86::_mm_sign_epi32 fn'>_mm_sign_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>ssse3</code></span><p>Negates packed 32-bit integers in <code>a</code> when the corresponding signed 32-bit
integer in <code>b</code> is negative, and returns the results.
Element in result are zeroed out when the corresponding element in <code>b</code>
is zero.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_sll_epi16.html" title='core::arch::x86::_mm_sll_epi16 fn'>_mm_sll_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Shifts packed 16-bit integers in <code>a</code> left by <code>count</code> while shifting in
zeros.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_sll_epi32.html" title='core::arch::x86::_mm_sll_epi32 fn'>_mm_sll_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Shifts packed 32-bit integers in <code>a</code> left by <code>count</code> while shifting in
zeros.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_sll_epi64.html" title='core::arch::x86::_mm_sll_epi64 fn'>_mm_sll_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Shifts packed 64-bit integers in <code>a</code> left by <code>count</code> while shifting in
zeros.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_slli_epi16.html" title='core::arch::x86::_mm_slli_epi16 fn'>_mm_slli_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Shifts packed 16-bit integers in <code>a</code> left by <code>imm8</code> while shifting in zeros.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_slli_epi32.html" title='core::arch::x86::_mm_slli_epi32 fn'>_mm_slli_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Shifts packed 32-bit integers in <code>a</code> left by <code>imm8</code> while shifting in zeros.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_slli_epi64.html" title='core::arch::x86::_mm_slli_epi64 fn'>_mm_slli_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Shifts packed 64-bit integers in <code>a</code> left by <code>imm8</code> while shifting in zeros.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_slli_si128.html" title='core::arch::x86::_mm_slli_si128 fn'>_mm_slli_si128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Shifts <code>a</code> left by <code>imm8</code> bytes while shifting in zeros.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_sllv_epi32.html" title='core::arch::x86::_mm_sllv_epi32 fn'>_mm_sllv_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Shifts packed 32-bit integers in <code>a</code> left by the amount
specified by the corresponding element in <code>count</code> while
shifting in zeros, and returns the result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_sllv_epi64.html" title='core::arch::x86::_mm_sllv_epi64 fn'>_mm_sllv_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Shifts packed 64-bit integers in <code>a</code> left by the amount
specified by the corresponding element in <code>count</code> while
shifting in zeros, and returns the result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_sqrt_pd.html" title='core::arch::x86::_mm_sqrt_pd fn'>_mm_sqrt_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Returns a new vector with the square root of each of the values in <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_sqrt_ps.html" title='core::arch::x86::_mm_sqrt_ps fn'>_mm_sqrt_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Returns the square root of packed single-precision (32-bit) floating-point
elements in <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_sqrt_sd.html" title='core::arch::x86::_mm_sqrt_sd fn'>_mm_sqrt_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Returns a new vector with the low element of <code>a</code> replaced by the square
root of the lower element <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_sqrt_ss.html" title='core::arch::x86::_mm_sqrt_ss fn'>_mm_sqrt_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Returns the square root of the first single-precision (32-bit)
floating-point element in <code>a</code>, the other elements are unchanged.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_sra_epi16.html" title='core::arch::x86::_mm_sra_epi16 fn'>_mm_sra_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Shifts packed 16-bit integers in <code>a</code> right by <code>count</code> while shifting in sign
bits.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_sra_epi32.html" title='core::arch::x86::_mm_sra_epi32 fn'>_mm_sra_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Shifts packed 32-bit integers in <code>a</code> right by <code>count</code> while shifting in sign
bits.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_srai_epi16.html" title='core::arch::x86::_mm_srai_epi16 fn'>_mm_srai_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Shifts packed 16-bit integers in <code>a</code> right by <code>imm8</code> while shifting in sign
bits.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_srai_epi32.html" title='core::arch::x86::_mm_srai_epi32 fn'>_mm_srai_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Shifts packed 32-bit integers in <code>a</code> right by <code>imm8</code> while shifting in sign
bits.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_srav_epi32.html" title='core::arch::x86::_mm_srav_epi32 fn'>_mm_srav_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Shifts packed 32-bit integers in <code>a</code> right by the amount specified by the
corresponding element in <code>count</code> while shifting in sign bits.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_srl_epi16.html" title='core::arch::x86::_mm_srl_epi16 fn'>_mm_srl_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Shifts packed 16-bit integers in <code>a</code> right by <code>count</code> while shifting in
zeros.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_srl_epi32.html" title='core::arch::x86::_mm_srl_epi32 fn'>_mm_srl_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Shifts packed 32-bit integers in <code>a</code> right by <code>count</code> while shifting in
zeros.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_srl_epi64.html" title='core::arch::x86::_mm_srl_epi64 fn'>_mm_srl_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Shifts packed 64-bit integers in <code>a</code> right by <code>count</code> while shifting in
zeros.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_srli_epi16.html" title='core::arch::x86::_mm_srli_epi16 fn'>_mm_srli_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Shifts packed 16-bit integers in <code>a</code> right by <code>imm8</code> while shifting in
zeros.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_srli_epi32.html" title='core::arch::x86::_mm_srli_epi32 fn'>_mm_srli_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Shifts packed 32-bit integers in <code>a</code> right by <code>imm8</code> while shifting in
zeros.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_srli_epi64.html" title='core::arch::x86::_mm_srli_epi64 fn'>_mm_srli_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Shifts packed 64-bit integers in <code>a</code> right by <code>imm8</code> while shifting in
zeros.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_srli_si128.html" title='core::arch::x86::_mm_srli_si128 fn'>_mm_srli_si128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Shifts <code>a</code> right by <code>imm8</code> bytes while shifting in zeros.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_srlv_epi32.html" title='core::arch::x86::_mm_srlv_epi32 fn'>_mm_srlv_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Shifts packed 32-bit integers in <code>a</code> right by the amount specified by
the corresponding element in <code>count</code> while shifting in zeros,</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_srlv_epi64.html" title='core::arch::x86::_mm_srlv_epi64 fn'>_mm_srlv_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx2</code></span><p>Shifts packed 64-bit integers in <code>a</code> right by the amount specified by
the corresponding element in <code>count</code> while shifting in zeros,</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_store1_ps.html" title='core::arch::x86::_mm_store1_ps fn'>_mm_store1_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Stores the lowest 32 bit float of <code>a</code> repeated four times into <em>aligned</em>
memory.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_store1_pd.html" title='core::arch::x86::_mm_store1_pd fn'>_mm_store1_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Stores the lower double-precision (64-bit) floating-point element from <code>a</code>
into 2 contiguous elements in memory. <code>mem_addr</code> must be aligned on a
16-byte boundary or a general-protection exception may be generated.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_store_pd.html" title='core::arch::x86::_mm_store_pd fn'>_mm_store_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Stores 128-bits (composed of 2 packed double-precision (64-bit)
floating-point elements) from <code>a</code> into memory. <code>mem_addr</code> must be aligned
on a 16-byte boundary or a general-protection exception may be generated.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_store_pd1.html" title='core::arch::x86::_mm_store_pd1 fn'>_mm_store_pd1</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Stores the lower double-precision (64-bit) floating-point element from <code>a</code>
into 2 contiguous elements in memory. <code>mem_addr</code> must be aligned on a
16-byte boundary or a general-protection exception may be generated.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_store_ps.html" title='core::arch::x86::_mm_store_ps fn'>_mm_store_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Stores four 32-bit floats into <em>aligned</em> memory.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_store_ps1.html" title='core::arch::x86::_mm_store_ps1 fn'>_mm_store_ps1</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Alias for <a href="fn._mm_store1_ps.html"><code>_mm_store1_ps</code></a></p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_store_sd.html" title='core::arch::x86::_mm_store_sd fn'>_mm_store_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Stores the lower 64 bits of a 128-bit vector of <code>[2 x double]</code> to a
memory location.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_store_si128.html" title='core::arch::x86::_mm_store_si128 fn'>_mm_store_si128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Stores 128-bits of integer data from <code>a</code> into memory.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_store_ss.html" title='core::arch::x86::_mm_store_ss fn'>_mm_store_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Stores the lowest 32 bit float of <code>a</code> into memory.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_storeh_pd.html" title='core::arch::x86::_mm_storeh_pd fn'>_mm_storeh_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Stores the upper 64 bits of a 128-bit vector of <code>[2 x double]</code> to a
memory location.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_storel_epi64.html" title='core::arch::x86::_mm_storel_epi64 fn'>_mm_storel_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Stores the lower 64-bit integer <code>a</code> to a memory location.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_storel_pd.html" title='core::arch::x86::_mm_storel_pd fn'>_mm_storel_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Stores the lower 64 bits of a 128-bit vector of <code>[2 x double]</code> to a
memory location.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_storer_pd.html" title='core::arch::x86::_mm_storer_pd fn'>_mm_storer_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Stores 2 double-precision (64-bit) floating-point elements from <code>a</code> into
memory in reverse order.
<code>mem_addr</code> must be aligned on a 16-byte boundary or a general-protection
exception may be generated.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_storer_ps.html" title='core::arch::x86::_mm_storer_ps fn'>_mm_storer_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Stores four 32-bit floats into <em>aligned</em> memory in reverse order.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_storeu_pd.html" title='core::arch::x86::_mm_storeu_pd fn'>_mm_storeu_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Stores 128-bits (composed of 2 packed double-precision (64-bit)
floating-point elements) from <code>a</code> into memory.
<code>mem_addr</code> does not need to be aligned on any particular boundary.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_storeu_ps.html" title='core::arch::x86::_mm_storeu_ps fn'>_mm_storeu_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Stores four 32-bit floats into memory. There are no restrictions on memory
alignment. For aligned memory <a href="fn._mm_store_ps.html"><code>_mm_store_ps</code></a> may be
faster.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_storeu_si128.html" title='core::arch::x86::_mm_storeu_si128 fn'>_mm_storeu_si128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Stores 128-bits of integer data from <code>a</code> into memory.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_stream_pd.html" title='core::arch::x86::_mm_stream_pd fn'>_mm_stream_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Stores a 128-bit floating point vector of <code>[2 x double]</code> to a 128-bit
aligned memory location.
To minimize caching, the data is flagged as non-temporal (unlikely to be
used again soon).</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_stream_ps.html" title='core::arch::x86::_mm_stream_ps fn'>_mm_stream_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Stores <code>a</code> into the memory at <code>mem_addr</code> using a non-temporal memory hint.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_stream_sd.html" title='core::arch::x86::_mm_stream_sd fn'>_mm_stream_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4a</code></span><p>Non-temporal store of <code>a.0</code> into <code>p</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_stream_si32.html" title='core::arch::x86::_mm_stream_si32 fn'>_mm_stream_si32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Stores a 32-bit integer value in the specified memory location.
To minimize caching, the data is flagged as non-temporal (unlikely to be
used again soon).</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_stream_si128.html" title='core::arch::x86::_mm_stream_si128 fn'>_mm_stream_si128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Stores a 128-bit integer vector to a 128-bit aligned memory location.
To minimize caching, the data is flagged as non-temporal (unlikely to be
used again soon).</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_stream_ss.html" title='core::arch::x86::_mm_stream_ss fn'>_mm_stream_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4a</code></span><p>Non-temporal store of <code>a.0</code> into <code>p</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_sub_epi8.html" title='core::arch::x86::_mm_sub_epi8 fn'>_mm_sub_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Subtracts packed 8-bit integers in <code>b</code> from packed 8-bit integers in <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_sub_epi16.html" title='core::arch::x86::_mm_sub_epi16 fn'>_mm_sub_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Subtracts packed 16-bit integers in <code>b</code> from packed 16-bit integers in <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_sub_epi32.html" title='core::arch::x86::_mm_sub_epi32 fn'>_mm_sub_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Subtract packed 32-bit integers in <code>b</code> from packed 32-bit integers in <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_sub_epi64.html" title='core::arch::x86::_mm_sub_epi64 fn'>_mm_sub_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Subtract packed 64-bit integers in <code>b</code> from packed 64-bit integers in <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_sub_pd.html" title='core::arch::x86::_mm_sub_pd fn'>_mm_sub_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Subtract packed double-precision (64-bit) floating-point elements in <code>b</code>
from <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_sub_ps.html" title='core::arch::x86::_mm_sub_ps fn'>_mm_sub_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Subtracts __m128 vectors.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_sub_sd.html" title='core::arch::x86::_mm_sub_sd fn'>_mm_sub_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Returns a new vector with the low element of <code>a</code> replaced by subtracting the
low element by <code>b</code> from the low element of <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_sub_ss.html" title='core::arch::x86::_mm_sub_ss fn'>_mm_sub_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Subtracts the first component of <code>b</code> from <code>a</code>, the other components are
copied from <code>a</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_subs_epi8.html" title='core::arch::x86::_mm_subs_epi8 fn'>_mm_subs_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Subtract packed 8-bit integers in <code>b</code> from packed 8-bit integers in <code>a</code>
using saturation.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_subs_epi16.html" title='core::arch::x86::_mm_subs_epi16 fn'>_mm_subs_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Subtract packed 16-bit integers in <code>b</code> from packed 16-bit integers in <code>a</code>
using saturation.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_subs_epu8.html" title='core::arch::x86::_mm_subs_epu8 fn'>_mm_subs_epu8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Subtract packed unsigned 8-bit integers in <code>b</code> from packed unsigned 8-bit
integers in <code>a</code> using saturation.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_subs_epu16.html" title='core::arch::x86::_mm_subs_epu16 fn'>_mm_subs_epu16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Subtract packed unsigned 16-bit integers in <code>b</code> from packed unsigned 16-bit
integers in <code>a</code> using saturation.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_test_all_ones.html" title='core::arch::x86::_mm_test_all_ones fn'>_mm_test_all_ones</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Tests whether the specified bits in <code>a</code> 128-bit integer vector are all
ones.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_test_all_zeros.html" title='core::arch::x86::_mm_test_all_zeros fn'>_mm_test_all_zeros</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Tests whether the specified bits in a 128-bit integer vector are all
zeros.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_test_mix_ones_zeros.html" title='core::arch::x86::_mm_test_mix_ones_zeros fn'>_mm_test_mix_ones_zeros</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Tests whether the specified bits in a 128-bit integer vector are
neither all zeros nor all ones.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_testc_pd.html" title='core::arch::x86::_mm_testc_pd fn'>_mm_testc_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Computes the bitwise AND of 128 bits (representing double-precision (64-bit)
floating-point elements) in <code>a</code> and <code>b</code>, producing an intermediate 128-bit
value, and set <code>ZF</code> to 1 if the sign bit of each 64-bit element in the
intermediate value is zero, otherwise set <code>ZF</code> to 0. Compute the bitwise
NOT of <code>a</code> and then AND with <code>b</code>, producing an intermediate value, and set
<code>CF</code> to 1 if the sign bit of each 64-bit element in the intermediate value
is zero, otherwise set <code>CF</code> to 0. Return the <code>CF</code> value.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_testc_ps.html" title='core::arch::x86::_mm_testc_ps fn'>_mm_testc_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Computes the bitwise AND of 128 bits (representing single-precision (32-bit)
floating-point elements) in <code>a</code> and <code>b</code>, producing an intermediate 128-bit
value, and set <code>ZF</code> to 1 if the sign bit of each 32-bit element in the
intermediate value is zero, otherwise set <code>ZF</code> to 0. Compute the bitwise
NOT of <code>a</code> and then AND with <code>b</code>, producing an intermediate value, and set
<code>CF</code> to 1 if the sign bit of each 32-bit element in the intermediate value
is zero, otherwise set <code>CF</code> to 0. Return the <code>CF</code> value.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_testc_si128.html" title='core::arch::x86::_mm_testc_si128 fn'>_mm_testc_si128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Tests whether the specified bits in a 128-bit integer vector are all
ones.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_testnzc_pd.html" title='core::arch::x86::_mm_testnzc_pd fn'>_mm_testnzc_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Computes the bitwise AND of 128 bits (representing double-precision (64-bit)
floating-point elements) in <code>a</code> and <code>b</code>, producing an intermediate 128-bit
value, and set <code>ZF</code> to 1 if the sign bit of each 64-bit element in the
intermediate value is zero, otherwise set <code>ZF</code> to 0. Compute the bitwise
NOT of <code>a</code> and then AND with <code>b</code>, producing an intermediate value, and set
<code>CF</code> to 1 if the sign bit of each 64-bit element in the intermediate value
is zero, otherwise set <code>CF</code> to 0. Return 1 if both the <code>ZF</code> and <code>CF</code> values
are zero, otherwise return 0.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_testnzc_ps.html" title='core::arch::x86::_mm_testnzc_ps fn'>_mm_testnzc_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Computes the bitwise AND of 128 bits (representing single-precision (32-bit)
floating-point elements) in <code>a</code> and <code>b</code>, producing an intermediate 128-bit
value, and set <code>ZF</code> to 1 if the sign bit of each 32-bit element in the
intermediate value is zero, otherwise set <code>ZF</code> to 0. Compute the bitwise
NOT of <code>a</code> and then AND with <code>b</code>, producing an intermediate value, and set
<code>CF</code> to 1 if the sign bit of each 32-bit element in the intermediate value
is zero, otherwise set <code>CF</code> to 0. Return 1 if both the <code>ZF</code> and <code>CF</code> values
are zero, otherwise return 0.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_testnzc_si128.html" title='core::arch::x86::_mm_testnzc_si128 fn'>_mm_testnzc_si128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Tests whether the specified bits in a 128-bit integer vector are
neither all zeros nor all ones.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_testz_pd.html" title='core::arch::x86::_mm_testz_pd fn'>_mm_testz_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Computes the bitwise AND of 128 bits (representing double-precision (64-bit)
floating-point elements) in <code>a</code> and <code>b</code>, producing an intermediate 128-bit
value, and set <code>ZF</code> to 1 if the sign bit of each 64-bit element in the
intermediate value is zero, otherwise set <code>ZF</code> to 0. Compute the bitwise
NOT of <code>a</code> and then AND with <code>b</code>, producing an intermediate value, and set
<code>CF</code> to 1 if the sign bit of each 64-bit element in the intermediate value
is zero, otherwise set <code>CF</code> to 0. Return the <code>ZF</code> value.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_testz_ps.html" title='core::arch::x86::_mm_testz_ps fn'>_mm_testz_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>avx</code></span><p>Computes the bitwise AND of 128 bits (representing single-precision (32-bit)
floating-point elements) in <code>a</code> and <code>b</code>, producing an intermediate 128-bit
value, and set <code>ZF</code> to 1 if the sign bit of each 32-bit element in the
intermediate value is zero, otherwise set <code>ZF</code> to 0. Compute the bitwise
NOT of <code>a</code> and then AND with <code>b</code>, producing an intermediate value, and set
<code>CF</code> to 1 if the sign bit of each 32-bit element in the intermediate value
is zero, otherwise set <code>CF</code> to 0. Return the <code>ZF</code> value.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_testz_si128.html" title='core::arch::x86::_mm_testz_si128 fn'>_mm_testz_si128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse4.1</code></span><p>Tests whether the specified bits in a 128-bit integer vector are all
zeros.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_tzcnt_32.html" title='core::arch::x86::_mm_tzcnt_32 fn'>_mm_tzcnt_32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>bmi1</code></span><p>Counts the number of trailing least significant zero bits.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_ucomieq_sd.html" title='core::arch::x86::_mm_ucomieq_sd fn'>_mm_ucomieq_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Compares the lower element of <code>a</code> and <code>b</code> for equality.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_ucomieq_ss.html" title='core::arch::x86::_mm_ucomieq_ss fn'>_mm_ucomieq_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Compares two 32-bit floats from the low-order bits of <code>a</code> and <code>b</code>. Returns
<code>1</code> if they are equal, or <code>0</code> otherwise. This instruction will not signal
an exception if either argument is a quiet NaN.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_ucomige_sd.html" title='core::arch::x86::_mm_ucomige_sd fn'>_mm_ucomige_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Compares the lower element of <code>a</code> and <code>b</code> for greater-than-or-equal.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_ucomige_ss.html" title='core::arch::x86::_mm_ucomige_ss fn'>_mm_ucomige_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Compares two 32-bit floats from the low-order bits of <code>a</code> and <code>b</code>. Returns
<code>1</code> if the value from <code>a</code> is greater than or equal to the one from <code>b</code>, or
<code>0</code> otherwise. This instruction will not signal an exception if either
argument is a quiet NaN.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_ucomigt_sd.html" title='core::arch::x86::_mm_ucomigt_sd fn'>_mm_ucomigt_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Compares the lower element of <code>a</code> and <code>b</code> for greater-than.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_ucomigt_ss.html" title='core::arch::x86::_mm_ucomigt_ss fn'>_mm_ucomigt_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Compares two 32-bit floats from the low-order bits of <code>a</code> and <code>b</code>. Returns
<code>1</code> if the value from <code>a</code> is greater than the one from <code>b</code>, or <code>0</code>
otherwise. This instruction will not signal an exception if either argument
is a quiet NaN.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_ucomile_sd.html" title='core::arch::x86::_mm_ucomile_sd fn'>_mm_ucomile_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Compares the lower element of <code>a</code> and <code>b</code> for less-than-or-equal.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_ucomile_ss.html" title='core::arch::x86::_mm_ucomile_ss fn'>_mm_ucomile_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Compares two 32-bit floats from the low-order bits of <code>a</code> and <code>b</code>. Returns
<code>1</code> if the value from <code>a</code> is less than or equal to the one from <code>b</code>, or <code>0</code>
otherwise. This instruction will not signal an exception if either argument
is a quiet NaN.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_ucomilt_sd.html" title='core::arch::x86::_mm_ucomilt_sd fn'>_mm_ucomilt_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Compares the lower element of <code>a</code> and <code>b</code> for less-than.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_ucomilt_ss.html" title='core::arch::x86::_mm_ucomilt_ss fn'>_mm_ucomilt_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Compares two 32-bit floats from the low-order bits of <code>a</code> and <code>b</code>. Returns
<code>1</code> if the value from <code>a</code> is less than the one from <code>b</code>, or <code>0</code> otherwise.
This instruction will not signal an exception if either argument is a quiet
NaN.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_ucomineq_sd.html" title='core::arch::x86::_mm_ucomineq_sd fn'>_mm_ucomineq_sd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Compares the lower element of <code>a</code> and <code>b</code> for not-equal.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_ucomineq_ss.html" title='core::arch::x86::_mm_ucomineq_ss fn'>_mm_ucomineq_ss</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Compares two 32-bit floats from the low-order bits of <code>a</code> and <code>b</code>. Returns
<code>1</code> if they are <strong>not</strong> equal, or <code>0</code> otherwise. This instruction will not
signal an exception if either argument is a quiet NaN.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_undefined_pd.html" title='core::arch::x86::_mm_undefined_pd fn'>_mm_undefined_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Returns vector of type __m128d with undefined elements.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_undefined_ps.html" title='core::arch::x86::_mm_undefined_ps fn'>_mm_undefined_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Returns vector of type __m128 with undefined elements.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_undefined_si128.html" title='core::arch::x86::_mm_undefined_si128 fn'>_mm_undefined_si128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Returns vector of type __m128i with undefined elements.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_unpackhi_epi8.html" title='core::arch::x86::_mm_unpackhi_epi8 fn'>_mm_unpackhi_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Unpacks and interleave 8-bit integers from the high half of <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_unpackhi_epi16.html" title='core::arch::x86::_mm_unpackhi_epi16 fn'>_mm_unpackhi_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Unpacks and interleave 16-bit integers from the high half of <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_unpackhi_epi32.html" title='core::arch::x86::_mm_unpackhi_epi32 fn'>_mm_unpackhi_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Unpacks and interleave 32-bit integers from the high half of <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_unpackhi_epi64.html" title='core::arch::x86::_mm_unpackhi_epi64 fn'>_mm_unpackhi_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Unpacks and interleave 64-bit integers from the high half of <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_unpackhi_pd.html" title='core::arch::x86::_mm_unpackhi_pd fn'>_mm_unpackhi_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>The resulting <code>__m128d</code> element is composed by the low-order values of
the two <code>__m128d</code> interleaved input elements, i.e.:</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_unpackhi_ps.html" title='core::arch::x86::_mm_unpackhi_ps fn'>_mm_unpackhi_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Unpacks and interleave single-precision (32-bit) floating-point elements
from the higher half of <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_unpacklo_epi8.html" title='core::arch::x86::_mm_unpacklo_epi8 fn'>_mm_unpacklo_epi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Unpacks and interleave 8-bit integers from the low half of <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_unpacklo_epi16.html" title='core::arch::x86::_mm_unpacklo_epi16 fn'>_mm_unpacklo_epi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Unpacks and interleave 16-bit integers from the low half of <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_unpacklo_epi32.html" title='core::arch::x86::_mm_unpacklo_epi32 fn'>_mm_unpacklo_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Unpacks and interleave 32-bit integers from the low half of <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_unpacklo_epi64.html" title='core::arch::x86::_mm_unpacklo_epi64 fn'>_mm_unpacklo_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Unpacks and interleave 64-bit integers from the low half of <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_unpacklo_pd.html" title='core::arch::x86::_mm_unpacklo_pd fn'>_mm_unpacklo_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>The resulting <code>__m128d</code> element is composed by the high-order values of
the two <code>__m128d</code> interleaved input elements, i.e.:</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_unpacklo_ps.html" title='core::arch::x86::_mm_unpacklo_ps fn'>_mm_unpacklo_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Unpacks and interleave single-precision (32-bit) floating-point elements
from the lower half of <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_xor_pd.html" title='core::arch::x86::_mm_xor_pd fn'>_mm_xor_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Computes the bitwise OR of <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_xor_ps.html" title='core::arch::x86::_mm_xor_ps fn'>_mm_xor_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse</code></span><p>Bitwise exclusive OR of packed single-precision (32-bit) floating-point
elements.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mm_xor_si128.html" title='core::arch::x86::_mm_xor_si128 fn'>_mm_xor_si128</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>sse2</code></span><p>Computes the bitwise XOR of 128 bits (representing integer data) in <code>a</code> and
<code>b</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._mulx_u32.html" title='core::arch::x86::_mulx_u32 fn'>_mulx_u32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>bmi2</code></span><p>Unsigned multiply without affecting flags.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._pdep_u32.html" title='core::arch::x86::_pdep_u32 fn'>_pdep_u32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>bmi2</code></span><p>Scatter contiguous low order bits of <code>a</code> to the result at the positions
specified by the <code>mask</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._pext_u32.html" title='core::arch::x86::_pext_u32 fn'>_pext_u32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>bmi2</code></span><p>Gathers the bits of <code>x</code> specified by the <code>mask</code> into the contiguous low
order bit positions of the result.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._popcnt32.html" title='core::arch::x86::_popcnt32 fn'>_popcnt32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>popcnt</code></span><p>Counts the bits that are set.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._rdrand16_step.html" title='core::arch::x86::_rdrand16_step fn'>_rdrand16_step</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>rdrand</code></span><p>Read a hardware generated 16-bit random value and store the result in val.
Returns 1 if a random value was generated, and 0 otherwise.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._rdrand32_step.html" title='core::arch::x86::_rdrand32_step fn'>_rdrand32_step</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>rdrand</code></span><p>Read a hardware generated 32-bit random value and store the result in val.
Returns 1 if a random value was generated, and 0 otherwise.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._rdseed16_step.html" title='core::arch::x86::_rdseed16_step fn'>_rdseed16_step</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>rdseed</code></span><p>Read a 16-bit NIST SP800-90B and SP800-90C compliant random value and store
in val. Return 1 if a random value was generated, and 0 otherwise.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._rdseed32_step.html" title='core::arch::x86::_rdseed32_step fn'>_rdseed32_step</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>rdseed</code></span><p>Read a 32-bit NIST SP800-90B and SP800-90C compliant random value and store
in val. Return 1 if a random value was generated, and 0 otherwise.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._rdtsc.html" title='core::arch::x86::_rdtsc fn'>_rdtsc</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Reads the current value of the processor’s time-stamp counter.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._subborrow_u32.html" title='core::arch::x86::_subborrow_u32 fn'>_subborrow_u32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86</span><p>Adds unsigned 32-bit integers <code>a</code> and <code>b</code> with unsigned 8-bit carry-in <code>c_in</code>
(carry or overflow flag), and store the unsigned 32-bit result in <code>out</code>, and
the carry-out is returned (carry or overflow flag).</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._t1mskc_u32.html" title='core::arch::x86::_t1mskc_u32 fn'>_t1mskc_u32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>tbm</code></span><p>Clears all bits below the least significant zero of <code>x</code> and sets all other
bits.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._t1mskc_u64.html" title='core::arch::x86::_t1mskc_u64 fn'>_t1mskc_u64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>tbm</code></span><p>Clears all bits below the least significant zero of <code>x</code> and sets all other
bits.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._tzcnt_u32.html" title='core::arch::x86::_tzcnt_u32 fn'>_tzcnt_u32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>bmi1</code></span><p>Counts the number of trailing least significant zero bits.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._tzmsk_u32.html" title='core::arch::x86::_tzmsk_u32 fn'>_tzmsk_u32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>tbm</code></span><p>Sets all bits below the least significant one of <code>x</code> and clears all other
bits.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._tzmsk_u64.html" title='core::arch::x86::_tzmsk_u64 fn'>_tzmsk_u64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>tbm</code></span><p>Sets all bits below the least significant one of <code>x</code> and clears all other
bits.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._xgetbv.html" title='core::arch::x86::_xgetbv fn'>_xgetbv</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>xsave</code></span><p>Reads the contents of the extended control register <code>XCR</code>
specified in <code>xcr_no</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._xrstor.html" title='core::arch::x86::_xrstor fn'>_xrstor</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>xsave</code></span><p>Performs a full or partial restore of the enabled processor states using
the state information stored in memory at <code>mem_addr</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._xrstors.html" title='core::arch::x86::_xrstors fn'>_xrstors</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>xsave,xsaves</code></span><p>Performs a full or partial restore of the enabled processor states using the
state information stored in memory at <code>mem_addr</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._xsave.html" title='core::arch::x86::_xsave fn'>_xsave</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>xsave</code></span><p>Performs a full or partial save of the enabled processor states to memory at
<code>mem_addr</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._xsavec.html" title='core::arch::x86::_xsavec fn'>_xsavec</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>xsave,xsavec</code></span><p>Performs a full or partial save of the enabled processor states to memory
at <code>mem_addr</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._xsaveopt.html" title='core::arch::x86::_xsaveopt fn'>_xsaveopt</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>xsave,xsaveopt</code></span><p>Performs a full or partial save of the enabled processor states to memory at
<code>mem_addr</code>.</p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._xsaves.html" title='core::arch::x86::_xsaves fn'>_xsaves</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>xsave,xsaves</code></span><p>Performs a full or partial save of the enabled processor states to memory at
<code>mem_addr</code></p>
</td></tr><tr class='module-item'><td><a class="fn" href="fn._xsetbv.html" title='core::arch::x86::_xsetbv fn'>_xsetbv</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab portability">x86 and <code>xsave</code></span><p>Copies 64-bits from <code>val</code> to the extended control register (<code>XCR</code>) specified
by <code>a</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._MM_SHUFFLE.html" title='core::arch::x86::_MM_SHUFFLE fn'>_MM_SHUFFLE</a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86</span><p>A utility function for creating masks to use with Intel shuffle and
permute intrinsics.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._bittest.html" title='core::arch::x86::_bittest fn'>_bittest</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86</span><p>Returns the bit in position <code>b</code> of the memory addressed by <code>p</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._bittestandcomplement.html" title='core::arch::x86::_bittestandcomplement fn'>_bittestandcomplement</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86</span><p>Returns the bit in position <code>b</code> of the memory addressed by <code>p</code>, then inverts that bit.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._bittestandreset.html" title='core::arch::x86::_bittestandreset fn'>_bittestandreset</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86</span><p>Returns the bit in position <code>b</code> of the memory addressed by <code>p</code>, then resets that bit to <code>0</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._bittestandset.html" title='core::arch::x86::_bittestandset fn'>_bittestandset</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86</span><p>Returns the bit in position <code>b</code> of the memory addressed by <code>p</code>, then sets the bit to <code>1</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._m_empty.html" title='core::arch::x86::_m_empty fn'>_m_empty</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Empty the MMX state, which marks the x87 FPU registers as available for use
by x87 instructions. This instruction must be used at the end of all MMX
technology procedures.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._m_maskmovq.html" title='core::arch::x86::_m_maskmovq fn'>_m_maskmovq</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Conditionally copies the values from each 8-bit element in the first
64-bit integer vector operand to the specified memory location, as
specified by the most significant bit in the corresponding element in the
second 64-bit integer vector operand.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._m_paddb.html" title='core::arch::x86::_m_paddb fn'>_m_paddb</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Adds packed 8-bit integers in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._m_paddd.html" title='core::arch::x86::_m_paddd fn'>_m_paddd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Adds packed 32-bit integers in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._m_paddsb.html" title='core::arch::x86::_m_paddsb fn'>_m_paddsb</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Adds packed 8-bit integers in <code>a</code> and <code>b</code> using saturation.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._m_paddsw.html" title='core::arch::x86::_m_paddsw fn'>_m_paddsw</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Adds packed 16-bit integers in <code>a</code> and <code>b</code> using saturation.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._m_paddusb.html" title='core::arch::x86::_m_paddusb fn'>_m_paddusb</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Adds packed unsigned 8-bit integers in <code>a</code> and <code>b</code> using saturation.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._m_paddusw.html" title='core::arch::x86::_m_paddusw fn'>_m_paddusw</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Adds packed unsigned 16-bit integers in <code>a</code> and <code>b</code> using saturation.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._m_paddw.html" title='core::arch::x86::_m_paddw fn'>_m_paddw</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Adds packed 16-bit integers in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._m_pavgb.html" title='core::arch::x86::_m_pavgb fn'>_m_pavgb</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Computes the rounded averages of the packed unsigned 8-bit integer
values and writes the averages to the corresponding bits in the
destination.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._m_pavgw.html" title='core::arch::x86::_m_pavgw fn'>_m_pavgw</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Computes the rounded averages of the packed unsigned 16-bit integer
values and writes the averages to the corresponding bits in the
destination.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._m_pextrw.html" title='core::arch::x86::_m_pextrw fn'>_m_pextrw</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Extracts 16-bit element from a 64-bit vector of <code>[4 x i16]</code> and
returns it, as specified by the immediate integer operand.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._m_pinsrw.html" title='core::arch::x86::_m_pinsrw fn'>_m_pinsrw</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Copies data from the 64-bit vector of <code>[4 x i16]</code> to the destination,
and inserts the lower 16-bits of an integer operand at the 16-bit offset
specified by the immediate operand <code>n</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._m_pmaxsw.html" title='core::arch::x86::_m_pmaxsw fn'>_m_pmaxsw</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Compares the packed 16-bit signed integers of <code>a</code> and <code>b</code> writing the
greatest value into the result.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._m_pmaxub.html" title='core::arch::x86::_m_pmaxub fn'>_m_pmaxub</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Compares the packed 8-bit signed integers of <code>a</code> and <code>b</code> writing the
greatest value into the result.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._m_pminsw.html" title='core::arch::x86::_m_pminsw fn'>_m_pminsw</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Compares the packed 16-bit signed integers of <code>a</code> and <code>b</code> writing the
smallest value into the result.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._m_pminub.html" title='core::arch::x86::_m_pminub fn'>_m_pminub</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Compares the packed 8-bit signed integers of <code>a</code> and <code>b</code> writing the
smallest value into the result.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._m_pmovmskb.html" title='core::arch::x86::_m_pmovmskb fn'>_m_pmovmskb</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Takes the most significant bit from each 8-bit element in a 64-bit
integer vector to create a 16-bit mask value. Zero-extends the value to
32-bit integer and writes it to the destination.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._m_pmulhuw.html" title='core::arch::x86::_m_pmulhuw fn'>_m_pmulhuw</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Multiplies packed 16-bit unsigned integer values and writes the
high-order 16 bits of each 32-bit product to the corresponding bits in
the destination.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._m_psadbw.html" title='core::arch::x86::_m_psadbw fn'>_m_psadbw</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Subtracts the corresponding 8-bit unsigned integer values of the two
64-bit vector operands and computes the absolute value for each of the
difference. Then sum of the 8 absolute differences is written to the
bits <code>[15:0]</code> of the destination; the remaining bits <code>[63:16]</code> are cleared.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._m_pshufw.html" title='core::arch::x86::_m_pshufw fn'>_m_pshufw</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Shuffles the 4 16-bit integers from a 64-bit integer vector to the
destination, as specified by the immediate value operand.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._m_psubb.html" title='core::arch::x86::_m_psubb fn'>_m_psubb</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Subtract packed 8-bit integers in <code>b</code> from packed 8-bit integers in <code>a</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._m_psubd.html" title='core::arch::x86::_m_psubd fn'>_m_psubd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Subtract packed 32-bit integers in <code>b</code> from packed 32-bit integers in <code>a</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._m_psubsb.html" title='core::arch::x86::_m_psubsb fn'>_m_psubsb</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Subtract packed 8-bit integers in <code>b</code> from packed 8-bit integers in <code>a</code>
using saturation.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._m_psubsw.html" title='core::arch::x86::_m_psubsw fn'>_m_psubsw</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Subtract packed 16-bit integers in <code>b</code> from packed 16-bit integers in <code>a</code>
using saturation.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._m_psubusb.html" title='core::arch::x86::_m_psubusb fn'>_m_psubusb</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Subtract packed unsigned 8-bit integers in <code>b</code> from packed unsigned 8-bit
integers in <code>a</code> using saturation.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._m_psubusw.html" title='core::arch::x86::_m_psubusw fn'>_m_psubusw</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Subtract packed unsigned 16-bit integers in <code>b</code> from packed unsigned
16-bit integers in <code>a</code> using saturation.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._m_psubw.html" title='core::arch::x86::_m_psubw fn'>_m_psubw</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Subtract packed 16-bit integers in <code>b</code> from packed 16-bit integers in <code>a</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm256_madd52hi_epu64.html" title='core::arch::x86::_mm256_madd52hi_epu64 fn'>_mm256_madd52hi_epu64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>avx512ifma,avx512vl</code></span><p>Multiply packed unsigned 52-bit integers in each 64-bit element of
<code>b</code> and <code>c</code> to form a 104-bit intermediate result. Add the high 52-bit
unsigned integer from the intermediate result with the
corresponding unsigned 64-bit integer in <code>a</code>, and store the
results in <code>dst</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm256_madd52lo_epu64.html" title='core::arch::x86::_mm256_madd52lo_epu64 fn'>_mm256_madd52lo_epu64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>avx512ifma,avx512vl</code></span><p>Multiply packed unsigned 52-bit integers in each 64-bit element of
<code>b</code> and <code>c</code> to form a 104-bit intermediate result. Add the low 52-bit
unsigned integer from the intermediate result with the
corresponding unsigned 64-bit integer in <code>a</code>, and store the
results in <code>dst</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm512_abs_epi32.html" title='core::arch::x86::_mm512_abs_epi32 fn'>_mm512_abs_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>avx512f</code></span><p>Computes the absolute values of packed 32-bit integers in <code>a</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm512_madd52hi_epu64.html" title='core::arch::x86::_mm512_madd52hi_epu64 fn'>_mm512_madd52hi_epu64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>avx512ifma</code></span><p>Multiply packed unsigned 52-bit integers in each 64-bit element of
<code>b</code> and <code>c</code> to form a 104-bit intermediate result. Add the high 52-bit
unsigned integer from the intermediate result with the
corresponding unsigned 64-bit integer in <code>a</code>, and store the
results in <code>dst</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm512_madd52lo_epu64.html" title='core::arch::x86::_mm512_madd52lo_epu64 fn'>_mm512_madd52lo_epu64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>avx512ifma</code></span><p>Multiply packed unsigned 52-bit integers in each 64-bit element of
<code>b</code> and <code>c</code> to form a 104-bit intermediate result. Add the low 52-bit
unsigned integer from the intermediate result with the
corresponding unsigned 64-bit integer in <code>a</code>, and store the
results in <code>dst</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm512_mask_abs_epi32.html" title='core::arch::x86::_mm512_mask_abs_epi32 fn'>_mm512_mask_abs_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>avx512f</code></span><p>Computes the absolute value of packed 32-bit integers in <code>a</code>, and store the
unsigned results in <code>dst</code> using writemask <code>k</code> (elements are copied from
<code>src</code> when the corresponding mask bit is not set).</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm512_maskz_abs_epi32.html" title='core::arch::x86::_mm512_maskz_abs_epi32 fn'>_mm512_maskz_abs_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>avx512f</code></span><p>Computes the absolute value of packed 32-bit integers in <code>a</code>, and store the
unsigned results in <code>dst</code> using zeromask <code>k</code> (elements are zeroed out when
the corresponding mask bit is not set).</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm512_set1_epi64.html" title='core::arch::x86::_mm512_set1_epi64 fn'>_mm512_set1_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>avx512f</code></span><p>Broadcast 64-bit integer <code>a</code> to all elements of <code>dst</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm512_setr_epi32.html" title='core::arch::x86::_mm512_setr_epi32 fn'>_mm512_setr_epi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>avx512f</code></span><p>Sets packed 32-bit integers in <code>dst</code> with the supplied values in reverse
order.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm512_setzero_si512.html" title='core::arch::x86::_mm512_setzero_si512 fn'>_mm512_setzero_si512</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>avx512f</code></span><p>Returns vector of type <code>__m512i</code> with all elements set to zero.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_abs_pi8.html" title='core::arch::x86::_mm_abs_pi8 fn'>_mm_abs_pi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>ssse3,mmx</code></span><p>Computes the absolute value of packed 8-bit integers in <code>a</code> and
return the unsigned results.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_abs_pi16.html" title='core::arch::x86::_mm_abs_pi16 fn'>_mm_abs_pi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>ssse3,mmx</code></span><p>Computes the absolute value of packed 8-bit integers in <code>a</code>, and returns the
unsigned results.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_abs_pi32.html" title='core::arch::x86::_mm_abs_pi32 fn'>_mm_abs_pi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>ssse3,mmx</code></span><p>Computes the absolute value of packed 32-bit integers in <code>a</code>, and returns the
unsigned results.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_add_pi8.html" title='core::arch::x86::_mm_add_pi8 fn'>_mm_add_pi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Adds packed 8-bit integers in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_add_pi16.html" title='core::arch::x86::_mm_add_pi16 fn'>_mm_add_pi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Adds packed 16-bit integers in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_add_pi32.html" title='core::arch::x86::_mm_add_pi32 fn'>_mm_add_pi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Adds packed 32-bit integers in <code>a</code> and <code>b</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_add_si64.html" title='core::arch::x86::_mm_add_si64 fn'>_mm_add_si64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse2,mmx</code></span><p>Adds two signed or unsigned 64-bit integer values, returning the
lower 64 bits of the sum.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_adds_pi8.html" title='core::arch::x86::_mm_adds_pi8 fn'>_mm_adds_pi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Adds packed 8-bit integers in <code>a</code> and <code>b</code> using saturation.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_adds_pi16.html" title='core::arch::x86::_mm_adds_pi16 fn'>_mm_adds_pi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Adds packed 16-bit integers in <code>a</code> and <code>b</code> using saturation.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_adds_pu8.html" title='core::arch::x86::_mm_adds_pu8 fn'>_mm_adds_pu8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Adds packed unsigned 8-bit integers in <code>a</code> and <code>b</code> using saturation.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_adds_pu16.html" title='core::arch::x86::_mm_adds_pu16 fn'>_mm_adds_pu16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Adds packed unsigned 16-bit integers in <code>a</code> and <code>b</code> using saturation.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_alignr_pi8.html" title='core::arch::x86::_mm_alignr_pi8 fn'>_mm_alignr_pi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>ssse3,mmx</code></span><p>Concatenates the two 64-bit integer vector operands, and right-shifts
the result by the number of bytes specified in the immediate operand.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_avg_pu8.html" title='core::arch::x86::_mm_avg_pu8 fn'>_mm_avg_pu8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Computes the rounded averages of the packed unsigned 8-bit integer
values and writes the averages to the corresponding bits in the
destination.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_avg_pu16.html" title='core::arch::x86::_mm_avg_pu16 fn'>_mm_avg_pu16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Computes the rounded averages of the packed unsigned 16-bit integer
values and writes the averages to the corresponding bits in the
destination.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_cmpgt_pi8.html" title='core::arch::x86::_mm_cmpgt_pi8 fn'>_mm_cmpgt_pi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Compares whether each element of <code>a</code> is greater than the corresponding
element of <code>b</code> returning <code>0</code> for <code>false</code> and <code>-1</code> for <code>true</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_cmpgt_pi16.html" title='core::arch::x86::_mm_cmpgt_pi16 fn'>_mm_cmpgt_pi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Compares whether each element of <code>a</code> is greater than the corresponding
element of <code>b</code> returning <code>0</code> for <code>false</code> and <code>-1</code> for <code>true</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_cmpgt_pi32.html" title='core::arch::x86::_mm_cmpgt_pi32 fn'>_mm_cmpgt_pi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Compares whether each element of <code>a</code> is greater than the corresponding
element of <code>b</code> returning <code>0</code> for <code>false</code> and <code>-1</code> for <code>true</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_cvt_pi2ps.html" title='core::arch::x86::_mm_cvt_pi2ps fn'>_mm_cvt_pi2ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Converts two elements of a 64-bit vector of <code>[2 x i32]</code> into two
floating point values and writes them to the lower 64-bits of the
destination. The remaining higher order elements of the destination are
copied from the corresponding elements in the first operand.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_cvt_ps2pi.html" title='core::arch::x86::_mm_cvt_ps2pi fn'>_mm_cvt_ps2pi</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Converts the two lower packed single-precision (32-bit) floating-point
elements in <code>a</code> to packed 32-bit integers.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_cvtpd_pi32.html" title='core::arch::x86::_mm_cvtpd_pi32 fn'>_mm_cvtpd_pi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse2,mmx</code></span><p>Converts the two double-precision floating-point elements of a
128-bit vector of <code>[2 x double]</code> into two signed 32-bit integer values,
returned in a 64-bit vector of <code>[2 x i32]</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_cvtpi8_ps.html" title='core::arch::x86::_mm_cvtpi8_ps fn'>_mm_cvtpi8_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Converts the lower 4 8-bit values of <code>a</code> into a 128-bit vector of 4 <code>f32</code>s.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_cvtpi16_ps.html" title='core::arch::x86::_mm_cvtpi16_ps fn'>_mm_cvtpi16_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Converts a 64-bit vector of <code>i16</code>s into a 128-bit vector of 4 <code>f32</code>s.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_cvtpi32_ps.html" title='core::arch::x86::_mm_cvtpi32_ps fn'>_mm_cvtpi32_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Converts two elements of a 64-bit vector of <code>[2 x i32]</code> into two
floating point values and writes them to the lower 64-bits of the
destination. The remaining higher order elements of the destination are
copied from the corresponding elements in the first operand.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_cvtpi32_pd.html" title='core::arch::x86::_mm_cvtpi32_pd fn'>_mm_cvtpi32_pd</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse2,mmx</code></span><p>Converts the two signed 32-bit integer elements of a 64-bit vector of
<code>[2 x i32]</code> into two double-precision floating-point values, returned in a
128-bit vector of <code>[2 x double]</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_cvtpi32x2_ps.html" title='core::arch::x86::_mm_cvtpi32x2_ps fn'>_mm_cvtpi32x2_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Converts the two 32-bit signed integer values from each 64-bit vector
operand of <code>[2 x i32]</code> into a 128-bit vector of <code>[4 x float]</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_cvtps_pi8.html" title='core::arch::x86::_mm_cvtps_pi8 fn'>_mm_cvtps_pi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Converts packed single-precision (32-bit) floating-point elements in <code>a</code> to
packed 8-bit integers, and returns theem in the lower 4 elements of the
result.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_cvtps_pi16.html" title='core::arch::x86::_mm_cvtps_pi16 fn'>_mm_cvtps_pi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Converts packed single-precision (32-bit) floating-point elements in <code>a</code> to
packed 16-bit integers.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_cvtps_pi32.html" title='core::arch::x86::_mm_cvtps_pi32 fn'>_mm_cvtps_pi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Converts the two lower packed single-precision (32-bit) floating-point
elements in <code>a</code> to packed 32-bit integers.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_cvtpu8_ps.html" title='core::arch::x86::_mm_cvtpu8_ps fn'>_mm_cvtpu8_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Converts the lower 4 8-bit values of <code>a</code> into a 128-bit vector of 4 <code>f32</code>s.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_cvtpu16_ps.html" title='core::arch::x86::_mm_cvtpu16_ps fn'>_mm_cvtpu16_ps</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Converts a 64-bit vector of <code>i16</code>s into a 128-bit vector of 4 <code>f32</code>s.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_cvtsi32_si64.html" title='core::arch::x86::_mm_cvtsi32_si64 fn'>_mm_cvtsi32_si64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Copies 32-bit integer <code>a</code> to the lower elements of the return value, and zero
the upper element of the return value.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_cvtsi64_si32.html" title='core::arch::x86::_mm_cvtsi64_si32 fn'>_mm_cvtsi64_si32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Return the lower 32-bit integer in <code>a</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_cvtt_ps2pi.html" title='core::arch::x86::_mm_cvtt_ps2pi fn'>_mm_cvtt_ps2pi</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Converts the two lower packed single-precision (32-bit) floating-point
elements in <code>a</code> to packed 32-bit integers with truncation.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_cvttpd_pi32.html" title='core::arch::x86::_mm_cvttpd_pi32 fn'>_mm_cvttpd_pi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse2,mmx</code></span><p>Converts the two double-precision floating-point elements of a
128-bit vector of <code>[2 x double]</code> into two signed 32-bit integer values,
returned in a 64-bit vector of <code>[2 x i32]</code>.
If the result of either conversion is inexact, the result is truncated
(rounded towards zero) regardless of the current MXCSR setting.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_cvttps_pi32.html" title='core::arch::x86::_mm_cvttps_pi32 fn'>_mm_cvttps_pi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Converts the two lower packed single-precision (32-bit) floating-point
elements in <code>a</code> to packed 32-bit integers with truncation.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_empty.html" title='core::arch::x86::_mm_empty fn'>_mm_empty</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Empty the MMX state, which marks the x87 FPU registers as available for use
by x87 instructions. This instruction must be used at the end of all MMX
technology procedures.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_extract_pi16.html" title='core::arch::x86::_mm_extract_pi16 fn'>_mm_extract_pi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Extracts 16-bit element from a 64-bit vector of <code>[4 x i16]</code> and
returns it, as specified by the immediate integer operand.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_hadd_pi16.html" title='core::arch::x86::_mm_hadd_pi16 fn'>_mm_hadd_pi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>ssse3,mmx</code></span><p>Horizontally adds the adjacent pairs of values contained in 2 packed
64-bit vectors of <code>[4 x i16]</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_hadd_pi32.html" title='core::arch::x86::_mm_hadd_pi32 fn'>_mm_hadd_pi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>ssse3,mmx</code></span><p>Horizontally adds the adjacent pairs of values contained in 2 packed
64-bit vectors of <code>[2 x i32]</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_hadds_pi16.html" title='core::arch::x86::_mm_hadds_pi16 fn'>_mm_hadds_pi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>ssse3,mmx</code></span><p>Horizontally adds the adjacent pairs of values contained in 2 packed
64-bit vectors of <code>[4 x i16]</code>. Positive sums greater than 7FFFh are
saturated to 7FFFh. Negative sums less than 8000h are saturated to 8000h.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_hsub_pi16.html" title='core::arch::x86::_mm_hsub_pi16 fn'>_mm_hsub_pi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>ssse3,mmx</code></span><p>Horizontally subtracts the adjacent pairs of values contained in 2
packed 64-bit vectors of <code>[4 x i16]</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_hsub_pi32.html" title='core::arch::x86::_mm_hsub_pi32 fn'>_mm_hsub_pi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>ssse3,mmx</code></span><p>Horizontally subtracts the adjacent pairs of values contained in 2
packed 64-bit vectors of <code>[2 x i32]</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_hsubs_pi16.html" title='core::arch::x86::_mm_hsubs_pi16 fn'>_mm_hsubs_pi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>ssse3,mmx</code></span><p>Horizontally subtracts the adjacent pairs of values contained in 2
packed 64-bit vectors of <code>[4 x i16]</code>. Positive differences greater than
7FFFh are saturated to 7FFFh. Negative differences less than 8000h are
saturated to 8000h.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_insert_pi16.html" title='core::arch::x86::_mm_insert_pi16 fn'>_mm_insert_pi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Copies data from the 64-bit vector of <code>[4 x i16]</code> to the destination,
and inserts the lower 16-bits of an integer operand at the 16-bit offset
specified by the immediate operand <code>n</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_loadh_pi.html" title='core::arch::x86::_mm_loadh_pi fn'>_mm_loadh_pi</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse</code></span><p>Sets the upper two single-precision floating-point values with 64 bits of
data loaded from the address <code>p</code>; the lower two values are passed through
from <code>a</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_loadl_pi.html" title='core::arch::x86::_mm_loadl_pi fn'>_mm_loadl_pi</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse</code></span><p>Loads two floats from <code>p</code> into the lower half of a <code>__m128</code>. The upper half
is copied from the upper half of <code>a</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_madd52hi_epu64.html" title='core::arch::x86::_mm_madd52hi_epu64 fn'>_mm_madd52hi_epu64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>avx512ifma,avx512vl</code></span><p>Multiply packed unsigned 52-bit integers in each 64-bit element of
<code>b</code> and <code>c</code> to form a 104-bit intermediate result. Add the high 52-bit
unsigned integer from the intermediate result with the
corresponding unsigned 64-bit integer in <code>a</code>, and store the
results in <code>dst</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_madd52lo_epu64.html" title='core::arch::x86::_mm_madd52lo_epu64 fn'>_mm_madd52lo_epu64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>avx512ifma,avx512vl</code></span><p>Multiply packed unsigned 52-bit integers in each 64-bit element of
<code>b</code> and <code>c</code> to form a 104-bit intermediate result. Add the low 52-bit
unsigned integer from the intermediate result with the
corresponding unsigned 64-bit integer in <code>a</code>, and store the
results in <code>dst</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_maddubs_pi16.html" title='core::arch::x86::_mm_maddubs_pi16 fn'>_mm_maddubs_pi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>ssse3,mmx</code></span><p>Multiplies corresponding pairs of packed 8-bit unsigned integer
values contained in the first source operand and packed 8-bit signed
integer values contained in the second source operand, adds pairs of
contiguous products with signed saturation, and writes the 16-bit sums to
the corresponding bits in the destination.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_maskmove_si64.html" title='core::arch::x86::_mm_maskmove_si64 fn'>_mm_maskmove_si64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Conditionally copies the values from each 8-bit element in the first
64-bit integer vector operand to the specified memory location, as
specified by the most significant bit in the corresponding element in the
second 64-bit integer vector operand.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_max_pi16.html" title='core::arch::x86::_mm_max_pi16 fn'>_mm_max_pi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Compares the packed 16-bit signed integers of <code>a</code> and <code>b</code> writing the
greatest value into the result.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_max_pu8.html" title='core::arch::x86::_mm_max_pu8 fn'>_mm_max_pu8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Compares the packed 8-bit signed integers of <code>a</code> and <code>b</code> writing the
greatest value into the result.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_min_pi16.html" title='core::arch::x86::_mm_min_pi16 fn'>_mm_min_pi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Compares the packed 16-bit signed integers of <code>a</code> and <code>b</code> writing the
smallest value into the result.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_min_pu8.html" title='core::arch::x86::_mm_min_pu8 fn'>_mm_min_pu8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Compares the packed 8-bit signed integers of <code>a</code> and <code>b</code> writing the
smallest value into the result.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_movemask_pi8.html" title='core::arch::x86::_mm_movemask_pi8 fn'>_mm_movemask_pi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Takes the most significant bit from each 8-bit element in a 64-bit
integer vector to create a 16-bit mask value. Zero-extends the value to
32-bit integer and writes it to the destination.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_movepi64_pi64.html" title='core::arch::x86::_mm_movepi64_pi64 fn'>_mm_movepi64_pi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse2,mmx</code></span><p>Returns the lower 64 bits of a 128-bit integer vector as a 64-bit
integer.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_movpi64_epi64.html" title='core::arch::x86::_mm_movpi64_epi64 fn'>_mm_movpi64_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse2,mmx</code></span><p>Moves the 64-bit operand to a 128-bit integer vector, zeroing the
upper bits.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_mul_su32.html" title='core::arch::x86::_mm_mul_su32 fn'>_mm_mul_su32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse2,mmx</code></span><p>Multiplies 32-bit unsigned integer values contained in the lower bits
of the two 64-bit integer vectors and returns the 64-bit unsigned
product.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_mulhi_pu16.html" title='core::arch::x86::_mm_mulhi_pu16 fn'>_mm_mulhi_pu16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Multiplies packed 16-bit unsigned integer values and writes the
high-order 16 bits of each 32-bit product to the corresponding bits in
the destination.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_mulhrs_pi16.html" title='core::arch::x86::_mm_mulhrs_pi16 fn'>_mm_mulhrs_pi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>ssse3,mmx</code></span><p>Multiplies packed 16-bit signed integer values, truncates the 32-bit
products to the 18 most significant bits by right-shifting, rounds the
truncated value by adding 1, and writes bits <code>[16:1]</code> to the destination.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_mullo_pi16.html" title='core::arch::x86::_mm_mullo_pi16 fn'>_mm_mullo_pi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Multiplies packed 16-bit integer values and writes the
low-order 16 bits of each 32-bit product to the corresponding bits in
the destination.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_packs_pi16.html" title='core::arch::x86::_mm_packs_pi16 fn'>_mm_packs_pi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Converts packed 16-bit integers from <code>a</code> and <code>b</code> to packed 8-bit integers
using signed saturation.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_packs_pi32.html" title='core::arch::x86::_mm_packs_pi32 fn'>_mm_packs_pi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Converts packed 32-bit integers from <code>a</code> and <code>b</code> to packed 16-bit integers
using signed saturation.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_sad_pu8.html" title='core::arch::x86::_mm_sad_pu8 fn'>_mm_sad_pu8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Subtracts the corresponding 8-bit unsigned integer values of the two
64-bit vector operands and computes the absolute value for each of the
difference. Then sum of the 8 absolute differences is written to the
bits <code>[15:0]</code> of the destination; the remaining bits <code>[63:16]</code> are cleared.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_set1_epi64.html" title='core::arch::x86::_mm_set1_epi64 fn'>_mm_set1_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse2,mmx</code></span><p>Initializes both values in a 128-bit vector of <code>[2 x i64]</code> with the
specified 64-bit value.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_set1_pi8.html" title='core::arch::x86::_mm_set1_pi8 fn'>_mm_set1_pi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Broadcasts 8-bit integer a to all all elements of dst.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_set1_pi16.html" title='core::arch::x86::_mm_set1_pi16 fn'>_mm_set1_pi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Broadcasts 16-bit integer a to all all elements of dst.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_set1_pi32.html" title='core::arch::x86::_mm_set1_pi32 fn'>_mm_set1_pi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Broadcasts 32-bit integer a to all all elements of dst.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_set_epi64.html" title='core::arch::x86::_mm_set_epi64 fn'>_mm_set_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse2,mmx</code></span><p>Initializes both 64-bit values in a 128-bit vector of <code>[2 x i64]</code> with
the specified 64-bit integer values.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_set_pi8.html" title='core::arch::x86::_mm_set_pi8 fn'>_mm_set_pi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Sets packed 8-bit integers in dst with the supplied values.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_set_pi16.html" title='core::arch::x86::_mm_set_pi16 fn'>_mm_set_pi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Sets packed 16-bit integers in dst with the supplied values.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_set_pi32.html" title='core::arch::x86::_mm_set_pi32 fn'>_mm_set_pi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Sets packed 32-bit integers in dst with the supplied values.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_setr_epi64.html" title='core::arch::x86::_mm_setr_epi64 fn'>_mm_setr_epi64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse2,mmx</code></span><p>Constructs a 128-bit integer vector, initialized in reverse order
with the specified 64-bit integral values.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_setr_pi8.html" title='core::arch::x86::_mm_setr_pi8 fn'>_mm_setr_pi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Sets packed 8-bit integers in dst with the supplied values in reverse order.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_setr_pi16.html" title='core::arch::x86::_mm_setr_pi16 fn'>_mm_setr_pi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Sets packed 16-bit integers in dst with the supplied values in reverse
order.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_setr_pi32.html" title='core::arch::x86::_mm_setr_pi32 fn'>_mm_setr_pi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Sets packed 32-bit integers in dst with the supplied values in reverse
order.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_setzero_si64.html" title='core::arch::x86::_mm_setzero_si64 fn'>_mm_setzero_si64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Constructs a 64-bit integer vector initialized to zero.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_shuffle_pi8.html" title='core::arch::x86::_mm_shuffle_pi8 fn'>_mm_shuffle_pi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>ssse3,mmx</code></span><p>Shuffles packed 8-bit integers in <code>a</code> according to shuffle control mask in
the corresponding 8-bit element of <code>b</code>, and returns the results</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_shuffle_pi16.html" title='core::arch::x86::_mm_shuffle_pi16 fn'>_mm_shuffle_pi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Shuffles the 4 16-bit integers from a 64-bit integer vector to the
destination, as specified by the immediate value operand.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_sign_pi8.html" title='core::arch::x86::_mm_sign_pi8 fn'>_mm_sign_pi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>ssse3,mmx</code></span><p>Negates packed 8-bit integers in <code>a</code> when the corresponding signed 8-bit
integer in <code>b</code> is negative, and returns the results.
Element in result are zeroed out when the corresponding element in <code>b</code> is
zero.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_sign_pi16.html" title='core::arch::x86::_mm_sign_pi16 fn'>_mm_sign_pi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>ssse3,mmx</code></span><p>Negates packed 16-bit integers in <code>a</code> when the corresponding signed 16-bit
integer in <code>b</code> is negative, and returns the results.
Element in result are zeroed out when the corresponding element in <code>b</code> is
zero.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_sign_pi32.html" title='core::arch::x86::_mm_sign_pi32 fn'>_mm_sign_pi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>ssse3,mmx</code></span><p>Negates packed 32-bit integers in <code>a</code> when the corresponding signed 32-bit
integer in <code>b</code> is negative, and returns the results.
Element in result are zeroed out when the corresponding element in <code>b</code> is
zero.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_storeh_pi.html" title='core::arch::x86::_mm_storeh_pi fn'>_mm_storeh_pi</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse</code></span><p>Stores the upper half of <code>a</code> (64 bits) into memory.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_storel_pi.html" title='core::arch::x86::_mm_storel_pi fn'>_mm_storel_pi</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse</code></span><p>Stores the lower half of <code>a</code> (64 bits) into memory.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_stream_pi.html" title='core::arch::x86::_mm_stream_pi fn'>_mm_stream_pi</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse,mmx</code></span><p>Stores 64-bits of integer data from a into memory using a non-temporal
memory hint.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_sub_pi8.html" title='core::arch::x86::_mm_sub_pi8 fn'>_mm_sub_pi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Subtract packed 8-bit integers in <code>b</code> from packed 8-bit integers in <code>a</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_sub_pi16.html" title='core::arch::x86::_mm_sub_pi16 fn'>_mm_sub_pi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Subtract packed 16-bit integers in <code>b</code> from packed 16-bit integers in <code>a</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_sub_pi32.html" title='core::arch::x86::_mm_sub_pi32 fn'>_mm_sub_pi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Subtract packed 32-bit integers in <code>b</code> from packed 32-bit integers in <code>a</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_sub_si64.html" title='core::arch::x86::_mm_sub_si64 fn'>_mm_sub_si64</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>sse2,mmx</code></span><p>Subtracts signed or unsigned 64-bit integer values and writes the
difference to the corresponding bits in the destination.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_subs_pi8.html" title='core::arch::x86::_mm_subs_pi8 fn'>_mm_subs_pi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Subtract packed 8-bit integers in <code>b</code> from packed 8-bit integers in <code>a</code>
using saturation.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_subs_pi16.html" title='core::arch::x86::_mm_subs_pi16 fn'>_mm_subs_pi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Subtract packed 16-bit integers in <code>b</code> from packed 16-bit integers in <code>a</code>
using saturation.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_subs_pu8.html" title='core::arch::x86::_mm_subs_pu8 fn'>_mm_subs_pu8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Subtract packed unsigned 8-bit integers in <code>b</code> from packed unsigned 8-bit
integers in <code>a</code> using saturation.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_subs_pu16.html" title='core::arch::x86::_mm_subs_pu16 fn'>_mm_subs_pu16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Subtract packed unsigned 16-bit integers in <code>b</code> from packed unsigned
16-bit integers in <code>a</code> using saturation.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_unpackhi_pi8.html" title='core::arch::x86::_mm_unpackhi_pi8 fn'>_mm_unpackhi_pi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Unpacks the upper four elements from two <code>i8x8</code> vectors and interleaves
them into the result: <code>[a.4, b.4, a.5, b.5, a.6, b.6, a.7, b.7]</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_unpackhi_pi16.html" title='core::arch::x86::_mm_unpackhi_pi16 fn'>_mm_unpackhi_pi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Unpacks the upper two elements from two <code>i16x4</code> vectors and interleaves
them into the result: <code>[a.2, b.2, a.3, b.3]</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_unpackhi_pi32.html" title='core::arch::x86::_mm_unpackhi_pi32 fn'>_mm_unpackhi_pi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Unpacks the upper element from two <code>i32x2</code> vectors and interleaves them
into the result: <code>[a.1, b.1]</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_unpacklo_pi8.html" title='core::arch::x86::_mm_unpacklo_pi8 fn'>_mm_unpacklo_pi8</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Unpacks the lower four elements from two <code>i8x8</code> vectors and interleaves
them into the result: <code>[a.0, b.0, a.1, b.1, a.2, b.2, a.3, b.3]</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_unpacklo_pi16.html" title='core::arch::x86::_mm_unpacklo_pi16 fn'>_mm_unpacklo_pi16</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Unpacks the lower two elements from two <code>i16x4</code> vectors and interleaves
them into the result: <code>[a.0 b.0 a.1 b.1]</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn._mm_unpacklo_pi32.html" title='core::arch::x86::_mm_unpacklo_pi32 fn'>_mm_unpacklo_pi32</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86 and <code>mmx</code></span><p>Unpacks the lower element from two <code>i32x2</code> vectors and interleaves them
into the result: <code>[a.0, b.0]</code>.</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn.has_cpuid.html" title='core::arch::x86::has_cpuid fn'>has_cpuid</a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86</span><p>Does the host support the <code>cpuid</code> instruction?</p>
</td></tr><tr class='unstable module-item'><td><a class="fn" href="fn.ud2.html" title='core::arch::x86::ud2 fn'>ud2</a><a title='unsafe function' href='#'><sup>⚠</sup></a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86</span><p>Generates the trap instruction <code>UD2</code></p>
</td></tr></table><h2 id='types' class='section-header'><a href="#types">Type Definitions</a></h2>
<table><tr class='unstable module-item'><td><a class="type" href="type.__mmask16.html" title='core::arch::x86::__mmask16 type'>__mmask16</a></td><td class='docblock-short'><span class="stab unstable">Experimental</span><span class="stab portability">x86</span><p>The <code>__mmask16</code> type used in AVX-512 intrinsics, a 16-bit integer</p>
</td></tr></table></section><section id="search" class="content hidden"></section><section class="footer"></section><aside id="help" class="hidden"><div><h1 class="hidden">Help</h1><div class="shortcuts"><h2>Keyboard Shortcuts</h2><dl><dt><kbd>?</kbd></dt><dd>Show this help dialog</dd><dt><kbd>S</kbd></dt><dd>Focus the search field</dd><dt><kbd>↑</kbd></dt><dd>Move up in search results</dd><dt><kbd>↓</kbd></dt><dd>Move down in search results</dd><dt><kbd>↹</kbd></dt><dd>Switch tab</dd><dt><kbd>&#9166;</kbd></dt><dd>Go to active search result</dd><dt><kbd>+</kbd></dt><dd>Expand all sections</dd><dt><kbd>-</kbd></dt><dd>Collapse all sections</dd></dl></div><div class="infos"><h2>Search Tricks</h2><p>Prefix searches with a type followed by a colon (e.g., <code>fn:</code>) to restrict the search to a given type.</p><p>Accepted types are: <code>fn</code>, <code>mod</code>, <code>struct</code>, <code>enum</code>, <code>trait</code>, <code>type</code>, <code>macro</code>, and <code>const</code>.</p><p>Search functions by type signature (e.g., <code>vec -> usize</code> or <code>* -> vec</code>)</p><p>Search multiple things at once by splitting your query with comma (e.g., <code>str,u8</code> or <code>String,struct:Vec,test</code>)</p></div></div></aside><script>window.rootPath = "../../../";window.currentCrate = "core";</script><script src="../../../aliases.js"></script><script src="../../../main1.35.0.js"></script><script defer src="../../../search-index.js"></script></body></html>