【经验】无线SOC EFR32BG22带安全功能的OTA怎么实现?
材料准备:
Simplicity studio 5; GSDK 4.2.3; EFR32BG22 EVB(可用BG22模块+jlink烧录器代替)
手机APP:EFR connect,安卓安装包在github下载:EFRConnect - v2.7.0.apk
下载链接:https://github.com/SiliconLabs/EFRConnect-android/blob/master/build/EFRConnect%20-%20v2.7.0.apk
备注:本文涉及到的commander命令和详细的解释,参阅UG162: Simplicity Commander Reference Guide
生成带安全性能的bootloader:
1、 选择对应的蓝牙SOC芯片型号,生成“Bootloader - SoC Bluetooth AppLoader OTA DFU”工程。打开工程下面的*slcp文件,在“software component”找到Bootloader Core组件。添加安全特性,沟选:Require signed firmware upgrade files,Enable secure boot。沟选完成后,bootloader对升级固件的要求是需要签名。
2、 编译工程,获得带安全功能的bootloader目标文件hex和s37文件。
生成秘钥
1、 使用Simplicity Commander创建安全密钥,为了便于使用,请将Commander路径(例如SSv5安装在D盘情况下:D:\SiliconLabs\SimplicityStudio\v5\developer\adapter_packs\Commander)
添加到操作系统中的path环境变量中。
2、 在命令行中运行Commander,使用以下命令生成ECDSA-P256签名密钥对(私钥app-sign-key.pem和公钥app-sign-pubkey.pem)和公钥对应的token格式文件(app-sign-pubkey.txt)。后面会通过Simplicity Commander把token格式的签名公钥(app-sign-pubkey.txt)写入到芯片main flash最后一页。
commander util genkey --type ecc-p256 --privkey app-sign-key.pem --pubkey app-sign-pubkey.pem --tokenfile app-sign-pubkey.txt
3、 运行Simplicity Commander生成为GBL文件解密的密钥,生成token格式文件,后面写入到芯片main flash最后一页。
commander util genkey --type aes-ccm --outfile app-encrypt-key.txt
注意:生成key文件的时候,请确保这两个文件名完全相同:app-sign-key.pem,app-encrypt-key.txt,这两个文件再接下来的操作,会被create_bl_files.bat文件使用。
给蓝牙应用固件签名
由于在bootloader程序中启用了安全引导(签名),因此只能引导已(签名)的应用程序镜像。
1、生成“Bluetooth - SoC Empty”工程,编译获得目标文件。默认的蓝牙广播名称是:Empty Example。
2、将前面生成的key文件:app-sign-key.pem,app-encrypt-key.txt拷贝到蓝牙工程目录下,放在和create_bl_files.bat文件在同一级目录下。
3、进入到create_bl_files.bat文件所在的文件夹,双击bat文件运行,生成OTA升级的GBL文件,这些文件会存放在工程目录下的output_gbl文件夹。把整个output_gbl文件夹拷贝单独存放备用。
4、 在output_gbl文件夹中,找到“application-signed.gbl ”,重命名为:BG22empty-signed.gbl
找到“application.gbl ”,重命名为:BG22empty.gbl 。
5、打开“Bluetooth - SoC Empty“工程中*.slcp文件,打开“CONFIGURATION TOOLS”,选择Bluetooth GATT Configurator打开。在“Device Name” 中修改蓝牙名称为“SEOTA Example”,保存后,重新编译。删除工程目录下的output_gbl文件夹,双击bat文件运行,生成新的OTA升级的GBL文件,把整个output_gbl文件夹拷贝单独存放备用。
把找到“application-signed.gbl ”,重命名为:BG22SEOTA-signed.gbl。此步骤主要是获得新蓝牙名称的固件,用于检验OTA升级是否成功。
获得带签名的蓝牙固件hex或者s37文件
1、 把BG22empty-signed.gbl文件拷贝到Commander路径下。执行以下命令,把gbl文件转换成hex文件或者s37文件。用于首次BG22芯片首次固件烧录使用。
commander convert BG22empty-signed.gbl --outfile BG22empty-signed.s37
测试log:
D:\>cd SiliconLabs\SimplicityStudio\v5\developer\adapter_packs\Commander
D:\SiliconLabs\SimplicityStudio\v5\developer\adapter_packs\commander>commander convert BG22empty-signed.gbl --outfile BG22empty-signed.s37
Parsing file BG22empty-signed.gbl...
Writing to BG22empty-signed.s37...
DONE
烧录固件和密钥
1、 为了测试效果,本次测试我们先把BG22芯片整片的flash擦除。后面的测试无需再擦除flash,直接烧录即可。
2、把bootloader和BG22empty-signed.s37烧录到BG22芯片中。使用EFR connect手机APP搜索蓝牙设备。这个时候会发现一个设备名称为OTA的蓝牙设备,是因为还未烧录签名的公钥到BG22中,bootloader不能引导启动应用程序,此时广播的设备是bootloader中的APPloader在做蓝牙广播。
3、烧录签名公钥到BG22芯片中。把app-sign-pubkey.txt文件拷贝到Commander目录下,执行以下命令:
commander flash --tokengroup znet --tokenfile app-sign-pubkey.txt --device EFR32BG22C224F512
log记录:
D:\SiliconLabs\SimplicityStudio\v5\developer\adapter_packs\commander>commander flash --tokengroup znet --tokenfile app-sign-pubkey.txt --device EFR32BG22C224F512
Writing 8192 bytes starting at address 0x0007e000
Comparing range 0x0007E000 - 0x0007FFFF (8 KB)
Programming range 0x0007E000 - 0x0007FFFF (8 KB)
Flashing completed successfully!
DONE
使用EFR connect手机APP搜索蓝牙设备。这个时候会发现一个设备名称为Empty Example的蓝牙设备,说明带签名的固件已经被正确的引导和运行了。
测试非签名固件:可以找一个不带签名的原始的BG22蓝牙固件,烧录到BG22芯片中,此时搜索到的蓝牙设备名称是OTA,说明带签名验证的bootloader,对这份固件的签名验证不通过,代码不能运行。
使用带签名固件做OTA固件升级:
1、把签名操作所生成的GBL文件复制到手机中:BG22empty.gbl ,BG22empty-signed.gbl,BG22SEOTA-signed.gbl
2、 在手机中打开EFR Connect应用程序。
3、 选择“SCANNER ”选项。
搜索蓝牙设备。找到蓝牙广播名称为“Empty Example”。因为你周围可能还有其他同名的设备在做广告,所以把你的智能手机放在你的设备附近,找到RSSI最高的设备。确保找到你想要设计的设备。
单击“Connect”按钮连接到蓝牙设备。
5、打开右上角 “OTA Firmware”。
选择“partial”、“Reliablity”。
选择BG22SEOTA-signed.gbl
单击Upload。
上传完成后设备会自动重启,您应该会看到新的蓝牙广播名称:SEOTA Example
您可以重复步骤5,选择“BG22empty-signed.gbl”固件,升级完成后会看到蓝牙广播名称为:Empty Example
选择非签名固件BG22empty.gbl进行OTA升级。会出现如下错误提示,升级终止。
- |
- +1 赞 0
- 收藏
- 评论 0
本文由John提供,版权归世强硬创平台所有,非经授权,任何媒体、网站或个人不得转载,授权转载时须注明“来源:世强硬创平台”。
相关推荐
【经验】芯科科技EFR32BG22系列蓝牙SOC修改自定义广播包的思路与具体实例
在蓝牙的实际应用中,往往需要自定义的蓝牙广播包来适应不同的应用环境,本文主要介绍基于SILICON LABS的EFR32BG22蓝牙SOC实现自定义广播数据包的方法。
设计经验 发布时间 : 2023-03-16
【经验】STUDIO V5中蓝牙SoC EFR32BG22添加串口LOG打印的方法
在调试Silicon Labs蓝牙SoC EFR32BG22时,一般需要添加LOG打印信息,通过串口的方式来判断代码运行是否正常。由于使用RTT功能在打印信息时无法再次在线调试和代码下载,所以直接采用串口的方式更加便捷。
设计经验 发布时间 : 2021-06-30
【经验】Silicon Labs的蓝牙SoC EFR32BG22如何进行在线的OTA升级?
Silicon Labs的蓝牙SOC EFR32BG目前已经能够支持到蓝牙5.2,工艺升级后的EFR32BG22的功耗能够达到接收4.1mA,0dbm发射功耗3.6mA,休眠功耗低至1.4uA,如此低的功耗,能够大幅延长蓝牙设备的电池续航时间。本文介绍蓝牙SoC EFR32BG22如何进行在线的OTA升级。
设计经验 发布时间 : 2020-06-07
芯科科技EFR32BG27蓝牙SoC助力持续性血糖监测CGM设备长达21天续航时间
在当今医疗领域,持续性血糖监测(CGM)成为人们关注的焦点,特别是对于糖尿病患者而言,实时了解血糖水平变化对于治疗和生活质量的提升具有举足轻重的意义。Silicon Labs提供的极小型、超低功耗EFR32BG27(BG27)蓝牙SoC在CGM中的应用显得尤为突出。本文将详细介绍BG27蓝牙SoC在CGM中的应用及其突出特点。
应用方案 发布时间 : 2024-07-12
【经验】Silicon Labs蓝牙Soc芯片EFR32BG22的蓝牙广播功率设置及注意事项
用户在使用Silicon Labs的蓝牙Soc芯片EFR32BG22实现蓝牙广播功能时,在不同的应用场景中要设置广播的发射功率,有的是为了降低产品的功耗,有的是为了增加或缩短通信的距离。那要如何设置广播时的功耗以及在设置时有哪些需要注意的事项?
设计经验 发布时间 : 2021-12-24
BG24蓝牙SoC具备低功耗、小型化等特性,为CoreHW提供蓝牙RTLS的先进解决方案
Silicon Labs(亦称“芯科科技”)的BG24蓝牙SoC具备低功耗、小型化等特性,并支持蓝牙定位技术包括蓝牙到达角(AoA)和蓝牙信道探测(Channel Sounding),为CoreHW公司提供了最先进的实时定位服务(RTLS) 解决方案,以开发出创新的CoreTag和CoreLocator定位应用产品。
应用方案 发布时间 : 2024-06-21
芯科科技提供多款无线连接和控制芯片产品及解决方案,BG2x系列蓝牙SoC成就多样医疗物联网用例,
Silicon Labs(亦称“芯科科技”)的无线SoC和MCU助力全球客户的医疗物联网应用创新,持续打造更智能、高效、安全和便捷的健康监测设备。智能和网联技术近年来一直是医疗和健康保障领域内的热门技术,许多厂商都在利用医疗物联网(IoMT)技术开发更加智能和互联的健康监测设备,以利用物联网、云计算、人工智能和可穿戴等新一代信息通信技术,来帮助用户时刻监控自己的健康状况、降低医疗费用和就医麻烦。
原厂动态 发布时间 : 2023-06-29
【经验】EFR32BG22系列蓝牙SOC电池电压与VDD供电电压检测ADC的方法
EFR32BG22作为低功耗蓝牙SOC方案,经常应用于电池供电的方案中,一般采用内部的ADC作为采集通道,内部的输入源作为输入接口,来测试VDD供电电压。本文将讲解电池电压与VDD供电电压检测ADC的方法。
设计经验 发布时间 : 2020-11-28
BG2x系列蓝牙SoC包罗性能、安全、功耗和成本优势,助力移远通信于嵌入式展发表新蓝牙模组
芯科科技一直致力于为物联网设备制造商提供小型、专为应用而优化的BG2x系列蓝牙SoC解决方案。我们的SoC产品不仅能以小体积提供超低功耗且高性能的低功耗蓝牙连接,还具有医疗等级的安全性;同时还领先行业集成了人工智能和机器学习(AI/ML)硬件加速器、模拟、DC-DC转换器、RF认证天线以及许多其他功能。
原厂动态 发布时间 : 2024-04-20
【经验】EFR32BG系列蓝牙SoC之低功耗测试操作指导
很多的蓝牙设备都是电池供电的,因此对蓝牙SoC功耗水平测试与评估就非常有必要。Silicon Labs公司提供的蓝牙评估板底板,都带有电流功耗测试功能,搭配Simplicity studio v4开发平台的energy profile功耗测试上位机,非常容易测试出EFR32BG系列蓝牙SoC的功耗水平。我们详细介绍功耗测试需要的软件和硬件以及测试操作。本文就将具体进行说明。
设计经验 发布时间 : 2020-02-20
洞悉标准化蓝牙ESL应用潜力,芯科科技全系列低功耗、高性能蓝牙SoC和模块现已支持最新蓝牙5.4版本
随着蓝牙标准的推陈出新,Silicon Labs(亦称“芯科科技”)也持续升级蓝牙解决方案,全系列低功耗、高性能蓝牙SoC和模块现已支持最新蓝牙5.4版本,以满足开发人员的需求。
原厂动态 发布时间 : 2023-08-10
EFR32BG2x系列蓝牙SoC如何配置外接FEM引脚,驱动FEM?
Silicon Labs公司的EFR32BG21或者EFR32BG2x系列的蓝牙SoC最大可以支持20dBm的发射功率,以及非常优秀的接收灵敏度。本文以BG21评估板SLWRB4181A,基于GSDK 4.4.1,介绍如何快速配置BG21实现FEM适配。
设计经验 发布时间 : 2024-02-28
【经验】芯科科技EFR32BG22系列蓝牙SOC低功耗优化的相关配置
本文主要介绍Silicon Labs(芯科科技)EFR32BG22系列蓝牙SOC目前所有的低功耗优化的相关配置,实现目标: VDD=3V,VSCALE0=0.9V,温度25℃,EM2模式下深度休眠为1.4μA。
设计经验 发布时间 : 2021-09-27
【经验】蓝牙SoC EFR32BG22增加Button功能并发送Notify数据包的方法
本文以Silicon Labs蓝牙SoC EFR32BG22的Thunderboard模块为例,介绍如何使用Simplicity Studio v5软件在蓝牙soc_empty工程中添加Button功能,并向手机发送Notify数据包的方法。
设计经验 发布时间 : 2021-03-14
【经验】Silicon Labs蓝牙SoC在开启了串口后,如何降低功耗?
在调试Silicon Labs的蓝牙SoC时,我们需要打开串口日志输出以方便调试,但是在添加了Log和IO Stream:USART组件后,可以看到日志可以输出了,但是随之EM2休眠功耗却降不下去了,这是由于添加了串口后,默认串口在EM2下是开启的,导致EM2下功耗会比较高,本文将以EFR32BG27为例,指导如何在添加了串口后降低串口功耗。
设计经验 发布时间 : 2023-09-05
电子商城
品牌:SILICON LABS
品类:Wireless Gecko SoC
价格:¥8.1764
现货: 104,128
现货市场
品牌:SILICON LABS
品类:Switch Hall Effect Magnetic Position Sensor
价格:¥2.2924
现货:126,000
服务
根据用户的蓝牙模块,使用Bluetooth 蓝牙测试装置MT8852B,测试蓝牙1.0至5.1,包括传输速率、功率、频率、调制和接收机灵敏度,生成测试报告。支持到场/视频直播测试,资深专家全程指导。
实验室地址: 深圳 提交需求>
提供语音芯片、MP3芯片、录音芯片、音频蓝牙芯片等IC定制,语音时长:40秒~3小时(外挂flash),可以外挂TF卡或U盘扩容。
最小起订量: 1pcs 提交需求>
登录 | 立即注册
提交评论