1#include "stm32_flash.hpp"
7 :
Flash(sectors[start_sector - 1].size, DetermineMinWriteSize(),
8 {
reinterpret_cast<void*
>(sectors[start_sector - 1].address),
9 sectors[sector_count - 1].address - sectors[start_sector - 1].address +
10 sectors[sector_count - 1].size}),
12 base_address_(sectors[start_sector - 1].address),
13 program_type_(DetermineProgramType()),
14 sector_count_(sector_count)
22 return ErrorCode::ARG_ERR;
25 uint32_t start_addr = base_address_ + offset;
26 uint32_t end_addr = start_addr + size;
28#if defined(__ICACHE_PRESENT) && (__ICACHE_PRESENT == 1U)
29 bool i_cache_enabled = ((SCB->CCR & SCB_CCR_IC_Msk) != 0U);
36#if defined(__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U)
37 bool d_cache_enabled = ((SCB->CCR & SCB_CCR_DC_Msk) != 0U);
46 for (
size_t i = 0; i < sector_count_; ++i)
48 const auto& sector = sectors_[i];
49 if (sector.address + sector.size <= start_addr)
53 if (sector.address >= end_addr)
57 FLASH_EraseInitTypeDef erase_init = {};
59#if defined(FLASH_TYPEERASE_PAGES) && defined(FLASH_PAGE_SIZE)
60 erase_init.TypeErase = FLASH_TYPEERASE_PAGES;
61 SetNbPages(erase_init, sector.address, i);
62 erase_init.NbPages = 1;
63 SetBanks(erase_init, sector.address);
64#elif defined(FLASH_TYPEERASE_SECTORS)
65 erase_init.TypeErase = FLASH_TYPEERASE_SECTORS;
66 erase_init.Sector =
static_cast<uint32_t
>(i) % FLASH_SECTOR_TOTAL;
67 erase_init.NbSectors = 1;
68#if defined(FLASH_BANK_1)
69 erase_init.Banks = STM32FlashBankOf(sector.address);
71#if defined(FLASH_CR_PSIZE)
72 erase_init.VoltageRange = FLASH_VOLTAGE_RANGE_1;
75 return ErrorCode::NOT_SUPPORT;
79 HAL_StatusTypeDef status = HAL_FLASHEx_Erase(&erase_init, &error);
80 if (status != HAL_OK || error != 0xFFFFFFFFU)
83 return ErrorCode::FAILED;
89#if defined(__ICACHE_PRESENT) && (__ICACHE_PRESENT == 1U)
96#if defined(__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U)
104 return ErrorCode::OK;
111 return ErrorCode::ARG_ERR;
114 uint32_t addr = base_address_ + offset;
115 if (!IsInRange(addr, data.
size_))
117 return ErrorCode::OUT_OF_RANGE;
120#if defined(__ICACHE_PRESENT) && (__ICACHE_PRESENT == 1U)
121 bool i_cache_enabled = ((SCB->CCR & SCB_CCR_IC_Msk) != 0U);
128#if defined(__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U)
129 bool d_cache_enabled = ((SCB->CCR & SCB_CCR_DC_Msk) != 0U);
138 const uint8_t* src =
reinterpret_cast<const uint8_t*
>(data.
addr_);
141#if defined(STM32H7) || defined(STM32H5)
142 alignas(32) uint32_t flash_word_buffer[8] = {0xFFFFFFFFu, 0xFFFFFFFFu, 0xFFFFFFFFu,
143 0xFFFFFFFFu, 0xFFFFFFFFu, 0xFFFFFFFFu,
144 0xFFFFFFFFu, 0xFFFFFFFFu};
145 while (written < data.
size_)
152 if (
Memory::FastCmp(
reinterpret_cast<const uint8_t*
>(addr + written), src + written,
155 written += chunk_size;
159 if (HAL_FLASH_Program(program_type_, addr + written,
160 reinterpret_cast<uint32_t
>(flash_word_buffer)) != HAL_OK)
163 return ErrorCode::FAILED;
166 written += chunk_size;
170 while (written < data.
size_)
174 if (
Memory::FastCmp(
reinterpret_cast<const uint8_t*
>(addr + written), src + written,
177 written += chunk_size;
181 uint64_t word = 0xFFFFFFFFFFFFFFFF;
184 if (HAL_FLASH_Program(program_type_, addr + written, word) != HAL_OK)
187 return ErrorCode::FAILED;
190 written += chunk_size;
196#if defined(__ICACHE_PRESENT) && (__ICACHE_PRESENT == 1U)
203#if defined(__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U)
210 return ErrorCode::OK;
213bool STM32Flash::IsInRange(uint32_t addr,
size_t size)
const
215 const uint32_t BEGIN = base_address_;
216 const uint32_t LIMIT =
217 sectors_[sector_count_ - 1].address + sectors_[sector_count_ - 1].size;
218 const uint32_t END = addr + size;
219 return (addr >= BEGIN) && (END <= LIMIT) && (END >= addr);
常量原始数据封装类。 A class for encapsulating constant raw data.
size_t size_
数据大小(字节)。 The size of the data (in bytes).
const void * addr_
数据存储地址(常量)。 The storage address of the data (constant).
Abstract base class representing a flash memory interface. 抽象基类,表示闪存接口。
size_t MinWriteSize() const
Returns the minimum writable block size in bytes. 获取最小可写块大小(字节)。
static void FastSet(void *dst, uint8_t value, size_t size)
快速内存填充 / Fast memory fill
static int FastCmp(const void *a, const void *b, size_t size)
快速内存比较 / Fast memory comparison
static void FastCopy(void *dst, const void *src, size_t size)
快速内存拷贝 / Fast memory copy
ErrorCode Write(size_t offset, ConstRawData data) override
Writes data to the flash memory. 向闪存写入数据。
STM32Flash(const FlashSector *sectors, size_t sector_count, size_t start_sector)
STM32Flash 类,构造时传入扇区列表,自动判断编程粒度。
ErrorCode Erase(size_t offset, size_t size) override
Erases a section of the flash memory. 擦除闪存的指定区域。
constexpr auto min(T1 a, T2 b) -> typename std::common_type< T1, T2 >::type
计算两个数的最小值
STM32Flash 通用类,构造时传入扇区列表,自动判断编程粒度。