Struct ExtendedFeatures
pub struct ExtendedFeatures { /* private fields */ }
dep_raw_cpuid
only.Expand description
Implementations§
§impl ExtendedFeatures
impl ExtendedFeatures
pub const fn has_fsgsbase(&self) -> bool
pub const fn has_fsgsbase(&self) -> bool
pub const fn has_tsc_adjust_msr(&self) -> bool
pub const fn has_tsc_adjust_msr(&self) -> bool
pub const fn has_fdp(&self) -> bool
pub const fn has_fdp(&self) -> bool
FDP_EXCPTN_ONLY. x87 FPU Data Pointer updated only on x87 exceptions if 1.
§Platforms
❌ AMD (reserved) ✅ Intel
pub const fn has_rep_movsb_stosb(&self) -> bool
pub const fn has_rep_movsb_stosb(&self) -> bool
pub const fn has_invpcid(&self) -> bool
pub const fn has_invpcid(&self) -> bool
INVPCID. If 1, supports INVPCID instruction for system software that manages process-context identifiers.
§Platforms
❌ AMD (reserved) ✅ Intel
pub const fn has_rdtm(&self) -> bool
pub const fn has_rdtm(&self) -> bool
Supports Intel Resource Director Technology (RDT) Monitoring capability.
§Platforms
❌ AMD (reserved) ✅ Intel
pub const fn has_fpu_cs_ds_deprecated(&self) -> bool
pub const fn has_fpu_cs_ds_deprecated(&self) -> bool
pub const fn has_rdta(&self) -> bool
pub const fn has_rdta(&self) -> bool
Supports Intel Resource Director Technology (RDT) Allocation capability.
§Platforms
❌ AMD (reserved) ✅ Intel
pub const fn has_rdseed(&self) -> bool
pub const fn has_rdseed(&self) -> bool
pub const fn has_smap(&self) -> bool
pub const fn has_smap(&self) -> bool
SMAP. Supports Supervisor-Mode Access Prevention (and the CLAC/STAC instructions) if 1.
§Platforms
✅ AMD ✅ Intel
pub const fn has_clflushopt(&self) -> bool
pub const fn has_clflushopt(&self) -> bool
pub const fn has_processor_trace(&self) -> bool
pub const fn has_processor_trace(&self) -> bool
pub const fn has_sgx(&self) -> bool
pub const fn has_sgx(&self) -> bool
Supports Intel® Software Guard Extensions (Intel® SGX Extensions).
§Platforms
❌ AMD (reserved) ✅ Intel
pub const fn has_avx512f(&self) -> bool
pub const fn has_avx512f(&self) -> bool
pub const fn has_avx512dq(&self) -> bool
pub const fn has_avx512dq(&self) -> bool
pub const fn has_avx512_ifma(&self) -> bool
pub const fn has_avx512_ifma(&self) -> bool
pub const fn has_avx512pf(&self) -> bool
pub const fn has_avx512pf(&self) -> bool
pub const fn has_avx512er(&self) -> bool
pub const fn has_avx512er(&self) -> bool
pub const fn has_avx512cd(&self) -> bool
pub const fn has_avx512cd(&self) -> bool
pub const fn has_avx512bw(&self) -> bool
pub const fn has_avx512bw(&self) -> bool
pub const fn has_avx512vl(&self) -> bool
pub const fn has_avx512vl(&self) -> bool
pub const fn has_prefetchwt1(&self) -> bool
pub const fn has_prefetchwt1(&self) -> bool
pub const fn has_ospke(&self) -> bool
pub const fn has_ospke(&self) -> bool
OS has set CR4.PKE to enable protection keys (and the RDPKRU/WRPKRU instructions.
§Platforms
❌ AMD (reserved) ✅ Intel
pub const fn has_waitpkg(&self) -> bool
pub const fn has_waitpkg(&self) -> bool
WAITPKG
❓ AMD ✅ Intel
pub const fn has_av512vbmi2(&self) -> bool
pub const fn has_av512vbmi2(&self) -> bool
AVX512VBMI2
✅ AMD ✅ Intel
pub const fn has_cet_ss(&self) -> bool
pub const fn has_cet_ss(&self) -> bool
Supports CET shadow stack features. Processors that set this bit define bits 0..2 of the IA32_U_CET and IA32_S_CET MSRs. Enumerates support for the following MSRs: IA32_INTERRUPT_SPP_TABLE_ADDR, IA32_PL3_SSP, IA32_PL2_SSP, IA32_PL1_SSP, and IA32_PL0_SSP.
❓ AMD ✅ Intel
pub const fn has_vpclmulqdq(&self) -> bool
pub const fn has_vpclmulqdq(&self) -> bool
VPCLMULQDQ
❓ AMD ✅ Intel
pub const fn has_avx512vnni(&self) -> bool
pub const fn has_avx512vnni(&self) -> bool
pub const fn has_avx512bitalg(&self) -> bool
pub const fn has_avx512bitalg(&self) -> bool
AVX512BITALG
✅ AMD ✅ Intel
pub const fn has_tme_en(&self) -> bool
pub const fn has_tme_en(&self) -> bool
Indicates the following MSRs are supported: IA32_TME_CAPABILITY, IA32_TME_ACTIVATE, IA32_TME_EXCLUDE_MASK, and IA32_TME_EXCLUDE_BASE.
❓ AMD ✅ Intel
pub const fn has_avx512vpopcntdq(&self) -> bool
pub const fn has_avx512vpopcntdq(&self) -> bool
AVX512VPOPCNTDQ
✅ AMD ✅ Intel
pub const fn has_sgx_lc(&self) -> bool
pub const fn has_sgx_lc(&self) -> bool
pub fn mawau_value(&self) -> u8 ⓘ
pub fn mawau_value(&self) -> u8 ⓘ
The value of MAWAU used by the BNDLDX and BNDSTX instructions in 64-bit mode.
§Platforms
❌ AMD (reserved) ✅ Intel
pub const fn has_avx512_4vnniw(&self) -> bool
pub const fn has_avx512_4vnniw(&self) -> bool
pub const fn has_avx512_4fmaps(&self) -> bool
pub const fn has_avx512_4fmaps(&self) -> bool
pub const fn has_avx512_vp2intersect(&self) -> bool
pub const fn has_avx512_vp2intersect(&self) -> bool
pub const fn has_amx_bf16(&self) -> bool
pub const fn has_amx_bf16(&self) -> bool
pub const fn has_avx512_fp16(&self) -> bool
pub const fn has_avx512_fp16(&self) -> bool
pub const fn has_amx_tile(&self) -> bool
pub const fn has_amx_tile(&self) -> bool
pub const fn has_amx_int8(&self) -> bool
pub const fn has_amx_int8(&self) -> bool
pub const fn has_avx_vnni(&self) -> bool
pub const fn has_avx_vnni(&self) -> bool
pub const fn has_avx512_bf16(&self) -> bool
pub const fn has_avx512_bf16(&self) -> bool
pub const fn has_fsrcrs(&self) -> bool
pub const fn has_fsrcrs(&self) -> bool
pub const fn has_hreset(&self) -> bool
pub const fn has_hreset(&self) -> bool
pub const fn has_cet_sss(&self) -> bool
pub const fn has_cet_sss(&self) -> bool
Trait Implementations§
Auto Trait Implementations§
impl Freeze for ExtendedFeatures
impl RefUnwindSafe for ExtendedFeatures
impl Send for ExtendedFeatures
impl Sync for ExtendedFeatures
impl Unpin for ExtendedFeatures
impl UnwindSafe for ExtendedFeatures
Blanket Implementations§
§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
§type ArchivedMetadata = ()
type ArchivedMetadata = ()
§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> ByteSized for T
impl<T> ByteSized for T
Source§const BYTE_ALIGN: usize = _
const BYTE_ALIGN: usize = _
Source§fn byte_align(&self) -> usize ⓘ
fn byte_align(&self) -> usize ⓘ
Source§fn ptr_size_ratio(&self) -> [usize; 2]
fn ptr_size_ratio(&self) -> [usize; 2]
Source§impl<T, R> Chain<R> for Twhere
T: ?Sized,
impl<T, R> Chain<R> for Twhere
T: ?Sized,
Source§impl<T> ExtAny for T
impl<T> ExtAny for T
Source§fn as_any_mut(&mut self) -> &mut dyn Anywhere
Self: Sized,
fn as_any_mut(&mut self) -> &mut dyn Anywhere
Self: Sized,
Source§impl<T> ExtMem for Twhere
T: ?Sized,
impl<T> ExtMem for Twhere
T: ?Sized,
Source§const NEEDS_DROP: bool = _
const NEEDS_DROP: bool = _
Source§fn mem_align_of_val(&self) -> usize ⓘ
fn mem_align_of_val(&self) -> usize ⓘ
Source§fn mem_size_of_val(&self) -> usize ⓘ
fn mem_size_of_val(&self) -> usize ⓘ
Source§fn mem_needs_drop(&self) -> bool
fn mem_needs_drop(&self) -> bool
true
if dropping values of this type matters. Read moreSource§fn mem_forget(self)where
Self: Sized,
fn mem_forget(self)where
Self: Sized,
self
without running its destructor. Read moreSource§fn mem_replace(&mut self, other: Self) -> Selfwhere
Self: Sized,
fn mem_replace(&mut self, other: Self) -> Selfwhere
Self: Sized,
Source§unsafe fn mem_zeroed<T>() -> T
unsafe fn mem_zeroed<T>() -> T
unsafe_layout
only.T
represented by the all-zero byte-pattern. Read moreSource§unsafe fn mem_transmute_copy<Src, Dst>(src: &Src) -> Dst
unsafe fn mem_transmute_copy<Src, Dst>(src: &Src) -> Dst
unsafe_layout
only.T
represented by the all-zero byte-pattern. Read moreSource§fn mem_as_bytes(&self) -> &[u8] ⓘ
fn mem_as_bytes(&self) -> &[u8] ⓘ
unsafe_slice
only.§impl<S> FromSample<S> for S
impl<S> FromSample<S> for S
fn from_sample_(s: S) -> S
Source§impl<T> Hook for T
impl<T> Hook for T
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
§fn in_current_span(self) -> Instrumented<Self> ⓘ
fn in_current_span(self) -> Instrumented<Self> ⓘ
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more§impl<F, T> IntoSample<T> for Fwhere
T: FromSample<F>,
impl<F, T> IntoSample<T> for Fwhere
T: FromSample<F>,
fn into_sample(self) -> T
§impl<T> LayoutRaw for T
impl<T> LayoutRaw for T
§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError> ⓘ
fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError> ⓘ
§impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
§unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
§fn resolve_niched(out: Place<NichedOption<T, N1>>)
fn resolve_niched(out: Place<NichedOption<T, N1>>)
out
indicating that a T
is niched.