add first rev of eeprom
and ref voltage in varhandler
This commit is contained in:
2071
Middlewares/ST/EEPROM_Emul/Core/eeprom_emul.c
Normal file
2071
Middlewares/ST/EEPROM_Emul/Core/eeprom_emul.c
Normal file
File diff suppressed because it is too large
Load Diff
142
Middlewares/ST/EEPROM_Emul/Core/eeprom_emul.h
Normal file
142
Middlewares/ST/EEPROM_Emul/Core/eeprom_emul.h
Normal file
@ -0,0 +1,142 @@
|
||||
/**
|
||||
******************************************************************************
|
||||
* @file EEPROM_Emul/Core/eeprom_emul.h
|
||||
* @author MCD Application Team
|
||||
* @brief This file contains all the functions prototypes for the EEPROM
|
||||
* emulation firmware library.
|
||||
******************************************************************************
|
||||
* @attention
|
||||
*
|
||||
* <h2><center>© Copyright (c) 2020 STMicroelectronics.
|
||||
* All rights reserved.</center></h2>
|
||||
*
|
||||
* This software component is licensed by ST under BSD 3-Clause license,
|
||||
* the "License"; You may not use this file except in compliance with the
|
||||
* License. You may obtain a copy of the License at:
|
||||
* opensource.org/licenses/BSD-3-Clause
|
||||
*
|
||||
******************************************************************************
|
||||
*/
|
||||
|
||||
/* Define to prevent recursive inclusion -------------------------------------*/
|
||||
#ifndef __EEPROM_EMUL_H
|
||||
#define __EEPROM_EMUL_H
|
||||
|
||||
/* Includes ------------------------------------------------------------------*/
|
||||
#include "eeprom_emul_conf.h"
|
||||
#include "eeprom_emul_types.h"
|
||||
#include "flash_interface.h"
|
||||
|
||||
/** @addtogroup EEPROM_Emulation
|
||||
* @{
|
||||
*/
|
||||
|
||||
/* Private constants ---------------------------------------------------------*/
|
||||
/** @defgroup EEPROM_Private_Constants EEPROM Private Constants
|
||||
* @{
|
||||
*/
|
||||
|
||||
/** @defgroup Private_Other_Constants Private Other Constants
|
||||
* @{
|
||||
*/
|
||||
|
||||
/* Page definitions */
|
||||
#define PAGE_SIZE FLASH_PAGE_SIZE /*!< Page size */
|
||||
#define PAGE_HEADER_SIZE EE_ELEMENT_SIZE * 4U /*!< Page Header is 4 elements to save page state */
|
||||
#define NB_MAX_ELEMENTS_BY_PAGE ((PAGE_SIZE - PAGE_HEADER_SIZE) / EE_ELEMENT_SIZE) /*!< Max number of elements by page */
|
||||
#define PAGES_NUMBER (((((NB_OF_VARIABLES + NB_MAX_ELEMENTS_BY_PAGE) / NB_MAX_ELEMENTS_BY_PAGE) * 2U) * CYCLES_NUMBER) + GUARD_PAGES_NUMBER)
|
||||
/*!< Number of consecutives pages used by the application */
|
||||
#define NB_MAX_WRITTEN_ELEMENTS ((NB_MAX_ELEMENTS_BY_PAGE * PAGES_NUMBER) / 2U) /*!< Max number of elements written before triggering pages transfer */
|
||||
#define START_PAGE PAGE(START_PAGE_ADDRESS) /*!< Page index of the 1st page used for EEPROM emul, in the bank */
|
||||
#define END_EEPROM_ADDRESS (START_PAGE_ADDRESS + (PAGES_NUMBER * FLASH_PAGE_SIZE) - 1) /*!< Last address of EEPROM emulation flash pages */
|
||||
|
||||
/* No page define */
|
||||
#define EE_NO_PAGE_FOUND ((uint32_t)0xFFFFFFFFU)
|
||||
|
||||
/**
|
||||
* @}
|
||||
*/
|
||||
|
||||
/**
|
||||
* @}
|
||||
*/
|
||||
|
||||
/* Private macro -------------------------------------------------------------*/
|
||||
/** @defgroup EEPROM_Private_Macros EEPROM Private Macros
|
||||
* @{
|
||||
*/
|
||||
|
||||
/** @defgroup Macros_Pages Macros to manipulate pages
|
||||
* @{
|
||||
*/
|
||||
|
||||
/* Macros to manipulate pages */
|
||||
#ifdef SECURE_FEATURES
|
||||
#define PAGE_ADDRESS(__PAGE__) (uint32_t)(FLASH_BASE_NS + (__PAGE__) * PAGE_SIZE + ((START_PAGE_ADDRESS - FLASH_BASE_NS) / BANK_SIZE) * BANK_SIZE) /*!< Get page address from page index */
|
||||
#define PAGE(__ADDRESS__) (uint32_t)((((__ADDRESS__) - FLASH_BASE_NS) % BANK_SIZE) / FLASH_PAGE_SIZE) /*!< Get page index from page address */
|
||||
#else
|
||||
#define PAGE_ADDRESS(__PAGE__) (uint32_t)(FLASH_BASE + (__PAGE__) * PAGE_SIZE + ((START_PAGE_ADDRESS - FLASH_BASE) / BANK_SIZE) * BANK_SIZE) /*!< Get page address from page index */
|
||||
#define PAGE(__ADDRESS__) (uint32_t)((((__ADDRESS__) - FLASH_BASE) % BANK_SIZE) / FLASH_PAGE_SIZE) /*!< Get page index from page address */
|
||||
#endif
|
||||
#define PREVIOUS_PAGE(__PAGE__) (uint32_t)((((__PAGE__) - START_PAGE - 1U + PAGES_NUMBER) % PAGES_NUMBER) + START_PAGE) /*!< Get page index of previous page, among circular page list */
|
||||
#define FOLLOWING_PAGE(__PAGE__) (uint32_t)((((__PAGE__) - START_PAGE + 1U) % PAGES_NUMBER) + START_PAGE) /*!< Get page index of following page, among circular page list */
|
||||
|
||||
/**
|
||||
* @}
|
||||
*/
|
||||
|
||||
/** @defgroup Macros_Elements Macros to manipulate elements
|
||||
* @{
|
||||
*/
|
||||
|
||||
/* Macros to manipulate elements */
|
||||
#define EE_VIRTUALADDRESS_VALUE(__ELEMENT__) (EE_VIRTUALADDRESS_TYPE)((__ELEMENT__) & EE_MASK_VIRTUALADDRESS) /*!< Get virtual address value from element value */
|
||||
#define EE_DATA_VALUE(__ELEMENT__) (EE_DATA_TYPE)(((__ELEMENT__) & EE_MASK_DATA) >> EE_DATA_SHIFT) /*!< Get Data value from element value */
|
||||
#define EE_CRC_VALUE(__ELEMENT__) (EE_CRC_TYPE)(((__ELEMENT__) & EE_MASK_CRC) >> EE_CRC_SHIFT) /*!< Get Crc value from element value */
|
||||
#define EE_ELEMENT_VALUE(__VIRTADDR__,__DATA__,__CRC__) (((EE_ELEMENT_TYPE)(__DATA__) << EE_DATA_SHIFT) | (__CRC__) << EE_CRC_SHIFT | (__VIRTADDR__)) /*!< Get element value from virtual addr, data and crc values */
|
||||
|
||||
/**
|
||||
* @}
|
||||
*/
|
||||
|
||||
/**
|
||||
* @}
|
||||
*/
|
||||
|
||||
/* Exported constants --------------------------------------------------------*/
|
||||
/* Exported types ------------------------------------------------------------*/
|
||||
/* Exported macro ------------------------------------------------------------*/
|
||||
/* Exported functions ------------------------------------------------------- */
|
||||
/** @defgroup EEPROM_Exported_Functions EEPROM Exported Functions
|
||||
* @{
|
||||
*/
|
||||
EE_Status EE_Format(EE_Erase_type EraseType);
|
||||
EE_Status EE_Init(EE_Erase_type EraseType);
|
||||
#if defined(EE_ACCESS_32BITS)
|
||||
EE_Status EE_ReadVariable32bits(uint16_t VirtAddress, uint32_t* pData);
|
||||
EE_Status EE_WriteVariable32bits(uint16_t VirtAddress, uint32_t Data);
|
||||
#endif
|
||||
#if defined(FLASH_LINES_128B)
|
||||
EE_Status EE_ReadVariable96bits(uint16_t VirtAddress, uint64_t* pData);
|
||||
EE_Status EE_WriteVariable96bits(uint16_t VirtAddress, uint64_t* Data);
|
||||
#endif
|
||||
EE_Status EE_ReadVariable16bits(uint16_t VirtAddress, uint16_t* pData);
|
||||
EE_Status EE_WriteVariable16bits(uint16_t VirtAddress, uint16_t Data);
|
||||
EE_Status EE_ReadVariable8bits(uint16_t VirtAddress, uint8_t* pData);
|
||||
EE_Status EE_WriteVariable8bits(uint16_t VirtAddress, uint8_t Data);
|
||||
EE_Status EE_CleanUp(void);
|
||||
EE_Status EE_CleanUp_IT(void);
|
||||
EE_Status EE_DeleteCorruptedFlashAddress(uint32_t Address);
|
||||
void EE_EndOfCleanup_UserCallback(void);
|
||||
|
||||
/**
|
||||
* @}
|
||||
*/
|
||||
|
||||
/**
|
||||
* @}
|
||||
*/
|
||||
|
||||
#endif /* __EEPROM_EMUL_H */
|
||||
|
||||
/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
|
90
Middlewares/ST/EEPROM_Emul/Core/eeprom_emul_conf.h
Normal file
90
Middlewares/ST/EEPROM_Emul/Core/eeprom_emul_conf.h
Normal file
@ -0,0 +1,90 @@
|
||||
/**
|
||||
******************************************************************************
|
||||
* @file eeprom_emul_conf.h
|
||||
* @author MCD Application Team
|
||||
* @brief EEPROM emulation configuration file.
|
||||
* This file should be copied to the application folder and renamed
|
||||
* to eeprom_emul_conf.h.
|
||||
******************************************************************************
|
||||
* @attention
|
||||
*
|
||||
* <h2><center>© Copyright (c) 2020 STMicroelectronics.
|
||||
* All rights reserved.</center></h2>
|
||||
*
|
||||
* This software component is licensed by ST under BSD 3-Clause license,
|
||||
* the "License"; You may not use this file except in compliance with the
|
||||
* License. You may obtain a copy of the License at:
|
||||
* opensource.org/licenses/BSD-3-Clause
|
||||
*
|
||||
******************************************************************************
|
||||
*/
|
||||
|
||||
/** @addtogroup EEPROM_Emulation
|
||||
* @{
|
||||
*/
|
||||
|
||||
/* Define to prevent recursive inclusion -------------------------------------*/
|
||||
#ifndef __EEPROM_EMUL_CONF_H
|
||||
#define __EEPROM_EMUL_CONF_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
/* Private constants ---------------------------------------------------------*/
|
||||
/** @addtogroup EEPROM_Private_Constants
|
||||
* @{
|
||||
*/
|
||||
|
||||
/** @defgroup Private_Configuration_Constants Private Configuration Constants
|
||||
* @{
|
||||
*/
|
||||
|
||||
/* Configuration of eeprom emulation in flash, can be custom */
|
||||
#define START_PAGE_ADDRESS 0x0801F000U /*!< Start address of the second last page in flash, for EEPROM emulation */
|
||||
#define CYCLES_NUMBER 1U /*!< Number of 10Kcycles requested, minimum 1 for 10Kcycles (default), for instance 10 to reach 100Kcycles. This factor will increase pages number */
|
||||
#define GUARD_PAGES_NUMBER 0U /*!< Number of guard pages avoiding frequent transfers (must be multiple of 2): 0,2,4.. */
|
||||
|
||||
/* Configuration of crc calculation for eeprom emulation in flash */
|
||||
#define CRC_POLYNOMIAL_LENGTH LL_CRC_POLYLENGTH_16B /* CRC polynomial lenght 16 bits */
|
||||
#define CRC_POLYNOMIAL_VALUE 0x8005U /* Polynomial to use for CRC calculation */
|
||||
|
||||
/**
|
||||
* @}
|
||||
*/
|
||||
|
||||
/**
|
||||
* @}
|
||||
*/
|
||||
|
||||
/* Exported types ------------------------------------------------------------*/
|
||||
/* Exported constants --------------------------------------------------------*/
|
||||
/** @defgroup EEPROM_Exported_Constants EEPROM Exported Constants
|
||||
* @{
|
||||
*/
|
||||
|
||||
/** @defgroup Exported_Configuration_Constants Exported Configuration Constants
|
||||
* @{
|
||||
*/
|
||||
#define NB_OF_VARIABLES 6U /*!< Number of variables to handle in eeprom */
|
||||
|
||||
/**
|
||||
* @}
|
||||
*/
|
||||
|
||||
/**
|
||||
* @}
|
||||
*/
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
/**
|
||||
* @}
|
||||
*/
|
||||
|
||||
#endif /* __EEPROM_EMUL_CONF_H */
|
||||
|
||||
|
||||
/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
|
118
Middlewares/ST/EEPROM_Emul/Core/eeprom_emul_types.h
Normal file
118
Middlewares/ST/EEPROM_Emul/Core/eeprom_emul_types.h
Normal file
@ -0,0 +1,118 @@
|
||||
/**
|
||||
******************************************************************************
|
||||
* @file EEPROM_Emul/Core/eeprom_emul_types.h
|
||||
* @author MCD Application Team
|
||||
* @brief This file contains all the functions prototypes for the EEPROM
|
||||
* emulation firmware library.
|
||||
******************************************************************************
|
||||
* @attention
|
||||
*
|
||||
* <h2><center>© Copyright (c) 2020 STMicroelectronics.
|
||||
* All rights reserved.</center></h2>
|
||||
*
|
||||
* This software component is licensed by ST under BSD 3-Clause license,
|
||||
* the "License"; You may not use this file except in compliance with the
|
||||
* License. You may obtain a copy of the License at:
|
||||
* opensource.org/licenses/BSD-3-Clause
|
||||
*
|
||||
******************************************************************************
|
||||
*/
|
||||
|
||||
/* Define to prevent recursive inclusion -------------------------------------*/
|
||||
#ifndef __EEPROM_EMUL_TYPES_H
|
||||
#define __EEPROM_EMUL_TYPES_H
|
||||
|
||||
/** @addtogroup EEPROM_Emulation
|
||||
* @{
|
||||
*/
|
||||
|
||||
/* Exported constants --------------------------------------------------------*/
|
||||
/** @defgroup EEPROM_Exported_Constants EEPROM Exported Constants
|
||||
* @{
|
||||
*/
|
||||
|
||||
/** @defgroup Exported_Other_Constants Exported Other Constants
|
||||
* @{
|
||||
*/
|
||||
|
||||
/**
|
||||
* @brief EE Status enum definition.
|
||||
*/
|
||||
/* Define of the return value */
|
||||
typedef enum {
|
||||
/* External return codes : ok */
|
||||
EE_OK = 0U,
|
||||
|
||||
/* External return codes : errors */
|
||||
EE_ERASE_ERROR,
|
||||
EE_WRITE_ERROR,
|
||||
EE_ERROR_NOACTIVE_PAGE,
|
||||
EE_ERROR_NOERASE_PAGE,
|
||||
EE_ERROR_NOERASING_PAGE,
|
||||
EE_ERROR_NOACTIVE_NORECEIVE_NOVALID_PAGE,
|
||||
EE_NO_DATA,
|
||||
EE_INVALID_VIRTUALADDRESS,
|
||||
EE_INVALID_PAGE,
|
||||
EE_INVALID_PAGE_SEQUENCE,
|
||||
EE_INVALID_ELEMENT,
|
||||
EE_TRANSFER_ERROR,
|
||||
EE_DELETE_ERROR,
|
||||
EE_INVALID_BANK_CFG,
|
||||
|
||||
/* Internal return code */
|
||||
EE_NO_PAGE_FOUND,
|
||||
EE_PAGE_NOTERASED,
|
||||
EE_PAGE_ERASED,
|
||||
EE_PAGE_FULL,
|
||||
|
||||
/* External return code : action required */
|
||||
EE_CLEANUP_REQUIRED = 0x100U,
|
||||
|
||||
#ifdef DUALCORE_FLASH_SHARING
|
||||
/* Value returned when a program or erase operation is requested but
|
||||
* the flash is already used by CPU2 */
|
||||
EE_FLASH_USED,
|
||||
EE_SEM_TIMEOUT,
|
||||
#endif
|
||||
|
||||
} EE_Status;
|
||||
|
||||
/* Type of page erasing:
|
||||
EE_FORCED_ERASE --> pages to erase are erased unconditionnally
|
||||
EE_CONDITONAL_ERASE --> pages to erase are erased only if not fully erased */
|
||||
typedef enum {
|
||||
EE_FORCED_ERASE,
|
||||
EE_CONDITIONAL_ERASE
|
||||
} EE_Erase_type;
|
||||
|
||||
#if (defined DUALCORE_FLASH_SHARING) || (defined FLASH_LINES_128B)
|
||||
/* Type of write operations:
|
||||
EE_TRANSFER --> Used by WriteDoubleWord to know when the operation ongoing is a transfer
|
||||
EE_SIMPLE_WRITE --> Used by WriteDoubleWord to know when the operation ongoing is a simple writing */
|
||||
typedef enum {
|
||||
EE_TRANSFER,
|
||||
EE_SIMPLE_WRITE,
|
||||
EE_SET_PAGE,
|
||||
EE_INIT_WRITE
|
||||
} EE_Write_type;
|
||||
#endif
|
||||
|
||||
/* Masks of EE_Status return codes */
|
||||
#define EE_STATUSMASK_ERROR (uint16_t)0x00FFU /*!< Mask on EE_Status return code, selecting error codes */
|
||||
#define EE_STATUSMASK_CLEANUP (uint16_t)0x0100U /*!< Mask on EE_Status return code, selecting cleanup request codes */
|
||||
|
||||
/**
|
||||
* @}
|
||||
*/
|
||||
|
||||
/**
|
||||
* @}
|
||||
*/
|
||||
|
||||
/**
|
||||
* @}
|
||||
*/
|
||||
|
||||
#endif /* __EEPROM_EMUL_TYPES_H */
|
||||
|
||||
/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
|
Reference in New Issue
Block a user