完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
|
为防止盗版者对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?以便灌入新程序? |
|
相关推荐
8个回答
|
|
|
直接采用芯片的烧录加密即可。没必要搞那么复杂的。
|
|
|
|
|
|
回复第 2 楼 于2013-01-09 21:20:09发表:
直接采用芯片的烧录加密即可。没必要搞那么复杂的。 谢谢! 请您稍加解释下“芯片的烧录加密” SWD接口可以进行烧录加密吗? |
|
|
|
|
|
|
|
|
求STM32F051官方加密下载工具
|
|
|
|
|
|
不幸步你后尘了!
google了一番,建议使用STM32 ST-LINK Utility擦除flash。 随下载尝试,可操作都是失败。 后发现,在菜单"Target", "Settings" 中“Connection Mode”有个“Connect Under Reset”。 意思应该是进入bootloader模式。 尝试,终于连接成功! Erase Chip、Program、恢复正常。 |
|
|
|
|
|
直接用Jlink工具进行加密就行
|
|
|
|
|
|
|
|
|
哈哈,多看书
|
|
|
|
|
你正在撰写答案
如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。
STM32F405驱动DS1302时钟模块,输出时间错乱该怎么排查?
2810 浏览 2 评论
stm32f405rgt6驱动DS1302ZN出现时间错乱问题
2420 浏览 1 评论
stm32用fsmc读取ad7606采集数据,数据不变,只有开发版复位才更新数据
2288 浏览 0 评论
2404 浏览 1 评论
1643 浏览 1 评论
浏览过的版块 |
/9
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2025-12-2 06:17 , Processed in 0.787244 second(s), Total 56, Slave 49 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191

淘帖
1942