最近在写一个stm32的程序,已经设置了读写保护。
程序使用了bootloader,从网上找的进行了改造,发现其中可能有个bug,未经验证,想问问大家以前谁做过
摘录读写保护说明:
“
所有STM32的芯片都提供对Flash的保护,防止对Flash的非法访问 - 写保护和读保护。
1、读保护即大家通常说的“加密”,是作用于整个Flash存储区域。一旦设置了Flash的读保护,内置的Flash存储区只能通过程序的正常执行才能读出,而不能通过下述任何一种方式读出:A、 通过调试器(JTAG或SWD); B、从RAM中启动并执行的程序;
”
现在bootloader中有一个读取标志位的函数,功能是读取指定地址,函数如下,函数运行空间为flash:
//读取指定地址的字(32位数据)
//faddr:读地址
//返回值:对应数据.
unsigned int STMFLASH_ReadWord(unsigned int faddr)
{
return *(__IO unsigned int *)faddr;
}
是否存在这种可能,在设置了读保护后再通过在RAM中调用执行这个Flash空间的函数读取flash,如果可以的话保护就失效了,需要对这个函数进行一定的验证,当前我还没验证是否可行。还看看大家的看法和建议。。。。
共9条
1/1 1 跳转至页
来探讨一下!关于stm32读写保护可能的绕过方法
关键词: stm32 读写保护
共9条
1/1 1 跳转至页
回复
有奖活动 | |
---|---|
【有奖活动——B站互动赢积分】活动开启啦! | |
【有奖活动】分享技术经验,兑换京东卡 | |
话不多说,快进群! | |
请大声喊出:我要开发板! | |
【有奖活动】EEPW网站征稿正在进行时,欢迎踊跃投稿啦 | |
奖!发布技术笔记,技术评测贴换取您心仪的礼品 | |
打赏了!打赏了!打赏了! |