HAL_FLASHEx_Erase 第二个参数
时间: 2023-07-21 22:46:36 浏览: 90
HAL_FLASHEx_Erase函数的第二个参数是要擦除的起始扇区的编号。Flash存储器通常被划分为许多个扇区,每个扇区有自己的起始地址和大小。在使用HAL_FLASHEx_Erase函数时,需要指定要擦除的起始扇区的编号,然后函数将会擦除从该扇区开始的所有扇区。需要注意的是,擦除Flash存储器会将整个扇区的数据全部清除,因此在使用HAL_FLASHEx_Erase函数前需要备份重要的数据。
相关问题
HAL_FLASHEx_Erase函数解析
HAL_FLASHEx_Erase函数是HAL库中用于擦除Flash扇区的函数,其定义如下:
```c
HAL_StatusTypeDef HAL_FLASHEx_Erase(FLASH_EraseInitTypeDef *pEraseInit, uint32_t *SectorError);
```
该函数需要传入一个FLASH_EraseInitTypeDef类型的参数pEraseInit,该结构体定义了要擦除的Flash扇区的起始地址和大小等信息。函数最后会返回一个HAL_StatusTypeDef类型的值,表示擦除操作的结果,同时还可以通过传入一个指向uint32_t类型变量的指针SectorError,获取擦除失败时的错误代码。
HAL_FLASHEx_Erase函数的实现过程如下:
1. 检查要擦除的Flash扇区是否是合法的。如果扇区大小为0或者扇区起始地址不是Flash的起始地址,函数会返回错误代码HAL_ERROR。
2. 禁止中断,并且解锁Flash。
3. 设置Flash擦除相关的寄存器。具体的操作包括:
- 将Flash擦除使能(FLASH_CR_EOPIE)位清零。
- 将Flash解锁(FLASH_KEYR)寄存器的值设置为FLASH_KEY1和FLASH_KEY2。
- 将Flash擦除(FLASH_CR_PER)位设置为1。
- 将要擦除的Flash扇区地址(FLASH_CR_PNB)写入FLASH_CR寄存器。
4. 开始执行擦除操作。具体的操作包括:
- 将Flash开始擦除(FLASH_CR_STRT)位设置为1。
- 等待擦除操作完成,或者等待超时(FLASH_TIMEOUT_VALUE)。
- 检查擦除操作是否成功。如果成功,将返回HAL_OK;否则,将返回HAL_ERROR,并通过SectorError参数返回错误代码。
5. 恢复中断,并且重新锁定Flash。
需要注意的是,该函数执行期间会禁止中断,并且解锁Flash,并且在函数执行完毕之后会恢复中断,并且重新锁定Flash。因此,在调用该函数之前,需要确保中断不会影响到Flash的操作,并且需要适当地设置Flash的保护等级以避免意外修改Flash。
HAL_FLASHEx_Erase函数代码及解析
以下是HAL_FLASHEx_Erase函数的代码实现及解析,代码基于STM32Cube HAL库:
```c
HAL_StatusTypeDef HAL_FLASHEx_Erase(FLASH_EraseInitTypeDef *pEraseInit, uint32_t *SectorError)
{
uint32_t NbSectorsToErase;
uint32_t SectorErrorTmp;
uint32_t SECTORErrorMask;
HAL_StatusTypeDef status = HAL_OK;
/* Check the parameters */
assert_param(IS_FLASH_TYPEERASE(pEraseInit->TypeErase));
assert_param(IS_FLASH_PROGRAM_ADDRESS(pEraseInit->Banks));
assert_param(IS_FLASH_NBPAGES(pEraseInit->NbPages));
/* Get the number of sectors to erase from 1st sector*/
NbSectorsToErase = (pEraseInit->NbPages * FLASH_PAGE_SIZE) / FLASH_SECTOR_SIZE;
/* Check if there are any sectors to erase */
if (NbSectorsToErase == 0U)
{
return HAL_ERROR;
}
/* Wait for last operation to be completed */
status = FLASH_WaitForLastOperation(FLASH_TIMEOUT_VALUE);
if (status != HAL_OK)
{
return status;
}
/* Initialize SECTORErrorMask to 0 */
SECTORErrorMask = 0;
/* Erase by sector by sector to have a higher granularity than the page erase */
while (NbSectorsToErase > 0U)
{
/* Clear OPTVERR bit set on virgin samples */
__HAL_FLASH_CLEAR_FLAG(FLASH_FLAG_OPTVERR);
/* Wait for last operation to be completed */
status = FLASH_WaitForLastOperation(FLASH_TIMEOUT_VALUE);
if (status != HAL_OK)
{
break;
}
/* FLASH_SECTOR_0 to FLASH_SECTOR_11 are used for STM32F103xE, STM32F103xG, STM32F101xC and STM32F101xG devices */
/* FLASH_SECTOR_0 to FLASH_SECTOR_23 are used for STM32F103xB, STM32F103xC, STM32F103xD, STM32F103xE and STM32F100xC devices */
/* Get the sector to erase */
uint32_t sectornb = FLASH_SECTOR_0;
for (uint32_t i = 0; i < FLASH_SECTOR_NUMBER; i++)
{
if (pEraseInit->Sector & (1UL << i))
{
sectornb = i;
break;
}
}
/* Fill EraseInit structure*/
pEraseInit->TypeErase = FLASH_TYPEERASE_SECTORS;
pEraseInit->Sector = (uint32_t)(1U << sectornb);
pEraseInit->NbSectors = 1;
/* Call the erase module */
HAL_FLASHEx_Erase_IT(pEraseInit);
/* Wait for last operation to be completed */
status = FLASH_WaitForLastOperation(FLASH_TIMEOUT_VALUE);
/* If the erase operation is completed, disable the SER Bit */
FLASH->CR &= CR_SPARE_MASK;
if (status != HAL_OK)
{
/* In case of error, stop erase procedure and return the faulty sector */
SECTORErrorMask |= pEraseInit->Sector;
/* Save the error code */
SectorErrorTmp |= status;
}
else
{
/*
No error occurred in sector erase operation
SECTORErrorMask is reset
*/
SECTORErrorMask = 0;
}
/* Decrement number of sectors to erase */
NbSectorsToErase--;
/* Point on next sector */
pEraseInit->Sector = (uint32_t)(pEraseInit->Sector << 1U);
}
/* Return the Erase Status */
if (SectorError != NULL)
{
*SectorError = SectorErrorTmp;
}
if (SECTORErrorMask != 0U)
{
status = HAL_ERROR;
}
/* Return the erase status */
return status;
}
```
HAL_FLASHEx_Erase函数的实现过程如下:
1. 检查输入参数pEraseInit是否合法。该结构体包含了要擦除的Flash扇区的相关信息,如起始地址、扇区数量和擦除方式等。
2. 计算需要擦除的Flash扇区数量,并且检查是否有扇区需要擦除。如果扇区数量为0,则直接返回错误。
3. 等待上一次Flash操作(如写入或擦除)完成,并且清除OPTVERR标志位。如果等待超时,则返回错误。
4. 循环执行Flash扇区擦除操作,直到所有需要擦除的扇区都被擦除。具体的操作包括:
- 获取需要擦除的扇区编号,该编号是一个0到11(或23)之间的整数。
- 将需要擦除的扇区信息填入FLASH_EraseInitTypeDef结构体中,并且调用HAL_FLASHEx_Erase_IT函数执行擦除操作。
- 等待Flash擦除操作完成,并且检查是否有错误发生。如果发生了错误,则保存错误信息,但是继续执行擦除操作直到所有需要擦除的扇区都被擦除。
- 将擦除完成的扇区数量减1,继续执行下一个扇区的擦除操作。
5. 返回擦除操作的结果。如果有错误发生,则返回错误代码;否则,返回HAL_OK表示操作成功。
需要注意的是,该函数执行期间会禁止中断,并且解锁Flash,并且在函数执行完毕之后会恢复中断,并且重新锁定Flash。因此,在调用该函数之前,需要确保中断不会影响到Flash的操作,并且需要适当地设置Flash的保护等级以避免意外修改Flash。
相关推荐
![zip](https://img-home.csdnimg.cn/images/20210720083736.png)
![zip](https://img-home.csdnimg.cn/images/20210720083736.png)
![rar](https://img-home.csdnimg.cn/images/20210720083606.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)