raw_cpuid

Struct ExtendedFeatures

source
pub struct ExtendedFeatures { /* private fields */ }
Expand description

Structured Extended Feature Identifiers (LEAF=0x07).

§Platforms

🟡 AMD ✅ Intel

Implementations§

source§

impl ExtendedFeatures

source

pub const fn has_fsgsbase(&self) -> bool

FSGSBASE. Supports RDFSBASE/RDGSBASE/WRFSBASE/WRGSBASE if 1.

§Platforms

✅ AMD ✅ Intel

source

pub const fn has_tsc_adjust_msr(&self) -> bool

IA32_TSC_ADJUST MSR is supported if 1.

§Platforms

❌ AMD (reserved) ✅ Intel

source

pub const fn has_bmi1(&self) -> bool

BMI1

§Platforms

✅ AMD ✅ Intel

source

pub const fn has_hle(&self) -> bool

HLE

§Platforms

❌ AMD (reserved) ✅ Intel

source

pub const fn has_avx2(&self) -> bool

AVX2

§Platforms

✅ AMD ✅ Intel

source

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

source

pub const fn has_smep(&self) -> bool

SMEP. Supports Supervisor-Mode Execution Prevention if 1.

§Platforms

✅ AMD ✅ Intel

source

pub const fn has_bmi2(&self) -> bool

BMI2

§Platforms

✅ AMD ✅ Intel

source

pub const fn has_rep_movsb_stosb(&self) -> bool

Supports Enhanced REP MOVSB/STOSB if 1.

§Platforms

❌ AMD (reserved) ✅ Intel

source

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

source

pub const fn has_rtm(&self) -> bool

RTM

§Platforms

❌ AMD (reserved) ✅ Intel

source

pub const fn has_rdtm(&self) -> bool

Supports Intel Resource Director Technology (RDT) Monitoring capability.

§Platforms

❌ AMD (reserved) ✅ Intel

source

pub const fn has_fpu_cs_ds_deprecated(&self) -> bool

Deprecates FPU CS and FPU DS values if 1.

§Platforms

❌ AMD (reserved) ✅ Intel

source

pub const fn has_mpx(&self) -> bool

MPX. Supports Intel Memory Protection Extensions if 1.

§Platforms

❌ AMD (reserved) ✅ Intel

source

pub const fn has_rdta(&self) -> bool

Supports Intel Resource Director Technology (RDT) Allocation capability.

§Platforms

❌ AMD (reserved) ✅ Intel

source

pub const fn has_rdseed(&self) -> bool

Supports RDSEED.

§Platforms

✅ AMD ✅ Intel

source

pub const fn has_adx(&self) -> bool

Supports ADX.

§Platforms

✅ AMD ✅ Intel

source

pub const fn has_smap(&self) -> bool

SMAP. Supports Supervisor-Mode Access Prevention (and the CLAC/STAC instructions) if 1.

§Platforms

✅ AMD ✅ Intel

source

pub const fn has_clflushopt(&self) -> bool

Supports CLFLUSHOPT.

§Platforms

✅ AMD ✅ Intel

source

pub const fn has_processor_trace(&self) -> bool

Supports Intel Processor Trace.

§Platforms

❌ AMD (reserved) ✅ Intel

source

pub const fn has_sha(&self) -> bool

Supports SHA Instructions.

§Platforms

❌ AMD (reserved) ✅ Intel

source

pub const fn has_sgx(&self) -> bool

Supports Intel® Software Guard Extensions (Intel® SGX Extensions).

§Platforms

❌ AMD (reserved) ✅ Intel

source

pub const fn has_avx512f(&self) -> bool

Supports AVX512F.

§Platforms

✅ AMD ✅ Intel

source

pub const fn has_avx512dq(&self) -> bool

Supports AVX512DQ.

§Platforms

✅ AMD ✅ Intel

source

pub const fn has_avx512_ifma(&self) -> bool

AVX512_IFMA

§Platforms

✅ AMD ✅ Intel

source

pub const fn has_avx512pf(&self) -> bool

AVX512PF

§Platforms

✅ AMD ✅ Intel

source

pub const fn has_avx512er(&self) -> bool

AVX512ER

§Platforms

✅ AMD ✅ Intel

source

pub const fn has_avx512cd(&self) -> bool

AVX512CD

§Platforms

✅ AMD ✅ Intel

source

pub const fn has_avx512bw(&self) -> bool

AVX512BW

§Platforms

✅ AMD ✅ Intel

source

pub const fn has_avx512vl(&self) -> bool

AVX512VL

§Platforms

✅ AMD ✅ Intel

source

