Gan likun / mbed1-dev
Embed: (wiki syntax)

« Back to documentation index

FlashIAP Class Reference

FlashIAP Class Reference
[Drivers]

Flash IAP driver. More...

#include <FlashIAP.h>

Inherits NonCopyable< FlashIAP >.

Public Member Functions

int init ()
 Initialize a flash IAP device.
int deinit ()
 Deinitialize a flash IAP device.
int read (void *buffer, uint32_t addr, uint32_t size)
 Read data from a flash device.
int program (const void *buffer, uint32_t addr, uint32_t size)
 Program data to pages.
int erase (uint32_t addr, uint32_t size)
 Erase sectors.
uint32_t get_sector_size (uint32_t addr) const
 Get the sector size at the defined address.
uint32_t get_flash_start () const
 Get the flash start address.
uint32_t get_flash_size () const
 Get the flash size.
uint32_t get_page_size () const
 Get the program page size.

Detailed Description

Flash IAP driver.

It invokes flash HAL functions.

Note:
Synchronization level: Thread safe

Definition at line 41 of file FlashIAP.h.


Member Function Documentation

int deinit (  )

Deinitialize a flash IAP device.

Returns:
0 on success or a negative error code on failure

Definition at line 64 of file FlashIAP.cpp.

int erase ( uint32_t  addr,
uint32_t  size 
)

Erase sectors.

The state of an erased sector is undefined until it has been programmed

Parameters:
addrAddress of a sector to begin erasing, must be a multiple of the sector size
sizeSize to erase in bytes, must be a multiple of the sector size
Returns:
0 on success, negative error code on failure

Definition at line 118 of file FlashIAP.cpp.

uint32_t get_flash_size (  ) const

Get the flash size.

Returns:
Flash size

Definition at line 161 of file FlashIAP.cpp.

uint32_t get_flash_start (  ) const

Get the flash start address.

Returns:
Flash start address

Definition at line 156 of file FlashIAP.cpp.

uint32_t get_page_size (  ) const

Get the program page size.

The page size defines the writable page size

Returns:
Size of a program page in bytes

Definition at line 146 of file FlashIAP.cpp.

uint32_t get_sector_size ( uint32_t  addr ) const

Get the sector size at the defined address.

Sector size might differ at address ranges. An example <0-0x1000, sector size=1024; 0x10000-0x20000, size=2048>

Parameters:
addrAddress of or inside the sector to query
Returns:
Size of a sector in bytes or MBED_FLASH_INVALID_SIZE if not mapped

Definition at line 151 of file FlashIAP.cpp.

int init (  )

Initialize a flash IAP device.

Should be called once per lifetime of the object.

Returns:
0 on success or a negative error code on failure

Definition at line 53 of file FlashIAP.cpp.

int program ( const void *  buffer,
uint32_t  addr,
uint32_t  size 
)

Program data to pages.

The sectors must have been erased prior to being programmed

Parameters:
bufferBuffer of data to be written
addrAddress of a page to begin writing to, must be a multiple of program and sector sizes
sizeSize to write in bytes, must be a multiple of program and sector sizes
Returns:
0 on success, negative error code on failure

Definition at line 85 of file FlashIAP.cpp.

int read ( void *  buffer,
uint32_t  addr,
uint32_t  size 
)

Read data from a flash device.

This method invokes memcpy - reads number of bytes from the address

Parameters:
bufferBuffer to write to
addrFlash address to begin reading from
sizeSize to read in bytes
Returns:
0 on success, negative error code on failure

Definition at line 76 of file FlashIAP.cpp.