opentitanlib::spiflash::sfdp

Struct JedecParams

Source
pub struct JedecParams {
Show 24 fields pub block_erase_size: BlockEraseSize, pub write_granularity: WriteGranularity, pub write_en_required: bool, pub write_en_opcode: u8, pub erase_opcode_4kib: u8, pub support_fast_read_112: bool, pub address_modes: SupportedAddressModes, pub support_double_rate_clocking: bool, pub support_fast_read_122: bool, pub support_fast_read_144: bool, pub support_fast_read_114: bool, pub support_fast_read_222: bool, pub support_fast_read_444: bool, pub density: u32, pub param_112: FastReadParam, pub param_122: FastReadParam, pub param_114: FastReadParam, pub param_144: FastReadParam, pub param_222: FastReadParam, pub param_444: FastReadParam, pub erase: [SectorErase; 4], pub rev_b: Option<JedecParamsRevB>, pub rev_d: Option<JedecParamsRevD>, pub rev_f: Option<JedecParamsRevF>,
}
Expand description

The JEDEC parameter table is documented in JESD216 “Serial Flash Discoverable Parameters”. This structure represents the parameter table after decoding it from the packed bitfield representation documented by JEDEC.

I have access to the following specs:

  • JESD216 dated April 2011 (Flash parameters version 1.0).

  • JESD216B dated May 2014 (Flash parameters version 1.6).

  • JESD216D dated August 2019 (Flash parameters version 1.7, unchanged since rev C).

  • JESD216F dated February 2022 (Flash parameters version 1.7, unchanged since rev D).

  • Version 1.0 defines a table of 9 “dwords”. I’m considering this to be the minimum required parameter table.

  • Rev B, version 1.6 extends the table to 16 “dwords”, including information about erase timing, powerdown and alternate mode requirements.

  • Rev D, version 1.7 extends the table to 20 “dwords”, including information about eight-lane SPI modes.

  • Rev F, version 1.7 extends the table to 23 “dwords”, including information about dual data rate operations.

Fields§

§block_erase_size: BlockEraseSize

Erase granularity.

§write_granularity: WriteGranularity

Write granularity / buffer size.

§write_en_required: bool

WREN instruction required for writing to volatile status register.

§write_en_opcode: u8

Write enable opocde (this is a single bit in the jedec table; expanded to the actual opcode here).

§erase_opcode_4kib: u8

Erase opcode for 4KiB sector erase.

§support_fast_read_112: bool

Support Fast Read 1-1-2.

§address_modes: SupportedAddressModes

The address modes supported by the device.

§support_double_rate_clocking: bool

Device supports double rate clocking.

§support_fast_read_122: bool

Other styles of Fast Read. The numerical designator refers to the instruction transfer mode, the address transfer mode and data transfer mode. ie: 1-2-2 means single bit mode for the opcode, dual mode for the address and dual mode for the data phase.

§support_fast_read_144: bool§support_fast_read_114: bool§support_fast_read_222: bool§support_fast_read_444: bool§density: u32

The density of the part. In the jedec table, this is expressed in bits, but it is converted to bytes here.

§param_112: FastReadParam

Parameters for the various supported FastRead modes.

§param_122: FastReadParam§param_114: FastReadParam§param_144: FastReadParam§param_222: FastReadParam§param_444: FastReadParam§erase: [SectorErase; 4]

Erase sector sizes. It is common for devices to support a 4KiB erase size, a 32KiB erase size and a 64KiB erase size.

§rev_b: Option<JedecParamsRevB>§rev_d: Option<JedecParamsRevD>§rev_f: Option<JedecParamsRevF>

Trait Implementations§

Source§

impl Annotate for &JedecParams

Source§

fn format(&self, variant: Option<&str>, field: &MemberId<'_>) -> Option<Format>

Source§

fn comment(&self, variant: Option<&str>, field: &MemberId<'_>) -> Option<String>

Source§

fn as_annotate(&self) -> Option<&dyn Annotate>

§

fn thunk_serialize( &self, serializer: &mut AnnotatedSerializer<'_>, ) -> Result<Document, Error>

Source§

impl Annotate for JedecParams

Source§

fn format(&self, _variant: Option<&str>, field: &MemberId<'_>) -> Option<Format>

Source§

fn comment( &self, _variant: Option<&str>, field: &MemberId<'_>, ) -> Option<String>

Source§

fn as_annotate(&self) -> Option<&dyn Annotate>

§

fn thunk_serialize( &self, serializer: &mut AnnotatedSerializer<'_>, ) -> Result<Document, Error>

Source§

impl Debug for JedecParams

Source§

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

Formats the value using the given formatter. Read more
Source§

impl Default for JedecParams

Source§

fn default() -> JedecParams

Returns the “default value” for a type. Read more
Source§

impl Serialize for JedecParams

Source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
Source§

impl TryFrom<&[u8]> for JedecParams

Source§

type Error = Error

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

fn try_from(buf: &[u8]) -> Result<Self, Self::Error>

Performs the conversion.

Auto Trait Implementations§

Blanket Implementations§

§

impl<T> Annotate for T
where T: Serialize + ?Sized,

§

default fn format( &self, _variant: Option<&str>, _field: &MemberId<'_>, ) -> Option<Format>

§

default fn comment( &self, _variant: Option<&str>, _field: &MemberId<'_>, ) -> Option<String>

§

default fn as_annotate(&self) -> Option<&dyn Annotate>

§

default fn thunk_serialize( &self, serializer: &mut AnnotatedSerializer<'_>, ) -> Result<Document, Error>

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, U> ConsoleSend<T> for U
where T: ConsoleDevice + ?Sized, U: Serialize,

Source§

fn send(&self, device: &T) -> Result<(), Error>

Source§

fn send_with_crc(&self, device: &T) -> Result<(), Error>

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

Source§

type Output = T

Should always be Self
Source§

impl<T> Serialize for T
where T: Serialize + ?Sized,

Source§

fn erased_serialize(&self, serializer: &mut dyn Serializer) -> Result<(), Error>

Source§

fn do_erased_serialize( &self, serializer: &mut dyn Serializer, ) -> Result<(), ErrorImpl>

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.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V