pub const fn has_clwb(&self) -> bool

CLWB

§Platforms

✅ AMD ✅ Intel

source

pub const fn has_prefetchwt1(&self) -> bool

Has PREFETCHWT1 (Intel® Xeon Phi™ only).

§Platforms

❌ AMD (reserved) ✅ Intel

source

pub const fn has_umip(&self) -> bool

Supports user-mode instruction prevention if 1.

§Platforms

❌ AMD (reserved) ✅ Intel

source

pub const fn has_pku(&self) -> bool

Supports protection keys for user-mode pages.

§Platforms

❌ AMD (reserved) ✅ Intel

source

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

source

pub const fn has_waitpkg(&self) -> bool

WAITPKG

❓ AMD ✅ Intel

source

pub const fn has_av512vbmi2(&self) -> bool

AVX512VBMI2

✅ AMD ✅ Intel

source

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

source

pub const fn has_gfni(&self) -> bool

GFNI

❓ AMD ✅ Intel

source

pub const fn has_vaes(&self) -> bool

VAES

❓ AMD ✅ Intel

source

pub const fn has_vpclmulqdq(&self) -> bool

VPCLMULQDQ

❓ AMD ✅ Intel

source

pub const fn has_avx512vnni(&self) -> bool

AVX512VNNI

§Platforms

✅ AMD ✅ Intel

source

pub const fn has_avx512bitalg(&self) -> bool

AVX512BITALG

✅ AMD ✅ Intel

source

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

source

pub const fn has_avx512vpopcntdq(&self) -> bool

AVX512VPOPCNTDQ

✅ AMD ✅ Intel

source

pub const fn has_la57(&self) -> bool

Supports 57-bit linear addresses and five-level paging if 1.

§Platforms

❓ AMD ✅ Intel

source

pub const fn has_rdpid(&self) -> bool

RDPID and IA32_TSC_AUX are available.

§Bug

The Intel manual lists RDPID as bit 22 in the ECX register, but AMD lists it as bit 22 in the ebx register. We assumed that the AMD manual was wrong and query ecx, let’s see what happens.

§Platforms

✅ AMD ✅ Intel

source

pub const fn has_sgx_lc(&self) -> bool

Supports SGX Launch Configuration.

§Platforms

❌ AMD (reserved) ✅ Intel

source

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

source

pub const fn has_avx512_4vnniw(&self) -> bool

Supports AVX512_4VNNIW.

§Platforms

❌ AMD (reserved) ✅ Intel

source

pub const fn has_avx512_4fmaps(&self) -> bool

Supports AVX512_4FMAPS.

§Platforms

❌ AMD (reserved) ✅ Intel

source

pub const fn has_avx512_vp2intersect(&self) -> bool

Supports AVX512_VP2INTERSECT.

§Platforms

❌ AMD (reserved) ✅ Intel

source

pub const fn has_amx_bf16(&self) -> bool

Supports AMX_BF16.

§Platforms

❌ AMD (reserved) ✅ Intel

source

pub const fn has_avx512_fp16(&self) -> bool

Supports AVX512_FP16.

§Platforms

❌ AMD (reserved) ✅ Intel

source

pub const fn has_amx_tile(&self) -> bool

Supports AMX_TILE.

§Platforms

❌ AMD (reserved) ✅ Intel

source

pub const fn has_amx_int8(&self) -> bool

Supports AMX_INT8.

§Platforms

❌ AMD (reserved) ✅ Intel

source

pub const fn has_avx_vnni(&self) -> bool

Supports AVX_VNNI.

§Platforms

❌ AMD (reserved) ✅ Intel

source

pub const fn has_avx512_bf16(&self) -> bool

Supports AVX512_BF16.

§Platforms

❌ AMD (reserved) ✅ Intel

source

pub const fn has_fzrm(&self) -> bool

Supports Fast zero-length REP MOVSB

§Platforms

❌ AMD (reserved) ✅ Intel

source

pub const fn has_fsrs(&self) -> bool

Supports Fast Short REP STOSB

§Platforms

❌ AMD (reserved) ✅ Intel

source

pub const fn has_fsrcrs(&self) -> bool

Supports Fast Short REP CMPSB, REP SCASB

§Platforms

❌ AMD (reserved) ✅ Intel

source

pub const fn has_hreset(&self) -> bool

Supports HRESET

§Platforms

❌ AMD (reserved) ✅ Intel

source

pub const fn has_cet_sss(&self) -> bool

Supports CET_SSS

§Platforms

❌ AMD (reserved) ✅ Intel

Trait Implementations§

source§

impl Debug for ExtendedFeatures

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

source§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.