0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

防止技术“轻易”盗取,一种高端芯片加密方案详解

AGk5_ZLG_zhiyua 来源:互联网 作者:佚名 2017-12-15 09:37 次阅读

提起唯一ID,最容易想到的就是我们每个人的身份证号,均是独一无二的,无法仿冒。作为芯片而言,同样具有这一身份标识——UID。利用芯片这唯一ID来实现加密,在智能产品竞争越来越激烈的情况下是十分必要的。

首先需要明确的是,没有一种加密是“绝对”可靠的,但是加密手段可以增加非法使用者的解密成本,借此来防止技术被“轻易”盗取。本次以LPC1000的UID加密方案为例进行介绍。

LPC1000系列的加密方案

通过分析得出,基于CortexM0或CortexM3内核的LPC1000系列MCU通过软件加密的方法有两种:

1、使用代码读保护机制,限制用户访问片内Flash;

2、通过芯片UID并添加加密算法使每片MCU内的程序具有唯一性。

代码读保护机制是通过使能系统中的不同安全级别,以便限制访问片内Flash,本次不做重点介绍。

UID加密

UID是唯一标识符(unique identifier),在LPC1000系列微控制器的每一颗芯片都具有全球唯一的标识符,该标识符为128位二进制序列。因此我们可以利用芯片UID的唯一性对程序进行加密,使每一个产品中的程序也具有唯一性,即使非法使用者获取了MCU中的程序复制到其他芯片中也是不能正常运行的,从而达到保护开发者的知识产权不被侵犯和盗用的目的。

LPC1000的UID加密方案

基本思路是使用上位机软件通过编程器读取芯片的UID,经加密算法运算后生成密钥,下载程序的同时向MCU的Flash中某个地址写入密钥;MCU上电后,首先读取芯片的UID,再通过与上位机相同的加密算法运算后计算出密钥,并与之前写入Flash中的密钥比较,若相同则继续执行用户程序,否则跳入死循环或执行程序开发者指定的代码。

图1 LPC1000 UID加密方案流程图

实现此方案需要准备的资源如下。

硬件资源:

  • LPC1766FBD100芯片;

  • SmartPRO 5000U-PLUS编程器;

  • QFP100-NXP适配座;

  • SmartCortex M3-1700开发板(测试用,非必需)。

软件资源:

  • SmartPRO 2008 2.0.56.exe上位机软件;

  • Programmer.rar编程器上位机UID加密补丁;

  • Uid.rar编程器上位机UID加密算法;

  • LPC1766在Keil4下的工程模板;

  • Keil4开发环境;

  • Microsoft Visual C++ 6.0。

一、下位机

下位机(即LPC1766芯片)上电并初始化后,首先读取芯片的UID,解析密钥并与Flash中的密钥比较判断后,再继续执行用户代码。这里我们举例采用的加密算法是将UID的补码作为密钥,加密方法比较简单,用户可自行对加密算法进行修改,写出复杂的加密算法。

读取芯片UID的方法是通过调用芯片内部的IAP函数实现,如图2所示。

图2 读取UID

二、上位机

在下位机LPC1766的程序编写完成并生成hex或bin文件后,按照以下步骤对MCU进行加密。

第一步,在Microsoft Visual C++ 6.0下编写加密算法,这里我们已经编写完成,仅需解压uid.rar并打开其中的VC工程。用户需要在uid.cpp中的UidAlgorithm函数中添加自定义算法,如图3。

图3 加密算法工程

加密算法编写完成后,编译将生成一个名为uid.dll的算法文件。

第二步,安装SmartPRO 2008软件,我们默认安装在C:Program Files路径下。

第三步,安装SmartPRO 2800加密补丁,方法是将Programmer.rar解压到C:Programd FilesSmartPRO 2008Programmer路径下,覆盖原来的文件。

第四步,将加密算法生成的uid.dll文件复制到C:Programd FilesSmartPRO 2008Programmer下,SmartPRO 2008启动后将会自动调用uid.dll。

第五步,连接硬件,将LPC1766芯片放入适配座ZY503D中,连接USB通信电缆和电源

第六步,烧写文件,启动SmartPRO 2008软件,选择芯片“LPC1766@LQFP100”,打开烧录文件(在Keil编写下位机程序时生成的hex或bin文件 )。此时会出现一个如图4的特殊提示,这是因为Keil编译器在编译时没有将Flash中前8个字单元的内容进行代码有效校验和的填充而产生该警告,点击“确定”即可,编译器在下载过程中会调用校验算法自动添加校验。关于代码有效校验和填充的相关内容请参考LPC1766用户手册中“Flash编程”一章的相关内容。

图4 用户代码无效提示

第七步,开始下载,点击“组合”即可,默认执行的是擦除、编程、校验三个步骤的结合。

成功编程后,如果重新读取Flash,打开缓冲区,定位到0x00002000处,可以看到已经写入的密钥。如图5所示,与此前设计的加密算法和加密预期效果一致。

图5 缓冲区查看密钥

验证方法:取下适配座中的芯片,焊接到TinyARMT17核心板上,查到SmartCortex M3-1700开发板底板上,连接P0.11到BEEP插针,如所示。开发板上电后即可听到蜂鸣器的鸣叫。以此验证芯片计算出的密钥与Flash中写入的密钥校验一致,芯片程序正常运行。

