
接触读保护的代码如下: void Flash_DisableReadProtection(void) { FLASH_OBProgramInitTypeDef OBInit; HAL_FLASHEx_OBGetConfig(&OBInit); if(OBInit.RDPLevel == OB_RDP_LEVEL_1) { OBInit.OptionType = OPTIONBYTE_RDP; OBInit.RDPLevel = OB_RDP_LEVEL_0; // OBInit.WRPState = OB_WRPSTATE_DISABLE; HAL_FLASH_Unlock(); HAL_FLASH_OB_Unlock(); if(HAL_FLASHEx_OBProgram(&OBInit)!=HAL_OK) { HAL_FLASH_OB_Launch(); HAL_FLASH_OB_Lock(); HAL_FLASH_Lock(); return; } HAL_FLASH_OB_Launch(); HAL_FLASH_OB_Lock(); HAL_FLASH_Lock(); } return; }各位帮忙看看什么问题 |
MotorControl Workbench_6.3.2配置单片机时找不到STM32H743VIT6E
STM32H743IIT6同时配置ADC3通道中的温度及内部参考电压,扫描单次转换,怎样读出这二个数据?
TouchGFX Designer下载工程到STM32H7S7-DK报错
Demo 例程
关于STM32H743VIT6 在用QSPI的接口,想换个CS的管脚,但芯片内置是绑死的,这个要怎么处理,用个其他的IO口做片选
定时器使用DMA突发传输功能时,传入指针从常量数组改为变量数组后,传输功能异常。测试官方用例一样,是何原因?
STM32H745XIH6不能进行双核调试,CM4不能进行在线调试
正点原子阿波罗H743使用DMA2D后普通刷出现问题
STM32CubeMX在配置DCMI的腳位時,在Mode的選項中, 只有8bits, 10bits與12bits, 為何沒有14bits?
STM32H7双核调试问题:CM7能成功调试但CM4始终报"Failed to read ROM table via AP 3"错误
RDP_LEVE1改到RDP_LEVE0会全片擦除,这个我也通过手册了解了。但是在通过这个代码后,用ST-link查看时,读保护没有解除,这可能是什么原因导致?
你通过用户代码来解除读保护 导致用户代码都完蛋了,解除的意义是什么呢?
毕竟读保护对用户自身代码是没有妨碍的。
你现在是好奇或纠结的是为何代码里做过解除操作后仍是读保护状态,这个不好说。
个人观点是或不是读保护状态 已经不重要了。可能是因为用户代码只运行一部分
就被干掉了。下面部分来自H7系列参考手册的文字供你参考。
When Level 1 is active, programming the protection option byte (RDP) to Level 0causes the Flash memory and the backup SRAM to be mass-erased. As a result the
user code area is cleared before the read protection is removed.