
之前我们说到了Bootloader,有了它我们就可以方便的下载和运行新的程序,但是这也意味着别人也可以抄你的板子,用仿真器读出来你的程序,从而复制你的完整产品功能。所以你还需要学会对产品加密。 加密和破解是个比较那个的话题了。怎么说呢?有的东西不该收费、不该限制那么破解就是合理的,比如黑客们就看不惯某些网站企图垄断收费,某些软件企图限制网速收费。当然了,大多数人都是出于需求考虑选择的破解或者是盗版。总不能需要编辑个文档就买一套Word吧,总不能学个单片机花数十万买MDK和AD授权吧。一定程度上这些也是大多数人需求。这里关于故意引导用户习惯养成、低价&盗版挤压垄断软件市场垄断等等的话题我们就不谈了。 那么如果你不想你做的产品轻轻松松被人家复制,你就需要花一点功夫了。硬件上你可以灌胶密封、打磨掉丝印、多画无关的布线、多层布线从内走线、外接存储器、配置电阻校验等等。这里我们主要分析一下软件层面的。因为不涉及硬件改动,无差异应用等等。 首先最简单的你可以开启FLASH读取保护,防止0x0800 0000这块硬盘被别人复制下来。FLASH读保护功能在选项字节中配置。 ![]() 选项字节 选项字节的位置在0x1FFF C000,你还可以看到ST的手册的错误。需要关注的是第2个字节,即15~8位。 ![]() 读保护 默认值0xAA、保护等级0,就是不保护,所以你刚焊接好的新片子可以调试运行程序。 ![]() 读保护默认值 如果写的不是0xAA也不是0xCC,那么这时候就有了读保护功能,其他人就不能通过仿真器把你的FLASH数据读出来了。如果是0xCC那就更绝了。后面再讲。 那么怎么操作选项字节呢,跟你擦写FLASH一样,你首先得知道它在哪,也就是选项字节的地址。 ![]() 闪存存储器组织 在这里你可以看到最最最熟悉的0x0800 0000那块主存储区,还有帮你用串口下程序的ISP程序的0x1FFF 0000系统存储区,我们要找的选项字节首地址是0x1FFF C000。 我们可以直接访问选项字存储区,也可以通过FLASH接口寄存器。 首先翻到FLASH的接口寄存器位置。记住这个地址:0x4002 3C00。 ![]() FLASH接口寄存器 然后在最后的寄存器地图和复位值表中可以发现选项字节控制寄存器。 ![]() 选项字节控制寄存器 可以发现它的偏移是0x14,加上我们上面记住的地址,就是0x4002 3C00+0x14,即0x4002 3C14。然后读保护寄存器在15~8位,倒数第二个字节,由于STM32是小端模式,所以0x4002 3C14这个地址还只是第7~0位的第一个字节,所以读保护寄存器的地址就是0x4002 3C14 + 1了,即0x4002 3C15; 如果我们想知道FLASH有没有读保护呢?直接读取0x4002 3C15这个地址的一字节数据,不是0xAA就说明已经开了读保护了。比如HAL库的读保护读取源码就是这样。 ![]() 读保护等级获取 通过直接访问选项字也可以。同样需要加1访问15~8位的第二个字节。 ![]() 直接访问选项字 除此之外,STM32还有写保护功能。地址在读保护地址后面。即0x1FFF C008。 ![]() 写保护功能描述 例如407xx的单片机就是位11~0这12块扇区的写保护配置。同样的还是通过闪存接口寄存器访问,默认值是0xFFF。即全部是1。因为1是表示不保护,所以可以随便用bootloader来擦写FLASH扇区从而更新固件。紧接着后面就是前面讲的读保护。 ![]() 写保护默认值 比如可以开启bootloader所在FLASH的扇区的写保护。 访问的基本地址还是0x4002 3C00+0x14,偏移到FLASH_OPTCR,同样还是由于小端原因,所以bit 23~16所在的第3字节需要偏移2个字节,也就是之前的读保护RDP之后,即0x4002 3C16,比如HAL库就是这么上锁的。 ![]() 使能写保护 这样一来,除了你的bootloader可以擦写FLASH升级,外部仿真器想要解锁的话只能顺带清空FLASH了,就可以保护你的程序不被读出来复制。 那么这样就真的安全了吗?仍然不是,依赖硬件保护只是其中一种最简单的方法。更多的是靠加密算来进一步增加别人的复刻难度。 作者:mymymind |
STM32 GUI LTDC 最大像素时钟评估方法
【2025·STM32峰会】GUI解决方案实训分享1-对LVGL咖啡机例程的牛刀小试以及问题排查
OpenBLT移植到STM32F405开发板
为什么要先开启STM32外设时钟?
【STM32MP157】从ST官方例程中分析RPMsg-TTY/SDB核间通信的使用方法
【经验分享】STM32实例-RTC实时时钟实验④-获取RTC时间函数与中断服务函数
STM32 以太网 MAC Loopback 的实现
STM32功能安全设计包,助力产品功能安全认证
基于STM32启动过程startup_xxxx.s文件经验分享
HRTIM 指南