如下STM32F051 FLASH读保护代码对FLASH的选项字节的用途理解是否正确?

2019-07-14 13:49发布

为防止盗版者对STM32F051内FLASH中的二进制可执行代码进行读出,写了如下代码:

void Flash_Protect()
{
        if(OB_RDP_Level_1 != OB->RDP){
                FLASH_OB_Unlock();
                if(FLASH_COMPLETE == FLASH_OB_RDPConfig(OB_RDP_Level_1)){
                        FLASH_OB_Lock();
                        FLASH_OB_Launch(); // 复位
                }
        }
}


int main(void)
{
        //
        Flash_Protect();
}

请教大家:
1.如此对FLASH的选项字节的用途理解是否正确?
2.FLASH_OB_Launch(); // 复位
此行执行之后,实际效果是不可再调试;这一点我觉得是正确的
但是复位之后据观察整个代码的执行不是正确的,不知什么原因?

3.如何再从新全部擦除此FLASH?以便灌入新程序?
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
7条回答
ueywyrsdfs
1楼-- · 2019-07-14 17:45
回复第 2 楼 于2013-01-09 21:20:09发表:
直接采用芯片的烧录加密即可。没必要搞那么复杂的。
 
谢谢!
 
请您稍加解释下“芯片的烧录加密”
 
SWD接口可以进行烧录加密吗?
 
ueywyrsdfs
2楼-- · 2019-07-14 20:57
ueywyrsdfs
3楼-- · 2019-07-15 02:55
求STM32F051官方加密下载工具
testd011
4楼-- · 2019-07-15 03:40
不幸步你后尘了!
google了一番,建议使用STM32 ST-LINK Utility擦除flash。
随下载尝试,可操作都是失败。
后发现,在菜单"Target", "Settings" 中“Connection Mode”有个“Connect Under Reset”。
意思应该是进入bootloader模式。
尝试,终于连接成功!
Erase Chip、Program、恢复正常。
 
夜空城33
5楼-- · 2019-07-15 08:55
 精彩回答 2  元偷偷看……
脑洞大赛11
6楼-- · 2019-07-15 09:48

一周热门 更多>