#[non_exhaustive]#[repr(u32)]pub enum CpuFamily {
Unknown = 0,
Intel32 = 1,
Amd64 = 2,
Arm32 = 3,
Arm64 = 4,
Ppc32 = 5,
Ppc64 = 6,
Mips32 = 7,
Mips64 = 8,
Arm64_32 = 9,
Wasm32 = 10,
}
Expand description
Represents a family of CPUs.
This is strongly connected to the Arch
type, but reduces the selection to a range of
families with distinct properties, such as a generally common instruction set and pointer size.
This enumeration is represented as u32
for C-bindings and lowlevel APIs.
Variants (Non-exhaustive)§
This enum is marked as non-exhaustive
Unknown = 0
Any other CPU family that is not explicitly supported.
Intel32 = 1
32-bit little-endian CPUs using the Intel 8086 instruction set, also known as x86
.
Amd64 = 2
64-bit little-endian, also known as x86_64
, now widely used by Intel and AMD.
Arm32 = 3
32-bit ARM.
Arm64 = 4
64-bit ARM (e.g. ARMv8-A).
Ppc32 = 5
32-bit big-endian PowerPC.
Ppc64 = 6
64-bit big-endian PowerPC.
Mips32 = 7
32-bit MIPS.
Mips64 = 8
64-bit MIPS.
Arm64_32 = 9
ILP32 ABI on 64-bit ARM.
Wasm32 = 10
Virtual WASM 32-bit architecture.
Implementations§
Source§impl CpuFamily
impl CpuFamily
Sourcepub fn pointer_size(self) -> Option<usize>
pub fn pointer_size(self) -> Option<usize>
Returns the native pointer size.
This commonly defines the size of CPU registers including the instruction pointer, and the size of all pointers on the platform.
This function returns None
if the CPU family is unknown.
§Examples
use symbolic_common::CpuFamily;
assert_eq!(CpuFamily::Amd64.pointer_size(), Some(8));
assert_eq!(CpuFamily::Intel32.pointer_size(), Some(4));
Sourcepub fn instruction_alignment(self) -> Option<u64>
pub fn instruction_alignment(self) -> Option<u64>
Returns instruction alignment if fixed.
Some instruction sets, such as Intel’s x86, use variable length instruction encoding.
Others, such as ARM, have fixed length instructions. This method returns Some
for fixed
size instructions and None
for variable-length instruction sizes.
§Examples
use symbolic_common::CpuFamily;
// variable length on x86_64:
assert_eq!(CpuFamily::Amd64.instruction_alignment(), None);
// 4-byte alignment on all 64-bit ARM variants:
assert_eq!(CpuFamily::Arm64.instruction_alignment(), Some(4));
Sourcepub fn ip_register_name(self) -> Option<&'static str>
pub fn ip_register_name(self) -> Option<&'static str>
Returns the name of the instruction pointer register.
The instruction pointer register holds a pointer to currrent code execution at all times.
This is a differrent register on each CPU family. The size of the value in this register is
specified by pointer_size
.
Returns None
if the CPU family is unknown.
§Examples
use symbolic_common::CpuFamily;
assert_eq!(CpuFamily::Amd64.ip_register_name(), Some("rip"));
Trait Implementations§
Source§impl Ord for CpuFamily
impl Ord for CpuFamily
Source§impl PartialOrd for CpuFamily
impl PartialOrd for CpuFamily
impl Copy for CpuFamily
impl Eq for CpuFamily
impl StructuralPartialEq for CpuFamily
Auto Trait Implementations§
impl Freeze for CpuFamily
impl RefUnwindSafe for CpuFamily
impl Send for CpuFamily
impl Sync for CpuFamily
impl Unpin for CpuFamily
impl UnwindSafe for CpuFamily
Blanket Implementations§
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> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
clone_to_uninit
)