Module core::intrinsics 
source · core_intrinsics)Expand description
Compiler intrinsics.
The corresponding definitions are in https://github.com/rust-lang/rust/blob/master/compiler/rustc_codegen_llvm/src/intrinsic.rs. The corresponding const implementations are in https://github.com/rust-lang/rust/blob/master/compiler/rustc_const_eval/src/interpret/intrinsics.rs.
§Const intrinsics
Note: any changes to the constness of intrinsics should be discussed with the language team. This includes changes in the stability of the constness.
In order to make an intrinsic usable at compile-time, one needs to copy the implementation
from https://github.com/rust-lang/miri/blob/master/src/shims/intrinsics to
https://github.com/rust-lang/rust/blob/master/compiler/rustc_const_eval/src/interpret/intrinsics.rs and add a
#[rustc_const_unstable(feature = "const_such_and_such", issue = "01234")] to the intrinsic declaration.
If an intrinsic is supposed to be used from a const fn with a rustc_const_stable attribute,
the intrinsic’s attribute must be rustc_const_stable, too. Such a change should not be done
without T-lang consultation, because it bakes a feature into the language that cannot be
replicated in user code without compiler support.
§Volatiles
The volatile intrinsics provide operations intended to act on I/O memory, which are guaranteed to not be reordered by the compiler across other volatile intrinsics. See the LLVM documentation on [volatile].
§Atomics
The atomic intrinsics provide common atomic operations on machine words, with multiple possible memory orderings. They obey the same semantics as C++11. See the LLVM documentation on [atomics].
A quick refresher on memory ordering:
- Acquire - a barrier for acquiring a lock. Subsequent reads and writes take place after the barrier.
- Release - a barrier for releasing a lock. Preceding reads and writes take place before the barrier.
- Sequentially consistent - sequentially consistent operations are
guaranteed to happen in order. This is the standard mode for working
with atomic types and is equivalent to Java’s volatile.
§Unwinding
Rust intrinsics may, in general, unwind. If an intrinsic can never unwind, add the
#[rustc_nounwind] attribute so that the compiler can make use of this fact.
However, even for intrinsics that may unwind, rustc assumes that a Rust intrinsics will never initiate a foreign (non-Rust) unwind, and thus for panic=abort we can always assume that these intrinsics cannot unwind.
Modules§
- mirExperimentalRustc internal tooling for hand-writing MIR.
- simdExperimentalSIMD compiler intrinsics.
Traits§
- AggregateRawPtrExperimental
Functions§
- copy⚠Copiescount * size_of::<T>()bytes fromsrctodst. The source and destination may overlap.
- Copiescount * size_of::<T>()bytes fromsrctodst. The source and destination must not overlap.
- drop_in_place⚠Deprecated
- Reinterprets the bits of a value of one type as another type.
- Setscount * size_of::<T>()bytes of memory starting atdsttoval.
- abortExperimentalAborts the execution of the process.
- add_with_overflowExperimentalPerforms checked integer addition.
- aggregate_raw_ptrExperimentalLowers in MIR toRvalue::AggregatewithAggregateKind::RawPtr.
- arith_offset⚠ExperimentalCalculates the offset from a pointer, potentially wrapping.
- assert_inhabitedExperimentalA guard for unsafe functions that cannot ever be executed ifTis uninhabited: This will statically either panic, or do nothing.
- assert_mem_uninitialized_validExperimentalA guard forstd::mem::uninitialized. This will statically either panic, or do nothing.
- assert_zero_validExperimentalA guard for unsafe functions that cannot ever be executed ifTdoes not permit zero-initialization: This will statically either panic, or do nothing.
- assume⚠ExperimentalInforms the optimizer that a condition is always true. If the condition is false, the behavior is undefined.
- atomic_and_acqrel⚠ExperimentalBitwise and with the current value, returning the previous value.
- atomic_and_acquire⚠ExperimentalBitwise and with the current value, returning the previous value.
- atomic_and_relaxed⚠ExperimentalBitwise and with the current value, returning the previous value.
- atomic_and_release⚠ExperimentalBitwise and with the current value, returning the previous value.
- atomic_and_seqcst⚠ExperimentalBitwise and with the current value, returning the previous value.
- atomic_cxchg_acqrel_acquire⚠ExperimentalStores a value if the current value is the same as theoldvalue.
- atomic_cxchg_acqrel_relaxed⚠ExperimentalStores a value if the current value is the same as theoldvalue.
- atomic_cxchg_acqrel_seqcst⚠ExperimentalStores a value if the current value is the same as theoldvalue.
- atomic_cxchg_acquire_acquire⚠ExperimentalStores a value if the current value is the same as theoldvalue.
- atomic_cxchg_acquire_relaxed⚠ExperimentalStores a value if the current value is the same as theoldvalue.
- atomic_cxchg_acquire_seqcst⚠ExperimentalStores a value if the current value is the same as theoldvalue.
- atomic_cxchg_relaxed_acquire⚠ExperimentalStores a value if the current value is the same as theoldvalue.
- atomic_cxchg_relaxed_relaxed⚠ExperimentalStores a value if the current value is the same as theoldvalue.
- atomic_cxchg_relaxed_seqcst⚠ExperimentalStores a value if the current value is the same as theoldvalue.
- atomic_cxchg_release_acquire⚠ExperimentalStores a value if the current value is the same as theoldvalue.
- atomic_cxchg_release_relaxed⚠ExperimentalStores a value if the current value is the same as theoldvalue.
- atomic_cxchg_release_seqcst⚠ExperimentalStores a value if the current value is the same as theoldvalue.
- atomic_cxchg_seqcst_acquire⚠ExperimentalStores a value if the current value is the same as theoldvalue.
- atomic_cxchg_seqcst_relaxed⚠ExperimentalStores a value if the current value is the same as theoldvalue.
- atomic_cxchg_seqcst_seqcst⚠ExperimentalStores a value if the current value is the same as theoldvalue.
- atomic_cxchgweak_acqrel_acquire⚠ExperimentalStores a value if the current value is the same as theoldvalue.
- atomic_cxchgweak_acqrel_relaxed⚠ExperimentalStores a value if the current value is the same as theoldvalue.
- atomic_cxchgweak_acqrel_seqcst⚠ExperimentalStores a value if the current value is the same as theoldvalue.
- atomic_cxchgweak_acquire_acquire⚠ExperimentalStores a value if the current value is the same as theoldvalue.
- atomic_cxchgweak_acquire_relaxed⚠ExperimentalStores a value if the current value is the same as theoldvalue.
- atomic_cxchgweak_acquire_seqcst⚠ExperimentalStores a value if the current value is the same as theoldvalue.
- atomic_cxchgweak_relaxed_acquire⚠ExperimentalStores a value if the current value is the same as theoldvalue.
- atomic_cxchgweak_relaxed_relaxed⚠ExperimentalStores a value if the current value is the same as theoldvalue.
- atomic_cxchgweak_relaxed_seqcst⚠ExperimentalStores a value if the current value is the same as theoldvalue.
- atomic_cxchgweak_release_acquire⚠ExperimentalStores a value if the current value is the same as theoldvalue.
- atomic_cxchgweak_release_relaxed⚠ExperimentalStores a value if the current value is the same as theoldvalue.
- atomic_cxchgweak_release_seqcst⚠ExperimentalStores a value if the current value is the same as theoldvalue.
- atomic_cxchgweak_seqcst_acquire⚠ExperimentalStores a value if the current value is the same as theoldvalue.
- atomic_cxchgweak_seqcst_relaxed⚠ExperimentalStores a value if the current value is the same as theoldvalue.
- atomic_cxchgweak_seqcst_seqcst⚠ExperimentalStores a value if the current value is the same as theoldvalue.
- atomic_fence_acqrel⚠ExperimentalAn atomic fence.
- atomic_fence_acquire⚠ExperimentalAn atomic fence.
- atomic_fence_release⚠ExperimentalAn atomic fence.
- atomic_fence_seqcst⚠ExperimentalAn atomic fence.
- atomic_load_acquire⚠ExperimentalLoads the current value of the pointer.
- atomic_load_relaxed⚠ExperimentalLoads the current value of the pointer.
- atomic_load_seqcst⚠ExperimentalLoads the current value of the pointer.
- atomic_load_unordered⚠ExperimentalDo NOT use this intrinsic; “unordered” operations do not exist in our memory model! In terms of the Rust Abstract Machine, this operation is equivalent tosrc.read(), i.e., it performs a non-atomic read.
- atomic_max_acqrel⚠ExperimentalMaximum with the current value using a signed comparison.
- atomic_max_acquire⚠ExperimentalMaximum with the current value using a signed comparison.
- atomic_max_relaxed⚠ExperimentalMaximum with the current value.
- atomic_max_release⚠ExperimentalMaximum with the current value using a signed comparison.
- atomic_max_seqcst⚠ExperimentalMaximum with the current value using a signed comparison.
- atomic_min_acqrel⚠ExperimentalMinimum with the current value using a signed comparison.
- atomic_min_acquire⚠ExperimentalMinimum with the current value using a signed comparison.
- atomic_min_relaxed⚠ExperimentalMinimum with the current value using a signed comparison.
- atomic_min_release⚠ExperimentalMinimum with the current value using a signed comparison.
- atomic_min_seqcst⚠ExperimentalMinimum with the current value using a signed comparison.
- atomic_nand_acqrel⚠ExperimentalBitwise nand with the current value, returning the previous value.
- atomic_nand_acquire⚠ExperimentalBitwise nand with the current value, returning the previous value.
- atomic_nand_relaxed⚠ExperimentalBitwise nand with the current value, returning the previous value.
- atomic_nand_release⚠ExperimentalBitwise nand with the current value, returning the previous value.
- atomic_nand_seqcst⚠ExperimentalBitwise nand with the current value, returning the previous value.
- atomic_or_acqrel⚠ExperimentalBitwise or with the current value, returning the previous value.
- atomic_or_acquire⚠ExperimentalBitwise or with the current value, returning the previous value.
- atomic_or_relaxed⚠ExperimentalBitwise or with the current value, returning the previous value.
- atomic_or_release⚠ExperimentalBitwise or with the current value, returning the previous value.
- atomic_or_seqcst⚠ExperimentalBitwise or with the current value, returning the previous value.
- atomic_singlethreadfence_acqrel⚠ExperimentalA compiler-only memory barrier.
- atomic_singlethreadfence_acquire⚠ExperimentalA compiler-only memory barrier.
- atomic_singlethreadfence_release⚠ExperimentalA compiler-only memory barrier.
- atomic_singlethreadfence_seqcst⚠ExperimentalA compiler-only memory barrier.
- atomic_store_relaxed⚠ExperimentalStores the value at the specified memory location.
- atomic_store_release⚠ExperimentalStores the value at the specified memory location.
- atomic_store_seqcst⚠ExperimentalStores the value at the specified memory location.
- atomic_store_unordered⚠ExperimentalDo NOT use this intrinsic; “unordered” operations do not exist in our memory model! In terms of the Rust Abstract Machine, this operation is equivalent todst.write(val), i.e., it performs a non-atomic write.
- atomic_umax_acqrel⚠ExperimentalMaximum with the current value using an unsigned comparison.
- atomic_umax_acquire⚠ExperimentalMaximum with the current value using an unsigned comparison.
- atomic_umax_relaxed⚠ExperimentalMaximum with the current value using an unsigned comparison.
- atomic_umax_release⚠ExperimentalMaximum with the current value using an unsigned comparison.
- atomic_umax_seqcst⚠ExperimentalMaximum with the current value using an unsigned comparison.
- atomic_umin_acqrel⚠ExperimentalMinimum with the current value using an unsigned comparison.
- atomic_umin_acquire⚠ExperimentalMinimum with the current value using an unsigned comparison.
- atomic_umin_relaxed⚠ExperimentalMinimum with the current value using an unsigned comparison.
- atomic_umin_release⚠ExperimentalMinimum with the current value using an unsigned comparison.
- atomic_umin_seqcst⚠ExperimentalMinimum with the current value using an unsigned comparison.
- atomic_xadd_acqrel⚠ExperimentalAdds to the current value, returning the previous value.
- atomic_xadd_acquire⚠ExperimentalAdds to the current value, returning the previous value.
- atomic_xadd_relaxed⚠ExperimentalAdds to the current value, returning the previous value.
- atomic_xadd_release⚠ExperimentalAdds to the current value, returning the previous value.
- atomic_xadd_seqcst⚠ExperimentalAdds to the current value, returning the previous value.
- atomic_xchg_acqrel⚠ExperimentalStores the value at the specified memory location, returning the old value.
- atomic_xchg_acquire⚠ExperimentalStores the value at the specified memory location, returning the old value.
- atomic_xchg_relaxed⚠ExperimentalStores the value at the specified memory location, returning the old value.
- atomic_xchg_release⚠ExperimentalStores the value at the specified memory location, returning the old value.
- atomic_xchg_seqcst⚠ExperimentalStores the value at the specified memory location, returning the old value.
- atomic_xor_acqrel⚠ExperimentalBitwise xor with the current value, returning the previous value.
- atomic_xor_acquire⚠ExperimentalBitwise xor with the current value, returning the previous value.
- atomic_xor_relaxed⚠ExperimentalBitwise xor with the current value, returning the previous value.
- atomic_xor_release⚠ExperimentalBitwise xor with the current value, returning the previous value.
- atomic_xor_seqcst⚠ExperimentalBitwise xor with the current value, returning the previous value.
- atomic_xsub_acqrel⚠ExperimentalSubtract from the current value, returning the previous value.
- atomic_xsub_acquire⚠ExperimentalSubtract from the current value, returning the previous value.
- atomic_xsub_relaxed⚠ExperimentalSubtract from the current value, returning the previous value.
- atomic_xsub_release⚠ExperimentalSubtract from the current value, returning the previous value.
- atomic_xsub_seqcst⚠ExperimentalSubtract from the current value, returning the previous value.
- bitreverseExperimentalReverses the bits in an integer typeT.
- black_boxExperimentalSee documentation ofstd::hint::black_boxfor details.
- breakpoint⚠ExperimentalExecutes a breakpoint trap, for inspection by a debugger.
- bswapExperimentalReverses the bytes in an integer typeT.
- caller_locationExperimentalGets a reference to a staticLocationindicating where it was called.
- catch_unwind⚠ExperimentalRust’s “try catch” construct for unwinding. Invokes the function pointertry_fnwith the data pointerdata, and callscatch_fnif unwinding occurs whiletry_fnruns.
- ceilf32⚠ExperimentalReturns the smallest integer greater than or equal to anf32.
- ceilf64⚠ExperimentalReturns the smallest integer greater than or equal to anf64.
- compare_bytes⚠ExperimentalLexicographically compare[left, left + bytes)and[right, right + bytes)as unsigned bytes, returning negative ifleftis less, zero if all the bytes match, or positive ifrightis greater.
- const_allocate⚠ExperimentalAllocates a block of memory at compile time. At runtime, just returns a null pointer.
- const_deallocate⚠ExperimentalDeallocates a memory which allocated byintrinsics::const_allocateat compile time. At runtime, does nothing.
- const_eval_selectExperimentalSelects which function to call depending on the context.
- copysignf32⚠ExperimentalCopies the sign fromytoxforf32values.
- copysignf64⚠ExperimentalCopies the sign fromytoxforf64values.
- cosf32⚠ExperimentalReturns the cosine of anf32.
- cosf64⚠ExperimentalReturns the cosine of anf64.
- ctlzExperimentalReturns the number of leading unset bits (zeroes) in an integer typeT.
- ctlz_nonzero⚠ExperimentalLikectlz, but extra-unsafe as it returnsundefwhen given anxwith value0.
- ctpopExperimentalReturns the number of bits set in an integer typeT
- cttzExperimentalReturns the number of trailing unset bits (zeroes) in an integer typeT.
- cttz_nonzero⚠ExperimentalLikecttz, but extra-unsafe as it returnsundefwhen given anxwith value0.
- discriminant_valueExperimentalReturns the value of the discriminant for the variant in ‘v’; ifThas no discriminant, returns0.
- exact_div⚠ExperimentalPerforms an exact division, resulting in undefined behavior wherex % y != 0ory == 0orx == T::MIN && y == -1
- exp2f32⚠ExperimentalReturns 2 raised to the power of anf32.
- exp2f64⚠ExperimentalReturns 2 raised to the power of anf64.
- expf32⚠ExperimentalReturns the exponential of anf32.
- expf64⚠ExperimentalReturns the exponential of anf64.
- fabsf32⚠ExperimentalReturns the absolute value of anf32.
- fabsf64⚠ExperimentalReturns the absolute value of anf64.
- fadd_algebraicExperimentalFloat addition that allows optimizations based on algebraic rules.
- fadd_fast⚠ExperimentalFloat addition that allows optimizations based on algebraic rules. May assume inputs are finite.
- fdiv_algebraicExperimentalFloat division that allows optimizations based on algebraic rules.
- fdiv_fast⚠ExperimentalFloat division that allows optimizations based on algebraic rules. May assume inputs are finite.
- float_to_int_unchecked⚠ExperimentalConvert with LLVM’s fptoui/fptosi, which may return undef for values out of range (https://github.com/rust-lang/rust/issues/10184)
- floorf32⚠ExperimentalReturns the largest integer less than or equal to anf32.
- floorf64⚠ExperimentalReturns the largest integer less than or equal to anf64.
- fmaf32⚠ExperimentalReturnsa * b + cforf32values.
- fmaf64⚠ExperimentalReturnsa * b + cforf64values.
- fmul_algebraicExperimentalFloat multiplication that allows optimizations based on algebraic rules.
- fmul_fast⚠ExperimentalFloat multiplication that allows optimizations based on algebraic rules. May assume inputs are finite.
- forgetExperimentalMoves a value out of scope without running drop glue.
- frem_algebraicExperimentalFloat remainder that allows optimizations based on algebraic rules.
- frem_fast⚠ExperimentalFloat remainder that allows optimizations based on algebraic rules. May assume inputs are finite.
- fsub_algebraicExperimentalFloat subtraction that allows optimizations based on algebraic rules.
- fsub_fast⚠ExperimentalFloat subtraction that allows optimizations based on algebraic rules. May assume inputs are finite.
- is_val_statically_knownExperimentalReturns whether the argument’s value is statically known at compile-time.
- likelyExperimentalHints to the compiler that branch condition is likely to be true. Returns the value passed to it.
- log2f32⚠ExperimentalReturns the base 2 logarithm of anf32.
- log2f64⚠ExperimentalReturns the base 2 logarithm of anf64.
- log10f32⚠ExperimentalReturns the base 10 logarithm of anf32.
- log10f64⚠ExperimentalReturns the base 10 logarithm of anf64.
- logf32⚠ExperimentalReturns the natural logarithm of anf32.
- logf64⚠ExperimentalReturns the natural logarithm of anf64.
- maxnumf32ExperimentalReturns the maximum of twof32values.
- maxnumf64ExperimentalReturns the maximum of twof64values.
- min_align_ofExperimentalThe minimum alignment of a type.
- min_align_of_val⚠ExperimentalThe required alignment of the referenced value.
- minnumf32ExperimentalReturns the minimum of twof32values.
- minnumf64ExperimentalReturns the minimum of twof64values.
- mul_with_overflowExperimentalPerforms checked integer multiplication
- nearbyintf32⚠ExperimentalReturns the nearest integer to anf32. Changing the rounding mode is not possible in Rust, so this rounds half-way cases to the number with an even least significant digit.
- nearbyintf64⚠ExperimentalReturns the nearest integer to anf64. Changing the rounding mode is not possible in Rust, so this rounds half-way cases to the number with an even least significant digit.
- needs_dropExperimentalReturnstrueif the actual type given asTrequires drop glue; returnsfalseif the actual type provided forTimplementsCopy.
- nontemporal_store⚠ExperimentalEmits a!nontemporalstore according to LLVM (see their docs). Probably will never become stable.
- offset⚠ExperimentalCalculates the offset from a pointer.
- powf32⚠ExperimentalRaises anf32to anf32power.
- powf64⚠ExperimentalRaises anf64to anf64power.
- powif32⚠ExperimentalRaises anf32to an integer power.
- powif64⚠ExperimentalRaises anf64to an integer power.
- pref_align_of⚠ExperimentalThe preferred alignment of a type.
- prefetch_read_data⚠ExperimentalTheprefetchintrinsic is a hint to the code generator to insert a prefetch instruction if supported; otherwise, it is a no-op. Prefetches have no effect on the behavior of the program but can change its performance characteristics.
- prefetch_read_instruction⚠ExperimentalTheprefetchintrinsic is a hint to the code generator to insert a prefetch instruction if supported; otherwise, it is a no-op. Prefetches have no effect on the behavior of the program but can change its performance characteristics.
- prefetch_write_data⚠ExperimentalTheprefetchintrinsic is a hint to the code generator to insert a prefetch instruction if supported; otherwise, it is a no-op. Prefetches have no effect on the behavior of the program but can change its performance characteristics.
- prefetch_write_instruction⚠ExperimentalTheprefetchintrinsic is a hint to the code generator to insert a prefetch instruction if supported; otherwise, it is a no-op. Prefetches have no effect on the behavior of the program but can change its performance characteristics.
- ptr_guaranteed_cmpExperimentalSee documentation of<*const T>::guaranteed_eqfor details. Returns2if the result is unknown. Returns1if the pointers are guaranteed equal Returns0if the pointers are guaranteed inequal
- ptr_maskExperimentalMasks out bits of the pointer according to a mask.
- ptr_offset_from⚠ExperimentalSee documentation of<*const T>::offset_fromfor details.
- ptr_offset_from_unsigned⚠ExperimentalSee documentation of<*const T>::sub_ptrfor details.
- raw_eq⚠ExperimentalDetermines whether the raw bytes of the two values are equal.
- read_via_copy⚠ExperimentalThis is an implementation detail ofcrate::ptr::readand should not be used anywhere else. See its comments for why this exists.
- rintf32⚠ExperimentalReturns the nearest integer to anf32. Changing the rounding mode is not possible in Rust, so this rounds half-way cases to the number with an even least significant digit.
- rintf64⚠ExperimentalReturns the nearest integer to anf64. Changing the rounding mode is not possible in Rust, so this rounds half-way cases to the number with an even least significant digit.
- rotate_leftExperimentalPerforms rotate left.
- rotate_rightExperimentalPerforms rotate right.
- roundevenf32⚠ExperimentalReturns the nearest integer to anf32. Rounds half-way cases to the number with an even least significant digit.
- roundevenf64⚠ExperimentalReturns the nearest integer to anf64. Rounds half-way cases to the number with an even least significant digit.
- roundf32⚠ExperimentalReturns the nearest integer to anf32. Rounds half-way cases away from zero.
- roundf64⚠ExperimentalReturns the nearest integer to anf64. Rounds half-way cases away from zero.
- rustc_peekExperimentalMagic intrinsic that derives its meaning from attributes attached to the function.
- saturating_addExperimentalComputesa + b, saturating at numeric bounds.
- saturating_subExperimentalComputesa - b, saturating at numeric bounds.
- sinf32⚠ExperimentalReturns the sine of anf32.
- sinf64⚠ExperimentalReturns the sine of anf64.
- size_ofExperimentalThe size of a type in bytes.
- size_of_val⚠ExperimentalThe size of the referenced value in bytes.
- sqrtf32⚠ExperimentalReturns the square root of anf32
- sqrtf64⚠ExperimentalReturns the square root of anf64
- sub_with_overflowExperimentalPerforms checked integer subtraction
- three_way_compareExperimentalDoes a three-way comparison between the two integer arguments.
- transmute_unchecked⚠ExperimentalLiketransmute, but even less checked at compile-time: rather than giving an error forsize_of::<Src>() != size_of::<Dst>(), it’s Undefined Behaviour at runtime.
- truncf32⚠ExperimentalReturns the integer part of anf32.
- truncf64⚠ExperimentalReturns the integer part of anf64.
- type_idExperimentalGets an identifier which is globally unique to the specified type. This function will return the same value for a type regardless of whichever crate it is invoked in.
- type_nameExperimentalGets a static string slice containing the name of a type.
- typed_swap⚠ExperimentalNon-overlapping typed swap of a single value.
- unaligned_volatile_load⚠ExperimentalPerforms a volatile load from thesrcpointer The pointer is not required to be aligned.
- unaligned_volatile_store⚠ExperimentalPerforms a volatile store to thedstpointer. The pointer is not required to be aligned.
- unchecked_add⚠ExperimentalReturns the result of an unchecked addition, resulting in undefined behavior whenx + y > T::MAXorx + y < T::MIN.
- unchecked_div⚠ExperimentalPerforms an unchecked division, resulting in undefined behavior wherey == 0orx == T::MIN && y == -1
- unchecked_mul⚠ExperimentalReturns the result of an unchecked multiplication, resulting in undefined behavior whenx * y > T::MAXorx * y < T::MIN.
- unchecked_rem⚠ExperimentalReturns the remainder of an unchecked division, resulting in undefined behavior wheny == 0orx == T::MIN && y == -1
- unchecked_shl⚠ExperimentalPerforms an unchecked left shift, resulting in undefined behavior wheny < 0ory >= N, where N is the width of T in bits.
- unchecked_shr⚠ExperimentalPerforms an unchecked right shift, resulting in undefined behavior wheny < 0ory >= N, where N is the width of T in bits.
- unchecked_sub⚠ExperimentalReturns the result of an unchecked subtraction, resulting in undefined behavior whenx - y > T::MAXorx - y < T::MIN.
- unlikelyExperimentalHints to the compiler that branch condition is likely to be false. Returns the value passed to it.
- unreachable⚠ExperimentalInforms the optimizer that this point in the code is not reachable, enabling further optimizations.
- variant_countExperimentalReturns the number of variants of the typeTcast to ausize; ifThas no variants, returns0. Uninhabited variants will be counted.
- volatile_copy_memory⚠ExperimentalEquivalent to the appropriatellvm.memmove.p0i8.0i8.*intrinsic, with a size ofcount * size_of::<T>()and an alignment ofmin_align_of::<T>()
- volatile_copy_nonoverlapping_memory⚠ExperimentalEquivalent to the appropriatellvm.memcpy.p0i8.0i8.*intrinsic, with a size ofcount*size_of::<T>()and an alignment ofmin_align_of::<T>()
- volatile_load⚠ExperimentalPerforms a volatile load from thesrcpointer.
- volatile_set_memory⚠ExperimentalEquivalent to the appropriatellvm.memset.p0i8.*intrinsic, with a size ofcount * size_of::<T>()and an alignment ofmin_align_of::<T>().
- volatile_store⚠ExperimentalPerforms a volatile store to thedstpointer.
- vtable_align⚠Experimentalptrmust point to a vtable. The intrinsic will return the alignment stored in that vtable.
- vtable_size⚠Experimentalptrmust point to a vtable. The intrinsic will return the size stored in that vtable.
- wrapping_addExperimentalReturns (a + b) mod 2N, where N is the width of T in bits.
- wrapping_mulExperimentalReturns (a * b) mod 2N, where N is the width of T in bits.
- wrapping_subExperimentalReturns (a - b) mod 2N, where N is the width of T in bits.
- write_via_move⚠ExperimentalThis is an implementation detail ofcrate::ptr::writeand should not be used anywhere else. See its comments for why this exists.