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

    文章

    912

    浏览量

    70540
  • lpc1000
    +关注

    关注

    0

    文章

    1

    浏览量

    1608

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

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

收藏 人收藏

    评论

    相关推荐

    aes加密的常见错误及解决方案

    AES(Advanced Encryption Standard,高级加密标准)是一种对称加密算法,它使用固定长度的密钥对数据进行加密。在使用AES
    的头像 发表于 11-14 15:13 140次阅读

    智慧公交是什么?文带你详解智慧公交的解决方案

    智慧公交是什么?文带你详解智慧公交的解决方案
    的头像 发表于 11-05 12:26 133次阅读
    智慧公交是什么?<b class='flag-5'>一</b>文带你<b class='flag-5'>详解</b>智慧公交的解决<b class='flag-5'>方案</b>!

    安卓APP开发中,如何使用加密芯片?

    加密芯片一种专门设计用于保护信息安全的硬件设备,它通过内置的加密算法对数据进行加密和解密,以防止
    的头像 发表于 10-31 17:43 276次阅读
    安卓APP开发中,如何使用<b class='flag-5'>加密</b><b class='flag-5'>芯片</b>?

    为电机体化应用提供一种双通道集成电机驱动方案的电机驱动芯片-SS6811H

    电机驱动芯片 - SS6811H为舞台灯光和其它电机体化应用提供一种双通道集成电机驱动方案。SS6811H是款双通道H桥驱动
    的头像 发表于 09-26 09:33 270次阅读
    为电机<b class='flag-5'>一</b>体化应用提供<b class='flag-5'>一种</b>双通道集成电机驱动<b class='flag-5'>方案</b>的电机驱动<b class='flag-5'>芯片</b>-SS6811H

    AG32 芯片保护与加密

    AG32 芯片保护与加密 代码安全有两方式: 一种是 Lock flash,个是代码加密
    发表于 09-19 16:01

    一种供电总线技术POWERBUS二总线

    首先给大家介绍一种总线技术Powerbus总线,特性: 1.总线可供电,通讯和供电无需电气隔离 2.总线抗干扰能力强,可与市电并走 3.可支持总线电流20A(2400bps) 4.具备总线短路保护
    发表于 07-23 13:38

    一种浮力储能的技术方案

    如图的技术方案,各位请看看能否解决现在比较难处理储能的问题。
    发表于 07-04 15:41

    嵌入式产品如何做安全加密

    为了防止硬件电路与固件被抄袭,核心在于加密芯片和安全解决方案的设计,目前大多MPU并不具备安全防护功能,所以最好的办法是使用颗专用的
    的头像 发表于 06-20 17:46 776次阅读
    嵌入式产品如何做安全<b class='flag-5'>加密</b>?

    一种基于WTR096-28SS芯片方案的宠物喂食器设计方案

    方案宠物喂食器采用了WTR096-28SS芯片方案来实现智能化的喂食功能。该方案结合了先进的技术和设计理念,提供了便捷、智能和个性化的宠物
    的头像 发表于 03-12 10:38 452次阅读
    求<b class='flag-5'>一种</b>基于WTR096-28SS<b class='flag-5'>芯片</b><b class='flag-5'>方案</b>的宠物喂食器设计<b class='flag-5'>方案</b>

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

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

    应用方案:实时数据加密

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

    高性能加密芯片LKT4302U概述

    加密狗是一种关键的安全设备,扮演着数据安全的守护者。如果客户需要支持USB接口的、可控GPIO的加密芯片,LKT4302U是不错的选择。
    的头像 发表于 12-26 10:13 649次阅读

    加密芯片工作原理max32555

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

    FDE磁盘加密技术是什么

    (也称为File-Based Encryption)两大类。 3.1、FDE Full-Disk Encryption全盘加密在实现上有硬件、软件两方案。两者核心原理类
    的头像 发表于 11-29 10:54 1217次阅读
    FDE磁盘<b class='flag-5'>加密技术</b>是什么

    SiP封装、合封芯片芯片合封是一种技术吗?都是合封芯片技术

    本文将帮助您更好地理解合封芯片芯片合封和SiP系统级封装这三不同的技术。合封芯片一种将多个
    的头像 发表于 11-23 16:03 1530次阅读