V3.1.0
- Added Verify after Writing - Added Checking Pointer in Reading/Writing - Removed erasing buffer and formatting before write
This commit is contained in:
parent
460d569b92
commit
810dd7c944
|
@ -95,7 +95,7 @@ int main(void)
|
||||||
ee.val6 = 6;
|
ee.val6 = 6;
|
||||||
ee.val7 = 7;
|
ee.val7 = 7;
|
||||||
ee.val8 = 8;
|
ee.val8 = 8;
|
||||||
EE_Write(true);
|
EE_Write();
|
||||||
while (1)
|
while (1)
|
||||||
{
|
{
|
||||||
|
|
||||||
|
|
48
ee.c
48
ee.c
|
@ -169,8 +169,11 @@ bool EE_Init(void *StoragePointer, uint32_t Size)
|
||||||
bool answer = false;
|
bool answer = false;
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
|
/* checking size of eeprom area*/
|
||||||
if (Size > EE_SIZE)
|
if (Size > EE_SIZE)
|
||||||
{
|
{
|
||||||
|
eeHandle.Size = 0;
|
||||||
|
eeHandle.DataPointer = NULL;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
eeHandle.Size = Size;
|
eeHandle.Size = Size;
|
||||||
|
@ -199,15 +202,11 @@ uint32_t EE_Capacity(void)
|
||||||
/**
|
/**
|
||||||
* @brief Formats the EEPROM emulation area.
|
* @brief Formats the EEPROM emulation area.
|
||||||
* @note This function formats the EEPROM emulation area,
|
* @note This function formats the EEPROM emulation area,
|
||||||
* optionally erasing its content.
|
|
||||||
* @param EraseBuffer Indicates whether to erase the content of the EEPROM emulation area:
|
|
||||||
* - true: Erase the content of the EEPROM emulation area(In RAM).
|
|
||||||
* - false: Do not erase the content (only format Flash).
|
|
||||||
* @return bool Boolean value indicating the success of the operation:
|
* @return bool Boolean value indicating the success of the operation:
|
||||||
* - true: Formatting successful.
|
* - true: Formatting successful.
|
||||||
* - false: Formatting failed.
|
* - false: Formatting failed.
|
||||||
*/
|
*/
|
||||||
bool EE_Format(bool EraseBuffer)
|
bool EE_Format(void)
|
||||||
{
|
{
|
||||||
bool answer = false;
|
bool answer = false;
|
||||||
uint32_t error;
|
uint32_t error;
|
||||||
|
@ -216,6 +215,7 @@ bool EE_Format(bool EraseBuffer)
|
||||||
{
|
{
|
||||||
HAL_FLASH_Unlock();
|
HAL_FLASH_Unlock();
|
||||||
#ifdef HAL_ICACHE_MODULE_ENABLED
|
#ifdef HAL_ICACHE_MODULE_ENABLED
|
||||||
|
/* disabling ICACHE if enabled*/
|
||||||
HAL_ICACHE_Disable();
|
HAL_ICACHE_Disable();
|
||||||
#endif
|
#endif
|
||||||
#if EE_ERASE == EE_ERASE_PAGE_ADDRESS
|
#if EE_ERASE == EE_ERASE_PAGE_ADDRESS
|
||||||
|
@ -237,10 +237,12 @@ bool EE_Format(bool EraseBuffer)
|
||||||
#ifdef FLASH_VOLTAGE_RANGE_3
|
#ifdef FLASH_VOLTAGE_RANGE_3
|
||||||
flashErase.VoltageRange = FLASH_VOLTAGE_RANGE_3;
|
flashErase.VoltageRange = FLASH_VOLTAGE_RANGE_3;
|
||||||
#endif
|
#endif
|
||||||
|
/* erasing page/sector */
|
||||||
if (HAL_FLASHEx_Erase(&flashErase, &error) != HAL_OK)
|
if (HAL_FLASHEx_Erase(&flashErase, &error) != HAL_OK)
|
||||||
{
|
{
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
/* checking result */
|
||||||
if (error != 0xFFFFFFFF)
|
if (error != 0xFFFFFFFF)
|
||||||
{
|
{
|
||||||
break;
|
break;
|
||||||
|
@ -266,11 +268,15 @@ bool EE_Format(bool EraseBuffer)
|
||||||
void EE_Read(void)
|
void EE_Read(void)
|
||||||
{
|
{
|
||||||
uint8_t *data = eeHandle.DataPointer;
|
uint8_t *data = eeHandle.DataPointer;
|
||||||
|
if (data != NULL)
|
||||||
|
{
|
||||||
|
/* reading flash */
|
||||||
for (uint32_t i = 0; i < eeHandle.Size; i++)
|
for (uint32_t i = 0; i < eeHandle.Size; i++)
|
||||||
{
|
{
|
||||||
*data = (*(__IO uint8_t*) (EE_ADDRESS + i));
|
*data = (*(__IO uint8_t*) (EE_ADDRESS + i));
|
||||||
data++;
|
data++;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/***********************************************************************************************************/
|
/***********************************************************************************************************/
|
||||||
|
@ -278,31 +284,33 @@ void EE_Read(void)
|
||||||
/**
|
/**
|
||||||
* @brief Writes data to the EEPROM emulation area.
|
* @brief Writes data to the EEPROM emulation area.
|
||||||
* @note This function writes data to the EEPROM emulation area.
|
* @note This function writes data to the EEPROM emulation area.
|
||||||
* Optionally, the area can be formatted first before writing.
|
|
||||||
* @param FormatFirst: Indicates whether to format the EEPROM emulation area before writing:
|
|
||||||
* - true: Format the Flash area before writing.
|
|
||||||
* - false: Do not format the Flash area before writing.
|
|
||||||
* @retval true if the write operation is successful, false otherwise.
|
* @retval true if the write operation is successful, false otherwise.
|
||||||
*/
|
*/
|
||||||
bool EE_Write(bool FormatFirst)
|
bool EE_Write(void)
|
||||||
{
|
{
|
||||||
bool answer = true;
|
bool answer = true;
|
||||||
uint8_t *data = eeHandle.DataPointer;
|
uint8_t *data = eeHandle.DataPointer;
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
if (FormatFirst)
|
/* checking eeprom is initialize correctly */
|
||||||
{
|
if (data == NULL)
|
||||||
if (EE_Format(false) == false)
|
|
||||||
{
|
{
|
||||||
answer = false;
|
answer = false;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
/* formating flash area before writing */
|
||||||
|
if (EE_Format() == false)
|
||||||
|
{
|
||||||
|
answer = false;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
HAL_FLASH_Unlock();
|
HAL_FLASH_Unlock();
|
||||||
#ifdef HAL_ICACHE_MODULE_ENABLED
|
#ifdef HAL_ICACHE_MODULE_ENABLED
|
||||||
|
/* disabling ICACHE if enabled*/
|
||||||
HAL_ICACHE_Disable();
|
HAL_ICACHE_Disable();
|
||||||
#endif
|
#endif
|
||||||
#if (defined FLASH_TYPEPROGRAM_HALFWORD)
|
#if (defined FLASH_TYPEPROGRAM_HALFWORD)
|
||||||
|
/* writing buffer to flash */
|
||||||
for (uint32_t i = 0; i < eeHandle.Size ; i += 2)
|
for (uint32_t i = 0; i < eeHandle.Size ; i += 2)
|
||||||
{
|
{
|
||||||
uint64_t halfWord;
|
uint64_t halfWord;
|
||||||
|
@ -315,6 +323,7 @@ bool EE_Write(bool FormatFirst)
|
||||||
data += 2;
|
data += 2;
|
||||||
}
|
}
|
||||||
#elif (defined FLASH_TYPEPROGRAM_DOUBLEWORD)
|
#elif (defined FLASH_TYPEPROGRAM_DOUBLEWORD)
|
||||||
|
/* writing buffer to flash */
|
||||||
for (uint32_t i = 0; i < eeHandle.Size; i += 8)
|
for (uint32_t i = 0; i < eeHandle.Size; i += 8)
|
||||||
{
|
{
|
||||||
uint64_t doubleWord;
|
uint64_t doubleWord;
|
||||||
|
@ -327,6 +336,7 @@ bool EE_Write(bool FormatFirst)
|
||||||
data += 8;
|
data += 8;
|
||||||
}
|
}
|
||||||
#elif (defined FLASH_TYPEPROGRAM_QUADWORD)
|
#elif (defined FLASH_TYPEPROGRAM_QUADWORD)
|
||||||
|
/* writing buffer to flash */
|
||||||
for (uint32_t i = 0; i < eeHandle.Size; i += 16)
|
for (uint32_t i = 0; i < eeHandle.Size; i += 16)
|
||||||
{
|
{
|
||||||
if (HAL_FLASH_Program(FLASH_TYPEPROGRAM_QUADWORD, EE_ADDRESS + i, (uint32_t)data) != HAL_OK)
|
if (HAL_FLASH_Program(FLASH_TYPEPROGRAM_QUADWORD, EE_ADDRESS + i, (uint32_t)data) != HAL_OK)
|
||||||
|
@ -337,6 +347,7 @@ bool EE_Write(bool FormatFirst)
|
||||||
data += 16;
|
data += 16;
|
||||||
}
|
}
|
||||||
#elif (defined FLASH_TYPEPROGRAM_FLASHWORD)
|
#elif (defined FLASH_TYPEPROGRAM_FLASHWORD)
|
||||||
|
/* writing buffer to flash */
|
||||||
for (uint32_t i = 0; i < eeHandle.Size; i += FLASH_NB_32BITWORD_IN_FLASHWORD * 4)
|
for (uint32_t i = 0; i < eeHandle.Size; i += FLASH_NB_32BITWORD_IN_FLASHWORD * 4)
|
||||||
{
|
{
|
||||||
if (HAL_FLASH_Program(FLASH_TYPEPROGRAM_FLASHWORD, EE_ADDRESS + i, (uint32_t)data) != HAL_OK)
|
if (HAL_FLASH_Program(FLASH_TYPEPROGRAM_FLASHWORD, EE_ADDRESS + i, (uint32_t)data) != HAL_OK)
|
||||||
|
@ -347,6 +358,17 @@ bool EE_Write(bool FormatFirst)
|
||||||
data += FLASH_NB_32BITWORD_IN_FLASHWORD * 4;
|
data += FLASH_NB_32BITWORD_IN_FLASHWORD * 4;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
/* verifying Flash content */
|
||||||
|
data = eeHandle.DataPointer;
|
||||||
|
for (uint32_t i = 0; i < eeHandle.Size; i++)
|
||||||
|
{
|
||||||
|
if (*data != (*(__IO uint8_t*) (EE_ADDRESS + i)))
|
||||||
|
{
|
||||||
|
answer = false;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
data++;
|
||||||
|
}
|
||||||
|
|
||||||
} while (0);
|
} while (0);
|
||||||
|
|
||||||
|
|
13
ee.h
13
ee.h
|
@ -9,9 +9,14 @@
|
||||||
Youtube: https://www.youtube.com/@nimaltd
|
Youtube: https://www.youtube.com/@nimaltd
|
||||||
Instagram: https://instagram.com/github.NimaLTD
|
Instagram: https://instagram.com/github.NimaLTD
|
||||||
|
|
||||||
Version: 3.0.2
|
Version: 3.1.0
|
||||||
|
|
||||||
History:
|
History:
|
||||||
|
3.1.0
|
||||||
|
- Added Verify after Writing
|
||||||
|
- Added Checking Pointer in Reading/Writing
|
||||||
|
- Removed erasing buffer and formating before write
|
||||||
|
|
||||||
3.0.2
|
3.0.2
|
||||||
- Fixed Writing for H7B
|
- Fixed Writing for H7B
|
||||||
|
|
||||||
|
@ -47,10 +52,8 @@ extern "C"
|
||||||
|
|
||||||
typedef struct
|
typedef struct
|
||||||
{
|
{
|
||||||
uint32_t MagicWord;
|
|
||||||
uint8_t *DataPointer;
|
uint8_t *DataPointer;
|
||||||
uint32_t Size;
|
uint32_t Size;
|
||||||
uint32_t Lock;
|
|
||||||
|
|
||||||
} EE_HandleTypeDef;
|
} EE_HandleTypeDef;
|
||||||
|
|
||||||
|
@ -60,9 +63,9 @@ typedef struct
|
||||||
|
|
||||||
bool EE_Init(void *StoragePointer, uint32_t Size);
|
bool EE_Init(void *StoragePointer, uint32_t Size);
|
||||||
uint32_t EE_Capacity(void);
|
uint32_t EE_Capacity(void);
|
||||||
bool EE_Format(bool EraseBuffer);
|
bool EE_Format(void);
|
||||||
void EE_Read(void);
|
void EE_Read(void);
|
||||||
bool EE_Write(bool FormatFirst);
|
bool EE_Write(void);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user