This commit is contained in:
Nima Askari ----- نیما عسکری 2021-01-18 10:18:18 +03:30 committed by GitHub
parent f2b5627110
commit f2624dd856
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 108 additions and 72 deletions

63
ee.c
View File

@ -5,6 +5,7 @@
#define PAGE 0 #define PAGE 0
#define SECTOR 1 #define SECTOR 1
#define PAGE_NUM 2
#if defined(STM32F103xB) #if defined(STM32F103xB)
#define _EE_SIZE 1024 #define _EE_SIZE 1024
@ -12,7 +13,7 @@
#define _EE_FLASH_BANK FLASH_BANK_1 #define _EE_FLASH_BANK FLASH_BANK_1
#define _EE_PAGE_OR_SECTOR PAGE #define _EE_PAGE_OR_SECTOR PAGE
#if (_EE_USE_FLASH_PAGE_OR_SECTOR > 127) #if (_EE_USE_FLASH_PAGE_OR_SECTOR > 127)
#error "Please Enter currect address, maximum is (127)" #error "Please Enter correct address, maximum is (127)"
#endif #endif
#endif #endif
@ -22,7 +23,7 @@
#define _EE_FLASH_BANK FLASH_BANK_1 #define _EE_FLASH_BANK FLASH_BANK_1
#define _EE_PAGE_OR_SECTOR PAGE #define _EE_PAGE_OR_SECTOR PAGE
#if (_EE_USE_FLASH_PAGE_OR_SECTOR > 63) #if (_EE_USE_FLASH_PAGE_OR_SECTOR > 63)
#error "Please Enter currect address, maximum is (63)" #error "Please Enter correct address, maximum is (63)"
#endif #endif
#endif #endif
@ -32,7 +33,7 @@
#define _EE_FLASH_BANK FLASH_BANK_1 #define _EE_FLASH_BANK FLASH_BANK_1
#define _EE_PAGE_OR_SECTOR PAGE #define _EE_PAGE_OR_SECTOR PAGE
#if (_EE_USE_FLASH_PAGE_OR_SECTOR > 127) #if (_EE_USE_FLASH_PAGE_OR_SECTOR > 127)
#error "Please Enter currect address, maximum is (127)" #error "Please Enter correct address, maximum is (127)"
#endif #endif
#endif #endif
@ -42,7 +43,7 @@
#define _EE_FLASH_BANK FLASH_BANK_1 #define _EE_FLASH_BANK FLASH_BANK_1
#define _EE_PAGE_OR_SECTOR PAGE #define _EE_PAGE_OR_SECTOR PAGE
#if (_EE_USE_FLASH_PAGE_OR_SECTOR > 191) #if (_EE_USE_FLASH_PAGE_OR_SECTOR > 191)
#error "Please Enter currect address, maximum is (191)" #error "Please Enter correct address, maximum is (191)"
#endif #endif
#endif #endif
@ -52,7 +53,7 @@
#define _EE_FLASH_BANK FLASH_BANK_1 #define _EE_FLASH_BANK FLASH_BANK_1
#define _EE_PAGE_OR_SECTOR PAGE #define _EE_PAGE_OR_SECTOR PAGE
#if (_EE_USE_FLASH_PAGE_OR_SECTOR > 255) #if (_EE_USE_FLASH_PAGE_OR_SECTOR > 255)
#error "Please Enter currect address, maximum is (255)" #error "Please Enter correct address, maximum is (255)"
#endif #endif
#endif #endif
@ -61,7 +62,7 @@
#define _EE_ADDR_INUSE (((uint32_t)0x08000000) | (_EE_SIZE * _EE_USE_FLASH_PAGE_OR_SECTOR)) #define _EE_ADDR_INUSE (((uint32_t)0x08000000) | (_EE_SIZE * _EE_USE_FLASH_PAGE_OR_SECTOR))
#define _EE_PAGE_OR_SECTOR PAGE #define _EE_PAGE_OR_SECTOR PAGE
#if (_EE_USE_FLASH_PAGE_OR_SECTOR > 15) #if (_EE_USE_FLASH_PAGE_OR_SECTOR > 15)
#error "Please Enter currect address, maximum is (15)" #error "Please Enter correct address, maximum is (15)"
#endif #endif
#endif #endif
@ -70,7 +71,7 @@
#define _EE_ADDR_INUSE (((uint32_t)0x08000000) | (_EE_SIZE * _EE_USE_FLASH_PAGE_OR_SECTOR)) #define _EE_ADDR_INUSE (((uint32_t)0x08000000) | (_EE_SIZE * _EE_USE_FLASH_PAGE_OR_SECTOR))
#define _EE_PAGE_OR_SECTOR PAGE #define _EE_PAGE_OR_SECTOR PAGE
#if (_EE_USE_FLASH_PAGE_OR_SECTOR > 31) #if (_EE_USE_FLASH_PAGE_OR_SECTOR > 31)
#error "Please Enter currect address, maximum is (31)" #error "Please Enter correct address, maximum is (31)"
#endif #endif
#endif #endif
@ -79,7 +80,7 @@
#define _EE_ADDR_INUSE (((uint32_t)0x08000000) | (_EE_SIZE * _EE_USE_FLASH_PAGE_OR_SECTOR)) #define _EE_ADDR_INUSE (((uint32_t)0x08000000) | (_EE_SIZE * _EE_USE_FLASH_PAGE_OR_SECTOR))
#define _EE_PAGE_OR_SECTOR PAGE #define _EE_PAGE_OR_SECTOR PAGE
#if (_EE_USE_FLASH_PAGE_OR_SECTOR > 63) #if (_EE_USE_FLASH_PAGE_OR_SECTOR > 63)
#error "Please Enter currect address, maximum is (63)" #error "Please Enter correct address, maximum is (63)"
#endif #endif
#endif #endif
@ -88,7 +89,7 @@
#define _EE_ADDR_INUSE (((uint32_t)0x08000000) | (_EE_SIZE * _EE_USE_FLASH_PAGE_OR_SECTOR)) #define _EE_ADDR_INUSE (((uint32_t)0x08000000) | (_EE_SIZE * _EE_USE_FLASH_PAGE_OR_SECTOR))
#define _EE_PAGE_OR_SECTOR PAGE #define _EE_PAGE_OR_SECTOR PAGE
#if (_EE_USE_FLASH_PAGE_OR_SECTOR > 63) #if (_EE_USE_FLASH_PAGE_OR_SECTOR > 63)
#error "Please Enter currect address, maximum is (63)" #error "Please Enter correct address, maximum is (63)"
#endif #endif
#endif #endif
@ -97,11 +98,10 @@
#define _EE_ADDR_INUSE (((uint32_t)0x08000000) | (_EE_SIZE * _EE_USE_FLASH_PAGE_OR_SECTOR)) #define _EE_ADDR_INUSE (((uint32_t)0x08000000) | (_EE_SIZE * _EE_USE_FLASH_PAGE_OR_SECTOR))
#define _EE_PAGE_OR_SECTOR PAGE #define _EE_PAGE_OR_SECTOR PAGE
#if (_EE_USE_FLASH_PAGE_OR_SECTOR > 127) #if (_EE_USE_FLASH_PAGE_OR_SECTOR > 127)
#error "Please Enter currect address, maximum is (127)" #error "Please Enter correct address, maximum is (127)"
#endif #endif
#endif #endif
#if defined(STM32F405xx) || defined(STM32F407xx) || defined(STM32F415xx) || defined(STM32F417xx) #if defined(STM32F405xx) || defined(STM32F407xx) || defined(STM32F415xx) || defined(STM32F417xx)
#define _EE_SIZE (1024 * 128) #define _EE_SIZE (1024 * 128)
#define _EE_ADDR_INUSE (((uint32_t)0x08020000) | (_EE_SIZE*(_EE_USE_FLASH_PAGE_OR_SECTOR - 5))) #define _EE_ADDR_INUSE (((uint32_t)0x08020000) | (_EE_SIZE*(_EE_USE_FLASH_PAGE_OR_SECTOR - 5)))
@ -109,10 +109,20 @@
#define _EE_VOLTAGE_RANGE _EE_VOLTAGE #define _EE_VOLTAGE_RANGE _EE_VOLTAGE
#define _EE_PAGE_OR_SECTOR PAGE #define _EE_PAGE_OR_SECTOR PAGE
#if (_EE_USE_FLASH_PAGE_OR_SECTOR > 11) #if (_EE_USE_FLASH_PAGE_OR_SECTOR > 11)
#error "Please Enter currect address, maximum is (11)" #error "Please Enter correct address, maximum is (11)"
#endif #endif
#if (_EE_USE_FLASH_PAGE_OR_SECTOR < 5) #if (_EE_USE_FLASH_PAGE_OR_SECTOR < 5)
#error "Please Enter currect address, minimum is (5)" #error "Please Enter correct address, minimum is (5)"
#endif
#endif
#if defined(STM32L433xx)
#define _EE_SIZE 2048
#define _EE_ADDR_INUSE (((uint32_t)0x08000000) | (_EE_SIZE * _EE_USE_FLASH_PAGE_OR_SECTOR))
#define _EE_FLASH_BANK FLASH_BANK_1
#define _EE_PAGE_OR_SECTOR PAGE_NUM
#if (_EE_USE_FLASH_PAGE_OR_SECTOR > 127)
#error "Please Enter correct address, maximum is (127)"
#endif #endif
#endif #endif
@ -139,10 +149,14 @@ bool ee_format(bool keepRamData)
flashErase.NbPages = 1; flashErase.NbPages = 1;
flashErase.PageAddress = _EE_ADDR_INUSE; flashErase.PageAddress = _EE_ADDR_INUSE;
flashErase.TypeErase = FLASH_TYPEERASE_PAGES; flashErase.TypeErase = FLASH_TYPEERASE_PAGES;
#else #elif _EE_PAGE_OR_SECTOR == SECTOR
flashErase.NbSectors = 1; flashErase.NbSectors = 1;
flashErase.Sector = _EE_ADDR_INUSE; flashErase.Sector = _EE_ADDR_INUSE;
flashErase.TypeErase = FLASH_TYPEERASE_SECTORS; flashErase.TypeErase = FLASH_TYPEERASE_SECTORS;
#elif _EE_PAGE_OR_SECTOR == PAGE_NUM
flashErase.NbPages = 1;
flashErase.Page = _EE_USE_FLASH_PAGE_OR_SECTOR;
flashErase.TypeErase = FLASH_TYPEERASE_PAGES;
#endif #endif
#ifdef _EE_FLASH_BANK #ifdef _EE_FLASH_BANK
flashErase.Banks = _EE_FLASH_BANK; flashErase.Banks = _EE_FLASH_BANK;
@ -203,7 +217,8 @@ bool ee_write(uint32_t startVirtualAddress, uint32_t len, uint8_t* data)
return false; return false;
} }
} }
#else #endif
#ifdef FLASH_TYPEPROGRAM_HALFWORD
for (uint32_t i = 0; i < len ; i+=2) for (uint32_t i = 0; i < len ; i+=2)
{ {
if (HAL_FLASH_Program(FLASH_TYPEPROGRAM_HALFWORD, ((i + startVirtualAddress)) + _EE_ADDR_INUSE, (uint64_t)(data[i] | (data[i+1] << 8))) != HAL_OK) if (HAL_FLASH_Program(FLASH_TYPEPROGRAM_HALFWORD, ((i + startVirtualAddress)) + _EE_ADDR_INUSE, (uint64_t)(data[i] | (data[i+1] << 8))) != HAL_OK)
@ -212,6 +227,24 @@ bool ee_write(uint32_t startVirtualAddress, uint32_t len, uint8_t* data)
return false; return false;
} }
} }
#endif
#ifdef FLASH_TYPEPROGRAM_DOUBLEWORD
for (uint32_t i = 0; i < len; i += 8)
{
uint64_t data64 = data[i];
data64 += data[i + 1] * 0x100;
data64 += data[i + 2] * 0x10000;
data64 += data[i + 3] * 0x1000000;
data64 += data[i + 4] * 0x100000000;
data64 += data[i + 5] * 0x10000000000;
data64 += data[i + 6] * 0x1000000000000;
data64 += data[i + 7] * 0x100000000000000;
if (HAL_FLASH_Program(FLASH_TYPEPROGRAM_DOUBLEWORD, ((i + startVirtualAddress)) + _EE_ADDR_INUSE, data64) != HAL_OK)
{
HAL_FLASH_Lock();
return false;
}
}
#endif #endif
HAL_FLASH_Lock(); HAL_FLASH_Lock();
return true; return true;

