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;
30 for (
size_t i = 0; i < sector_count_; ++i)
32 const auto& sector = sectors_[i];
33 if (sector.address + sector.size <= start_addr)
37 if (sector.address >= end_addr)
41 FLASH_EraseInitTypeDef erase_init = {};
43#if defined(FLASH_TYPEERASE_PAGES) && defined(FLASH_PAGE_SIZE)
44 erase_init.TypeErase = FLASH_TYPEERASE_PAGES;
45 SetNbPages(erase_init, sector.address, i);
46 erase_init.NbPages = 1;
48#elif defined(FLASH_TYPEERASE_SECTORS)
49 erase_init.TypeErase = FLASH_TYPEERASE_SECTORS;
50 erase_init.Sector =
static_cast<uint32_t
>(i);
51 erase_init.NbSectors = 1;
52 erase_init.Banks = FLASH_BANK_1;
54 return ErrorCode::NOT_SUPPORT;
58 HAL_StatusTypeDef status = HAL_FLASHEx_Erase(&erase_init, &error);
59 if (status != HAL_OK || error != 0xFFFFFFFFU)
62 return ErrorCode::FAILED;
74 return ErrorCode::ARG_ERR;
77 uint32_t addr = base_address_ + offset;
78 if (!IsInRange(addr, data.
size_))
80 return ErrorCode::OUT_OF_RANGE;
85 const uint8_t* src =
reinterpret_cast<const uint8_t*
>(data.
addr_);
88#if defined(STM32H7) || defined(STM32H5)
89 alignas(32) uint32_t flash_word_buffer[8] = {0xFFFFFFFFu, 0xFFFFFFFFu, 0xFFFFFFFFu,
90 0xFFFFFFFFu, 0xFFFFFFFFu, 0xFFFFFFFFu,
91 0xFFFFFFFFu, 0xFFFFFFFFu};
92 while (written < data.
size_)
96 std::memcpy(flash_word_buffer, src + written, chunk_size);
98 if (memcmp(
reinterpret_cast<const uint8_t*
>(addr + written), src + written,
101 written += chunk_size;
105 if (HAL_FLASH_Program(program_type_, addr + written,
106 reinterpret_cast<uint32_t
>(flash_word_buffer)) != HAL_OK)
109 return ErrorCode::FAILED;
112 written += chunk_size;
116 while (written < data.
size_)
120 if (memcmp(
reinterpret_cast<const uint8_t*
>(addr + written), src + written,
123 written += chunk_size;
127 uint64_t word = 0xFFFFFFFFFFFFFFFF;
128 std::memcpy(&word, src + written, chunk_size);
130 if (HAL_FLASH_Program(program_type_, addr + written, word) != HAL_OK)
133 return ErrorCode::FAILED;
136 written += chunk_size;
141 return ErrorCode::OK;
144bool STM32Flash::IsInRange(uint32_t addr,
size_t size)
const
146 uint32_t end = addr + size;
147 for (
size_t i = 0; i < sector_count_; ++i)
149 const auto& s = sectors_[i];
150 if (addr >= s.address && end <= s.address + s.size)
常量原始数据封装类。 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. 获取最小可写块大小(字节)。
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 通用类,构造时传入扇区列表,自动判断编程粒度。