查看原文
其他

程序又被人白嫖了!你的MCU加密了吗?

嵌入式ARM 2021-01-31


现在的MCU程序可能别人花几百块钱就能破解,为了防止大家的程序不被剽窃,今天给大家分享点加密的内容。


一、常见加密方法


本节不讲加密具体实现算法,只讲常见加密方法。


1.程序写保护


这种方法是最常见,也是最简单的一种。现在的MUC基本都有写保护功能,但是这种容易被人破解。


2.烧断数据总线


这个方法听起来不错,但有损坏的风险,同样也能破解。


3.软件加密


是一些防止别人读懂程序的方法,单一的这种方法不能防止别人全盘复制,须配合其他的加密算法。


4.添加外部硬件电路的加密方法


这个方法效果看起来比较好,但会增加成本。


5.芯片打磨改型


这个方法改了型号能误导,但同时也增加成本,解密者一般也能分析出来。


6.通过通过联网加序列号加密


通过连接网络,在你的MCU中生成一个唯一的随机长序列号,并加入复杂的特种算法,或加入你们重新编码的企业信息在里面,每个芯片内不同,复制者只能复制到一个序列号。


7.通过MCU唯一的标识加密


以前很多MCU没有唯一标识码,现在的很多MCU都具有唯一标识码了。

这个方法比较好,简单省事,能很好的防止复制。


二、读保护 + 唯一ID加密


使用读保护 + 唯一ID的加密是最常用的一种方法,也是推荐大家使用的一种方法。


1.唯一ID现在正规的芯片,每颗出厂的时候都带了一个唯一标识码,这个号码是唯一不重复的,比如STM32的就使用96位作为唯一ID。


和我们每个人的身份证号码一样,现在刚出生的婴儿,上户的时候就给他一个身份证号,那么每个芯片一生产出来,也就具备了这个身份证号。



2.加密原理读保护就不用说了,增加被破解难度。


使用唯一ID加密的方法很多,这里说一种简单的方法:出厂时程序读取唯一ID并保存在一个位置,以后程序执行之前,要读取并匹配这个唯一ID,一致才执行程序。当然,这种方法是最基础的原理,但也存在被破解的风险。所以,存储的数据,以及读取验证这两个地方需要进一步添加一些算法。


这样操作之后,即使别人读取了你的程序,也是无法正常执行。


-END-




推荐阅读



【01】RAM较小的MCU必须会这个技巧!结构体内存对齐解析【02】知名半导体MCU大厂软件开发C代码规范【03】为什么嵌入式工程师会对8位MCU有误解?【04】RGB 接口和 MCU 接口有什么不一样?【05】从架构到 RTOS 详解 DSP 和 MCU 的区别和联系



免责声明:整理文章为传播相关技术,版权归原作者所有,如有侵权,请联系删除

    您可能也对以下帖子感兴趣

    文章有问题?点此查看未经处理的缓存