custom-board-bundle-sample-.../firmware/hw_layer/flash.h

173 lines
5.8 KiB
C

/**
* @file flash.h
*
*/
#ifndef FLASH_H
#define FLASH_H
#include "global.h"
/**
* @brief Number of sectors in the flash memory.
*/
#if !defined(FLASH_SECTOR_COUNT) || defined(__DOXYGEN__)
#define FLASH_SECTOR_COUNT 12
#endif
/* Error codes */
/** @brief Flash operation successful */
#define FLASH_RETURN_SUCCESS HAL_SUCCESS
/** @brief Flash operation error because of denied access, corrupted memory.*/
#define FLASH_RETURN_NO_PERMISSION -1
/** @brief Flash operation error because of bad flash, corrupted memory */
#define FLASH_RETURN_BAD_FLASH -11
#ifdef __cplusplus
extern "C" {
#endif /* __cplusplus */
/**
* @brief Maximum program/erase parallelism
*
* FLASH_CR_PSIZE_MASK is the mask to configure the parallelism value.
* FLASH_CR_PSIZE_VALUE is the parallelism value suitable for the voltage range.
*
* PSIZE(1:0) is defined as:
* 00 to program 8 bits per step
* 01 to program 16 bits per step
* 10 to program 32 bits per step
* 11 to program 64 bits per step
*/
// Warning, flashdata_t must be unsigned!!!
#if defined(STM32F4XX) || defined(STM32F7XX) || defined(__DOXYGEN__)
#define FLASH_CR_PSIZE_MASK FLASH_CR_PSIZE_0 | FLASH_CR_PSIZE_1
#if ((STM32_VDD >= 270) && (STM32_VDD <= 360)) || defined(__DOXYGEN__)
#define FLASH_CR_PSIZE_VALUE FLASH_CR_PSIZE_1
typedef uint32_t flashdata_t;
#elif (STM32_VDD >= 240) && (STM32_VDD < 270)
#define FLASH_CR_PSIZE_VALUE FLASH_CR_PSIZE_0
typedef uint16_t flashdata_t;
#elif (STM32_VDD >= 210) && (STM32_VDD < 240)
#define FLASH_CR_PSIZE_VALUE FLASH_CR_PSIZE_0
typedef uint16_t flashdata_t;
#elif (STM32_VDD >= 180) && (STM32_VDD < 210)
#define FLASH_CR_PSIZE_VALUE ((uint32_t)0x00000000)
typedef uint8_t flashdata_t;
#else
#error "invalid VDD voltage specified"
#endif
#endif /* defined(STM32F4XX) */
/** @brief Address in the flash memory */
typedef uintptr_t flashaddr_t;
/** @brief Index of a sector */
typedef uint8_t flashsector_t;
/**
* @brief Get the size of @p sector.
* @return @p sector size in bytes.
*/
size_t flashSectorSize(flashsector_t sector);
/**
* @brief Get the beginning address of @p sector.
* @param sector Sector to retrieve the beginning address of.
* @return First address (inclusive) of @p sector.
*/
flashaddr_t flashSectorBegin(flashsector_t sector);
/**
* @brief Get the end address of @p sector.
* @param sector Sector to retrieve the end address of.
* @return End address (exclusive) of @p sector (i.e. beginning address of the next sector).
*/
flashaddr_t flashSectorEnd(flashsector_t sector);
/**
* @brief Get the sector containing @p address.
* @warning @p address must be in the flash addresses range.
* @param address Address to be searched for.
* @return Sector containing @p address.
*/
flashsector_t flashSectorAt(flashaddr_t address);
/**
* @brief Erase the flash @p sector.
* @details The sector is checked for errors after erase.
* @note The sector is deleted regardless of its current state.
*
* @param sector Sector which is going to be erased.
* @return FLASH_RETURN_SUCCESS No error erasing the sector.
* @return FLASH_RETURN_BAD_FLASH Flash cell error.
* @return FLASH_RETURN_NO_PERMISSION Access denied.
*/
int flashSectorErase(flashsector_t sector);
/**
* @brief Erase the sectors containing the span of @p size bytes starting at @p address.
*
* @warning If @p address doesn't match the beginning of a sector, the
* data contained between the beginning of the sector and @p address will
* be erased too. The same applies for data contained at @p address + @p size
* up to the end of the sector.
*
* @param address Starting address of the span in flash memory.
* @param size Size of the span in bytes.
* @return FLASH_RETURN_SUCCESS No error erasing the flash memory.
* @return FLASH_RETURN_BAD_FLASH Flash cell error.
* @return FLASH_RETURN_NO_PERMISSION Access denied.
*/
int flashErase(flashaddr_t address, size_t size);
/**
* @brief Check if the @p size bytes of flash memory starting at @p address are erased.
* @note If the memory is erased, one can write data into it safely.
* @param address First address in flash memory to be checked.
* @param size Size of the memory space to be checked in bytes.
* @return TRUE Memory is already erased.
* @return FALSE Memory is not erased.
*/
bool flashIsErased(flashaddr_t address, size_t size);
/**
* @brief Check if the data in @p buffer are identical to the one in flash memory.
* @param address First address in flash memory to be checked.
* @param buffer Buffer containing the data to compare.
* @param size Size of @p buffer in bytes.
* @return TRUE if the flash memory and the buffer contain identical data.
* @return FALSE if the flash memory and the buffer don't contain identical data.
*/
bool flashCompare(flashaddr_t address, const char* buffer, size_t size);
/**
* @brief Copy data from the flash memory to a @p buffer.
* @warning The @p buffer must be at least @p size bytes long.
* @param address First address of the flash memory to be copied.
* @param buffer Buffer to copy to.
* @param size Size of the data to be copied in bytes.
* @return FLASH_RETURN_SUCCESS if successfully copied.
*/
int flashRead(flashaddr_t address, char* buffer, size_t size);
/**
* @brief Copy data from a @p buffer to the flash memory.
* @warning The flash memory area receiving the data must be erased.
* @warning The @p buffer must be at least @p size bytes long.
* @param address First address in the flash memory where to copy the data to.
* @param buffer Buffer containing the data to copy.
* @param size Size of the data to be copied in bytes.
* @return FLASH_RETURN_SUCCESS No error.
* @return FLASH_RETURN_NO_PERMISSION Access denied.
*/
int flashWrite(flashaddr_t address, const char* buffer, size_t size);
#ifdef __cplusplus
}
#endif /* __cplusplus */
#endif /* FLASH_H */