opentitanlib::spiflash::flash

Struct SpiFlash

Source
pub struct SpiFlash {
    pub size: u32,
    pub program_size: u32,
    pub address_mode: AddressMode,
    pub read_mode: ReadMode,
    pub erase_mode: EraseMode,
    pub sfdp: Option<Sfdp>,
    pub read_type: ReadTypes,
    pub erase: Vec<SectorErase>,
}

Fields§

§size: u32§program_size: u32§address_mode: AddressMode§read_mode: ReadMode§erase_mode: EraseMode§sfdp: Option<Sfdp>§read_type: ReadTypes§erase: Vec<SectorErase>

Implementations§

Source§

impl SpiFlash

Source

pub const READ: u8 = 3u8

Source

pub const FAST_READ: u8 = 11u8

Source

pub const FAST_DUAL_READ: u8 = 59u8

Source

pub const FAST_QUAD_READ: u8 = 107u8

Source

pub const READ_4B: u8 = 19u8

Source

pub const FAST_READ_4B: u8 = 12u8

Source

pub const FAST_DUAL_READ_4B: u8 = 60u8

Source

pub const FAST_QUAD_READ_4B: u8 = 108u8

Source

pub const PAGE_PROGRAM: u8 = 2u8

Source

pub const SECTOR_ERASE: u8 = 32u8

Source

pub const BLOCK_ERASE_32K: u8 = 82u8

Source

pub const BLOCK_ERASE_64K: u8 = 216u8

Source

pub const SECTOR_ERASE_4B: u8 = 33u8

Source

pub const BLOCK_ERASE_32K_4B: u8 = 92u8

Source

pub const BLOCK_ERASE_64K_4B: u8 = 220u8

Source

pub const CHIP_ERASE: u8 = 199u8

Source

pub const WRITE_ENABLE: u8 = 6u8

Source

pub const WRITE_DISABLE: u8 = 4u8

Source

pub const READ_STATUS: u8 = 5u8

Source

pub const READ_STATUS2: u8 = 53u8

Source

pub const READ_STATUS3: u8 = 21u8

Source

pub const WRITE_STATUS: u8 = 1u8

Source

pub const WRITE_STATUS2: u8 = 49u8

Source

pub const WRITE_STATUS3: u8 = 17u8

Source

pub const READ_ID: u8 = 159u8

Source

pub const ENTER_4B: u8 = 183u8

Source

pub const EXIT_4B: u8 = 233u8

Source

pub const READ_SFDP: u8 = 90u8

Source

pub const NOP: u8 = 0u8

Source

pub const RESET_ENABLE: u8 = 102u8

Source

pub const RESET: u8 = 153u8

Source

pub const LEGACY_PAGE_SIZE: u32 = 256u32

The legacy JEDEC page size for programming operations is 256 bytes.

Source

pub const STATUS_WIP: u8 = 1u8

Status register bits: The WIP bit indicates a write in progress (sometimes called the busy bit).

Source

pub const STATUS_WEL: u8 = 2u8

The WEL bit is the write enable latch.

Source

pub fn read_jedec_id(spi: &dyn Target, length: usize) -> Result<Vec<u8>>

Read length bytes of the JEDEC ID from the spi target.

Source

pub fn read_status(spi: &dyn Target) -> Result<u8>

Read status register from the spi target.

Source

pub fn read_status_ex(spi: &dyn Target, seq: Option<&[u8]>) -> Result<u32>

Read the extended status register from the spi target.

Source

pub fn wait_for_busy_clear(spi: &dyn Target) -> Result<()>

Poll the status register waiting for the busy bit to clear.

Source

pub fn set_write_enable(spi: &dyn Target) -> Result<()>

Send the WRITE_ENABLE opcode to the spi target.

Source

pub fn set_write_disable(spi: &dyn Target) -> Result<()>

Send the WRITE_DISABLE opcode to the spi target.

Source

pub fn read_sfdp(spi: &dyn Target) -> Result<Sfdp>

Read and parse the SFDP table from the spi target.

Source

pub fn from_sfdp(sfdp: Sfdp) -> Self

Create a new SpiFlash instance from an SFDP table.

Source

pub fn from_spi(spi: &dyn Target) -> Result<Self>

Create a new SpiFlash instance by reading an SFDP table from the spi Target.

Source

pub fn set_address_mode( &mut self, spi: &dyn Target, mode: AddressMode, ) -> Result<()>

Set the SPI flash addressing mode to either 3b or 4b mode.

Source

pub fn set_address_mode_auto(&mut self, spi: &dyn Target) -> Result<()>

Automatically set the addressing mode based on the size of the SPI flash.

Source

pub fn read( &self, spi: &dyn Target, address: u32, buffer: &mut [u8], ) -> Result<&Self>

Read into buffer from the SPI flash starting at address.

Source

pub fn read_with_progress( &self, spi: &dyn Target, address: u32, buffer: &mut [u8], progress: &dyn ProgressIndicator, use_4b_opcodes: bool, ) -> Result<&Self>

Read into buffer from the SPI flash starting at address. The progress callback will be invoked after each chunk of the read operation.

Source

pub fn chip_erase(&self, spi: &dyn Target) -> Result<&Self>

Erase the entire EEPROM via the CHIP_ERASE opcode.

Source

pub fn erase( &self, spi: &dyn Target, address: u32, length: u32, ) -> Result<&Self>

Erase a segment of the SPI flash starting at address for length bytes. The address and length must be sector aligned.

Source

pub fn erase_with_progress( &self, spi: &dyn Target, address: u32, length: u32, progress: &dyn ProgressIndicator, ) -> Result<&Self>

Erase a segment of the SPI flash starting at address for length bytes. The address and length must be sector aligned. The progress callback will be invoked after each chunk of the erase operation.

Source

pub fn program( &self, spi: &dyn Target, address: u32, buffer: &[u8], ) -> Result<&Self>

Program a segment of the SPI flash starting at address with the contents of buffer. The address and buffer length may be arbitrary. This function will not erase the segment first.

Source

pub fn program_with_progress( &self, spi: &dyn Target, address: u32, buffer: &[u8], progress: &dyn ProgressIndicator, ) -> Result<&Self>

Program a segment of the SPI flash starting at address with the contents of buffer. The address and buffer length may be arbitrary. This function will not erase the segment first. The progress callback will be invoked after each chunk of the program operation.

Source

pub fn chip_reset(spi: &dyn Target) -> Result<()>

Send the software reset sequence to the spi target.

Trait Implementations§

Source§

impl Default for SpiFlash

Source§

fn default() -> Self

Returns the “default value” for a type. 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> Same for T

Source§

type Output = T

Should always be Self
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