Attributes

Struct Attributes 

Source
pub struct Attributes {
    pub machine: Option<CString>,
    pub family: Option<CString>,
    pub revision: Option<CString>,
    pub serial_number: Option<CString>,
    pub soc_id: Option<CString>,
}
Expand description

Attributes for a SoC device.

These are both exported to userspace under /sys/devices/socX and provided to other drivers to match against via soc_device_match (not yet available in Rust) to enable quirks or device-specific support where necessary.

All fields are freeform - they have no specific formatting, just defined meanings. For example, the machine field could be “DB8500” or “Qualcomm Technologies, Inc. SM8560 HDK”, but regardless it should identify a board or product.

Fields§

§machine: Option<CString>

Should generally be a board ID or product ID. Examples include DB8500 (ST-Ericsson) or “Qualcomm Technologies, inc. SM8560 HDK”.

If this field is not populated, the SoC infrastructure will try to populate it from /model in the device tree.

§family: Option<CString>

The broader class this SoC belongs to. Examples include ux500 (for DB8500) or Snapdragon (for SM8650).

On chips with ARM firmware supporting SMCCC v1.2+, this may be a JEDEC JEP106 manufacturer identification.

§revision: Option<CString>

The manufacturing revision of the part. Frequently this is MAJOR.MINOR, but not always.

§serial_number: Option<CString>

Serial Number - uniquely identifies a specific SoC. If present, should be unique (buying a replacement part should change it if present). This field cannot be matched on and is solely present to export through /sys.

§soc_id: Option<CString>

SoC ID - identifies a specific SoC kind in question, sometimes more specifically than machine if the same SoC is used in multiple products. Some devices use this to specify a SoC name, e.g. “I.MX??”, and others just print an ID number (e.g. Tegra and Qualcomm).

On chips with ARM firmware supporting SMCCC v1.2+, this may be a JEDEC JEP106 manufacturer identification (the family value) followed by a colon and then a 4-digit ID value.

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> Init<T> for T

Source§

unsafe fn __init(self, slot: *mut T) -> Result<(), Infallible>

Initializes slot. Read more
Source§

fn chain<F>(self, f: F) -> ChainInit<Self, F, T, E>
where F: FnOnce(&mut T) -> Result<(), E>,

First initializes the value using self then calls the function f with the initialized value. Read more
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> PinInit<T> for T

Source§

unsafe fn __pinned_init(self, slot: *mut T) -> Result<(), Infallible>

Initializes slot. Read more
Source§

fn pin_chain<F>(self, f: F) -> ChainPinInit<Self, F, T, E>
where F: FnOnce(Pin<&mut T>) -> Result<(), E>,

First initializes the value using self then calls the function f with the initialized value. Read more
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.
Source§

impl<T, U, const N: u32> TryIntoBounded<T, N> for U
where T: Integer, U: TryInto<T>,

Source§

fn try_into_bounded(self) -> Option<Bounded<T, N>>

Attempts to convert self into a Bounded using N bits. Read more