找回密码
 立即注册
查看: 15|回复: 2

关于STC8H8K64U代码区部分Flash需要保护的问题

[复制链接]
  • 打卡等级:常住居民II
  • 打卡总天数:94
  • 最近打卡:2026-05-13 15:26:38

14

主题

56

回帖

730

积分

高级会员

积分
730
发表于 昨天 15:26 | 显示全部楼层 |阅读模式
最近一个小产品,涉及到使用MCU ID数据做成激活码问题,流程是这样的。

1:MCU代码包含两个部分:
     a: USB功能的bootloader,使用STC的官方下载软件;
     b: USB功能的APP,使用.hex文件,使用STC官方的升级软件。
2:把bootloader 和 .hex文件都交给客户自己下载,下载完成后,按下某个键后会输出 MCU ID(7各字节x2=14)。
3:客户把激活码发回给我,使用同样的算法,在软件工具生成8位激活码,发回客户;
4:客户在键盘输入或者USB发送激活码后,APP会校验此激活码是否正确,正确则保存到Flash中。
5:后续APP有bug的话,获得修改bug的.hex文件。通过USB发送命令,APP收到此命令后进入bootloader状态,等待升级。

现在的问题是,bootloader正常升级后,把客户输入的激活码擦除了,每次升级后都需要重新输入激活码。
STC官方bootloader升级代码里,有这么一段代码,是否可以设置某个范围的flash不能擦除,例如Flash的最后512字节去或者1K字节区?
//*******************************************************************************************

        case DFU_CMD_ERASE:
            addr = 0;
            while (addr < 0xf000)
            {
                iap_erase_page(addr);
                addr += 0x200;
            }
            break;

//*********************************************************************************************
或者在APP代码里把某段的Flash内如保护起来,不让bootloader擦除。

回复

使用道具 举报 送花

  • 打卡等级:常住居民II
  • 打卡总天数:94
  • 最近打卡:2026-05-13 15:26:38

14

主题

56

回帖

730

积分

高级会员

积分
730
发表于 昨天 15:42 | 显示全部楼层
有个不明白,为什么bootloader收到擦除命令后,从0区位置开始,而不是设定4K区位置开始?
Flash前4K区域不是给bootloader占用了吗?
然后我把代码修改以下后,代码能运行,也能正常升级,但是最后1K的flash写入数据失败。
//*****************************************************************************
        case DFU_CMD_ERASE:
            addr = 0;
            while (addr < 0xEC00)
            {
                iap_erase_page(addr);
                addr += 0x200;
            }
            break;
//*****************************************************************************
回复

使用道具 举报 送花

  • 打卡等级:以坛为家III
  • 打卡总天数:678
  • 最近打卡:2026-05-13 15:44:04
已绑定手机

52

主题

2632

回帖

9155

积分

论坛元老

积分
9155
发表于 昨天 15:44 | 显示全部楼层
用户ISP(bootloader)代码是开源的,用户可以根据自身需要修改功能和协议。
像你提供的擦除命令代码:
  1.         case DFU_CMD_ERASE:
  2.             addr = 0;
  3.             while (addr < 0xf000)
  4.             {
  5.                 iap_erase_page(addr);
  6.                 addr += 0x200;
  7.             }
  8.             break;
复制代码

addr < 0xf000 时才会执行擦除指令,也就是Flash空间 0xf000~0xffff 区域是不会被擦除的。
将存放激活码地址的空间也加入不擦除区域就可以。
例如设置 addr < 0xec00 ,那么升级时 0xec00~0xf000 区域也不会被擦除。
回复

使用道具 举报 送花

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|深圳国芯人工智能有限公司 ( 粤ICP备2022108929号-2 )

GMT+8, 2026-5-14 03:25 , Processed in 0.102334 second(s), 53 queries .

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

快速回复 返回顶部 返回列表