7
ee.h
View File

@ -7,7 +7,10 @@
Instagram: http://instagram.com/github.NimaLTD Instagram: http://instagram.com/github.NimaLTD
Youtube: https://www.youtube.com/channel/UCUhY7qY1klJm1d2kulr9ckw Youtube: https://www.youtube.com/channel/UCUhY7qY1klJm1d2kulr9ckw
Version: 2.0.1 Version: 2.0.2
(2.0.2)
Add L4().
(2.0.1) (2.0.1)
Change function name to ee_commit(). Change function name to ee_commit().
@ -23,7 +26,7 @@
#endif #endif
#include <stdbool.h> #include <stdbool.h>
#include "gpio.h" #include "main.h"
//################################################################################################################ //################################################################################################################
bool ee_init(void); bool ee_init(void);

View File

@ -1,7 +1,7 @@
#ifndef __EECONFIG_H #ifndef __EECONFIG_H
#define __EECONFIG_H #define __EECONFIG_H
#define _EE_USE_FLASH_PAGE_OR_SECTOR (63) #define _EE_USE_FLASH_PAGE_OR_SECTOR (127)
#define _EE_USE_RAM_BYTE (1024) #define _EE_USE_RAM_BYTE (1024)
#define _EE_VOLTAGE FLASH_VOLTAGE_RANGE_3 // use in some devices #define _EE_VOLTAGE FLASH_VOLTAGE_RANGE_3 // use in some devices
#endif #endif