STM32F105RCT6通过选项字节设置Flash读保护问题(基于HAL库)
实现函数如下:
__ramfunc HAL_StatusTypeDef chip_enter_flash_protection(void)
{
HAL_StatusTypeDef result = HAL_OK;
FLASH_OBProgramInitTypeDef OptionsBytesStruct = {0};
HAL_FLASHEx_OBGetConfig(&OptionsBytesStruct);
if (OptionsBytesStruct.RDPLevel == OB_RDP_LEVEL_0) {
OptionsBytesStruct.OptionType = OPTIONBYTE_RDP;
OptionsBytesStruct.RDPLevel = OB_RDP_LEVEL_1;
HAL_FLASH_Unlock();
HAL_FLASH_OB_Unlock();
result = HAL_FLASHEx_OBProgram(&OptionsBytesStruct);
if (result != HAL_OK) {
LOG("HAL_FLASHEx_OBProgram != HAL_OK\r\n");
HAL_FLASH_OB_Lock();
HAL_FLASH_Lock();
return result;
}
LOG("HAL_FLASH_OB_Launch 1\r\n");
HAL_FLASH_OB_Launch();
LOG("HAL_FLASH_OB_Launch 2\r\n");
HAL_FLASH_OB_Lock();
HAL_FLASH_Lock();
}
return result;
}
其中HAL_FLASH_OB_Launch()函数原型如下 其实就是系统软复位
/**
* @brief Launch the option byte loading.
* @note This function will reset automatically the MCU.
* @retval None
*/
void HAL_FLASH_OB_Launch(void)
{
/* Initiates a system reset request to launch the option byte loading */
HAL_NVIC_SystemReset();
}
该函数执行结果:
我的问题(实验过程中未仿真):
1、为什么执行了HAL_FLASH_OB_Launch()(即软复位)之后,程序并未重新开始运行?并且我按下开发板的reset按键(即硬复位)程序也起不来。
2、为什么我把芯片掉电,重新上电之后程序就可以跑起来了?而且读保护功能也开启了
3、也怀疑是进入了ST的引导程序,使用工具软件STM32CubeProgrammer 通过串口并未检测到连接,应该并未进入ST的引导程序
4、也测试把此函数(chip_enter_flash_protection())放置在RAM运行,但是结果一样
芯片手册看了半天也没看出个啥,哪位朋友解答一下我的疑问,十分感谢!