打印
[STM8]

请问 STM8L 在加密后,程序还可以修改程序区的Flash吗?

[复制链接]
936|7
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
songqian17|  楼主 | 2018-8-29 18:14 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
请问 STM8L 在加密后,程序还可以修改程序区的Flash吗?
沙发
jiaxw| | 2018-8-29 18:16 | 只看该作者
没试过;
你可以试下;

应该不行吧;

使用特权

评论回复
板凳
songqian17|  楼主 | 2018-8-29 18:18 | 只看该作者
不加保密位的可以,加了的有人说向一个地址写一个key可以擦除,具体是哪个地址不知道,

使用特权

评论回复
地板
songqian17|  楼主 | 2018-8-29 18:20 | 只看该作者
实验后证明是可以的.
void main(void)
{     
    FLASH_DUKR = 0xae;     
    asm("nop");     
    FLASH_DUKR = 0x56;                  // 解除写保护     
    asm("nop");     
    while(!(FLASH_IAPSR & 0x08));       // 等待解锁     
    asm("nop");     
    FLASH_CR2 = 0x80;                   // 对选项字节进行写操作     
    asm("nop");     
    *((unsigned char *)0x480b) = 0x55;     
    asm("nop");     
    *((unsigned char *)0x480c) = 0xaa;  // 写入选项字节  

    //按地址开始写程序
   
    while(1);
}

使用特权

评论回复
5
shimx| | 2018-8-29 18:22 | 只看该作者
可以的,可以直接调用FLSAH的库函数即可。改写前需要对flash写解锁。写保护位的作用只是不能通过工具读出flash数据,就是读保护而已。

使用特权

评论回复
6
jiaxw| | 2018-8-29 18:25 | 只看该作者

只知道32可以 。

使用特权

评论回复
7
songqian17|  楼主 | 2018-8-29 18:27 | 只看该作者
预料中的结果,先结贴吧,多谢大家啦

使用特权

评论回复
8
huahuagg| | 2018-8-29 18:49 | 只看该作者
只要不是存储的指令被加密了就行。这里一般不会那么复杂,所以应该可以。

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

463

主题

5749

帖子

1

粉丝