图6 开发板验证

总结

经此方法向芯片下载程序后,若有产品盗版者试图将程序读出然后复制到其他芯片上使用,程序将停留在判断密钥是否匹配语句,导致程序不再向下执行,从而防止软件程序被非法使用者盗用。ZLG致远电子在加密保护方面从未停止过脚步,为用户保驾护航不遗余力!

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 半导体芯片
    +关注

    关注

    60

    文章

    889

    浏览量

    69778
  • lpc1000
    +关注

    关注

    0

    文章

    1

    浏览量

    1596

原文标题:【安全】如何利用芯片“身份证”加密?

文章出处:【微信号:ZLG_zhiyuan,微信公众号:ZLG致远电子】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    集成芯片原理图详解

    集成芯片的原理图详解涉及多个方面,包括芯片的结构、功能模块、信号传输以及内部电路连接等。
    的头像 发表于 03-19 16:36 329次阅读

    AEB是一种汽车主动安全技术,主要由哪3大模块构成?

    AEB是一种汽车主动安全技术,主要由哪3大模块构成
    发表于 02-20 06:06

    加密狗是什么意思 加密狗怎么解除加密

    加密算法和技术,以确保软件的安全性和防止非法复制、盗版以及未经授权的使用。 加密狗可以看作是软件版权保护的一种授权策略,它将软件授权信息存储
    的头像 发表于 01-25 17:19 2507次阅读

    智能照明应用解决方案:弱电控制强电照明技术详解

    智能照明应用解决方案:弱电控制强电照明技术详解
    的头像 发表于 01-24 17:53 241次阅读
    智能照明应用解决<b class='flag-5'>方案</b>:弱电控制强电照明<b class='flag-5'>技术</b><b class='flag-5'>详解</b>

    应用方案:实时数据加密

    应用方案:实时数据加密 利用CPLD设计加密电路方便可行,能够较好地实现加密功能。AG32系列MCU产品,在芯片内部内置了CPLD逻辑,可以
    发表于 01-15 08:57

    韩国Neowine(纽文微)强加密芯片ALPU-P

    算法。 产品描述: ALPU-P由数字模块和模拟模块组成;采用TDFN23-8L封装; 属于强加密芯片 (即使在静电等湍流环境下)具有加解密功能,防止跳过验证; 单总线协议1-wire通信接口 ,通讯数据包含伪数据
    的头像 发表于 12-25 10:49 212次阅读
    韩国Neowine(纽文微)强<b class='flag-5'>加密</b><b class='flag-5'>芯片</b>ALPU-P

    加密芯片工作原理max32555

    加密芯片MAX32555是一种广泛应用的硬件加密设备,它采用先进的加密算法和技术,对数据进行
    的头像 发表于 12-13 15:03 861次阅读

    电子秤方案——口袋秤方案芯片技术

    电子秤方案——口袋秤方案芯片技术
    的头像 发表于 12-08 15:47 279次阅读

    国密加密工业路由器 数据安全升级

    提高数据传输的安全性,确保信息的机密性。国密加密路由器的优势主要体现在以下几个方面:一、高级别加密保护,支持国密加密芯片和国密SM算法软加密
    的头像 发表于 11-29 14:07 192次阅读
    国密<b class='flag-5'>加密</b>工业路由器 数据安全升级

    FDE磁盘加密技术是什么

    磁盘加密技术 如上节所述,Disk Encryption磁盘加密,目标是保护数据at Rest状态下的机密性,加密对象是整个磁盘/分区、或者文件系统,采用实时加解密技术。 磁盘
    的头像 发表于 11-29 10:54 474次阅读
    FDE磁盘<b class='flag-5'>加密技术</b>是什么

    HASH算法加密芯片的工作原理及其在STM32 MCU上的应用

    本文主要研究了HASH算法加密芯片的工作原理及其在STM32 MCU上的应用,实现了外部加密芯片对STM32 MCU的程序保护,目前的技术
    的头像 发表于 10-24 15:01 1651次阅读
    HASH算法<b class='flag-5'>加密</b><b class='flag-5'>芯片</b>的工作原理及其在STM32 MCU上的应用

    加密主控和加密芯片之间的关系是什么?

    加密主控和加密芯片之间的关系是?
    发表于 10-08 06:31

    LPC546xx加密配置-ECRP详解

    LPC546xx加密配置-ECRP详解
    的头像 发表于 09-27 16:24 644次阅读
    LPC546xx<b class='flag-5'>加密</b>配置-ECRP<b class='flag-5'>详解</b>

    探究加密芯片:它的定义、作用以及提供的保护措施

    加密芯片一种具有数据加密和安全保护功能的芯片,主要用于对敏感数据进行加密和保护,防范黑客攻击和
    发表于 05-19 17:26

    如何防止技术被盗

    如何防止技术被偷? 小偷的心理是多疑,因此我们加入如下代码。 while(i) { case 1:barek; case 2:braek; } 功能(); 这段代码用个空选择题,完成了
    发表于 05-05 12:54