你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

STM32开发软件如何加密

[复制链接]
w453509596 提问时间:2015-5-17 14:17 /
总是太忙,好久没有来论坛了,最近又遇到 问题了。听说STM32做的产品,别人可以把里面的代码读出来,我不想我做产品,让别人盗版了,请教下,如何对其进行加密。
收藏 1 评论11 发布时间:2015-5-17 14:17

举报

11个回答
wwwhlw 回答时间:2015-5-17 14:35:35
不懂,帮顶。。。
那就地方iv 回答时间:2015-5-17 15:44:40
可以使用STM32 ST-LINK Utility进行加密
chaplin1999-262 回答时间:2015-5-17 15:49:46
烧录的时候选择加密啊!
天使♀的☆宇★翼 回答时间:2015-5-17 16:12:18
有与楼主同样的困惑
你好我好大家好! 回答时间:2015-5-17 17:01:18
希望有高手可以详细的解答一下,也想学学习学习
lcdi 回答时间:2015-5-17 17:49:02
一个思路:让你的程序跟芯片的UID关联起来,每个芯片都有唯一的ID。这样即使简单破解读出程序,也不能烧录到别的芯片里正常工作。
当然反汇编之后仔细研读跟踪程序的执行还是能找到判断指令并且破解的,但是这样就可以大大增加破解难度和工作量,比一般的芯片破解成本高很多。
至于怎么关联,开动脑筋,每个人有不同的算法~
moyanming2013 回答时间:2015-5-17 17:58:47
chaplin1999-262 发表于 2015-5-17 15:49
烧录的时候选择加密啊!

en ,不同的烧录方式可以自动加密吧
meifan119 回答时间:2019-11-4 12:07:23
//STM32F10X软加密方法及实例代码

#define ID_ENCRYPT_EOR_RESULT_ADDRESS (0x0800F000)
#define ID_ENCRYPT_ADD_RESULT_ADDRESS (0x0800F004)
volatile uint32 gU32IdAdressVar;//这里一定要定义此变量,否则会被优化器优化掉
void Stm32F10xEncryptDemo(void)
{
        uint32 *u32IdAddress;
  uint32 u32EorRslt, u32AddRslt;
        #IF 0
        //如果直接赋值0X1FFFF7E8,则程序编译结果里会有0X1FFFF7E8,这样破解人员会很轻松
        //的找到这个内容,然后非常容易进行修改,去掉软加密
        u32IdAddress = (uint32*)0x1ffff7e8;
        #else
        //千万别显式的读取ID,即要把0X1FFFF7E8运算成隐式的,例如此例中0x1FFFF7E8 = (0x455873a * 4) + 0xEA9DB00;
        //这样,别人就算破解出了你的程序,也查找不到0X1FFFF7E8,这样就不能轻易的软解密,这样处理后如果要软解密,
        //一定要反汇编出来进行复杂逆向分析,难度极大,代价极高,很难搞定软加密了,达到保护产品的目的。
        gU32IdAdressVar = 0x455873a;
        gU32IdAdressVar <<= 2;//0x11561CE8
        u32IdAddress = (uint32*)(gU32IdAdressVar + 0xEA9DB00);//0x1ffff7e8
        #endif
        //读取单片机的ID,并进行运算,具体算法可以自己定,这里只用到简单的异或及和运算
        u32EorRslt = (*u32IdAddress) ^ (*(u32IdAddress + 1)) ^ (*(u32IdAddress + 2));
        u32AddRslt = (*u32IdAddress) + (*(u32IdAddress + 1)) + (*(u32IdAddress + 2));
        //进行对比,如果运算结果与FLASH保存的结果不一样,说明非法,运行错误代码
        if(u32EorRslt != *((uint32*)ID_ENCRYPT_EOR_RESULT_ADDRESS))
        {
                while(1);//异或算法结果不正确,进行错误分支
        }
        if(u32AddRslt != *((uint32*)ID_ENCRYPT_ADD_RESULT_ADDRESS))
        {
                while(1);//和算法结果不正确,进行错误分支
        }
}
//QQ9272078
aiherong 回答时间:2019-11-5 02:25:51
加密与否,烧录后机器码都一样的,只是熔断读使能
12下一页
关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32Cube扩展软件包
意法半导体边缘AI套件
ST - 理想汽车豪华SUV案例
ST意法半导体智能家居案例
STM32 ARM Cortex 32位微控制器
关注我们
st-img 微信公众号
st-img 手机版