杰理的蓝牙芯片的key是什么?以及该如何添加key?杰理key文件原理

news2025/7/18 8:19:52

目录

一、简介

关于杰理芯片的key文件,实际上 杰理芯片特有的一种机制,而这种机制就是存在于杰理芯片特有的架构,也是杰理公司延续将近10年的特点,估计以后也会是这种机制。具体为什么,请听我娓娓道来,这里是我个人的理解和总结,不代表杰理的观点

2.1 什么是key文件?

2.2 key文件是如何产生的?谁来分配?

2.3 为什么需要key文件?

2.4 如何在程序中添加key文件

2.5 实际开发中关于key文件报错的处理

三、总结


一、简介

很多的工程师,在开发杰理蓝牙芯片的第一步就会有一个很深的疑惑,关于key的

  1. 什么是key文件?
  2. Key文件是如何产生的?
  3. 为什么需要他key文件?
  4. 如何添加key文件?
  5. 以及实际开发中的一些报错该如何处理?

关于杰理芯片的key文件,实际上 杰理芯片特有的一种机制,而这种机制就是存在于杰理芯片特有的架构,也是杰理公司延续将近10年的特点,估计以后也会是这种机制。具体为什么,请听我娓娓道来,这里是我个人的理解和总结,不代表杰理的观点

2.1 什么是key文件?

简单理解,key文件就是密码文件,用来加密芯片的。仅此而已,无其他作用

2.2 key文件是如何产生的?谁来分配?

首先,key文件是杰理公司给每家代理商分配的,只有杰理才有权限分配key,一旦分配之后就是固定存在的,不可修改 。

其次key文件一旦烧录到芯片里面之后,就不可修改,不可删除

最后,key文件要写入到芯片里面去,只有两个途径

  1. 批量生产用的一拖二烧写器
  2. 批量生产用的一拖八烧写器

2.3 为什么需要key文件?

要明白key的作用,就要先从杰理芯片的整体架构讲起:

  1. 杰理的芯片架构是SOC 。他是由控制器+存储器的合封产物,也就是你看到的是一颗芯片,但是内部其实是2颗,甚至可能是三颗【比如早期的WIFI芯片】

==》其中“控制器”这个是杰理公司所设计,大概是才有OTP的机制,就是控制器生产出来就会烧录固定的代码,引导芯片直接去读取外挂的spiflash的内容到ram去执行

==》其中“存储器”是外购的,用来存放用户的程序

  1. 理解这个之后,我们再来探讨,杰理为什么要这么去做?

==》其实答案,呼之欲出,就是为了降成本

==》因为要在单颗芯片上面实现大容量的rom程序空间,成本是比较高昂的

==》但是如果选择把这些存储空间外扩,用成熟的工艺、低廉的价格的spiflash去代理,这样就是完美的解决了这个问题

==》这里还要引入一个技术,就是虚拟存储映射。早期杰理芯片开发的时候,会有一个切换bank的概念,就是程序执行到一个新的地方,就load对应位置的flash代码到ram里面运行,此时全局变量的定义就要特殊的处理 。但是目前杰理的芯片有了虚拟存储映射之后,就没有切换bank概念了

总结:

正因为这种特殊的机制,就需要密码了,也称之为key文件,其实就是密码。先来说说,不加key有什么隐患

==》假如别人要破解你的程序,只需要拿到你的芯片,开盖,然后把里面的spiflash的bin文件全部读出来,再进行简单的分析,就可以直接破解了 。因为你所有的程序都是在内置的spiflash里面放着的

==》引入key之后的好处:

  1. 、通过批量烧写器写入“key”到芯片内部的控制器里面 。再将经过key加密的bin文件烧入到内置的spiflash里面 。那么请问这种情况你该如何破解呢
  2. 、这个加密bin文件的操作,是杰理开发环境最终生成程序的时候,产生的
  3. 、因为你读出来flash的bin文件是经过加密的,没有用
  4. 、假如你知道了key文件,也就是密码,你也没法复制。因为你获取的bin文件没办法反推出来实际的bin文件

所以,整个的机制这里就讲明白了,key存在的必要性

2.4 如何在程序中添加key文件

这里拿AC695N系列的芯片举例说明

至于key文件获取,需要联系您的供应商直接获取即可

2.5 实际开发中关于key文件报错的处理

 

错误:KEY不匹配!!

芯片没有被烧写过KEY,请删除“-key<keyfile>参数”

ERROR: Failed to parse device info, error info:ERR KEY

已复制 个文件。

错误:fw文件中已经存在要添加的文件。

1个文件。

错误:fw文件中已经存在要添加的文件。

==》这个问题,log信息写的很详细了,就是目标芯片没有烧录key 。而你的程序里面加入了key文件,导致不能下载,仅此而已,详见2.4章节,删除加key这个操作即可解决

三、总结

很多工程师质疑key存在的意义,觉得很麻烦。有这个疑惑只是自己没有深入去理解而已

所以通过这篇文章详细的讲解他的来历,以及存在的必要性,希望能帮助到大家

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/8162.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

测试大咖漫谈如何搞定软件质量?

关于质量保障&#xff0c;好像已经说过太多&#xff0c;但这里还是抽象的唠叨几句。 多年的软件测试和质量保障工作让我越来越清晰的认识到&#xff1a;质量绝对不是一个环节&#xff0c;一个工种可以搞定的。比如&#xff1a; 从对语言的误用&#xff0c;到对第三方组件的误用…

第4关: 网页排序——PageRank算法

要求&#xff1a;编写实现网页数据集PageRank算法的程序&#xff0c;对网页数据集进行处理得到网页权重排序。 ####相关知识 ######PageRank算法原理 1.基本思想&#xff1a; 如果网页T存在一个指向网页A的连接&#xff0c;则表明T的所有者认为A比较重要&#xff0c;从而把T的一…

【Shell】入门Shell(基本变量、环境变量、特殊变量)

Shell脚本一、Shell脚本的执行方式1.脚本格式要求2. 编写第一个Shell脚本3.Shell脚本的常用执行方式二、Shell的变量1.Shell变量介绍2. Shell变量的定义a. 基本语法b. 快速入门(三案例)2. Shell变量的定义a. 定义变量的规则b. 将命令的返回值赋给变量三、Shell多行注释1. 用 :&…

成本优化之使用P2P的方案的需要了解的本地SDK的背后的原理

文章目录一. P2P的SDK到底做了什么二. P2P原理1. 同流分享思路2. 目前方案三. 使用P2P后产生的问题1. 有概率出现loading转菊花2. 首次打开速度明显慢于正常的通道1-2秒参考文章一. P2P的SDK到底做了什么 P2P的SDK在我们App启动后其实是开启了一个服务&#xff0c;固定端口去监…

刷题日记【第十一篇】-笔试必刷题【小易的升级之路+找出字符串中第一个只出现一次的字符+微信红包+计算字符串的编辑距离】

1.计算字符串的编辑距离【动态规划编程题】 import java.util.Scanner; import java.io.*;// 注意类名必须为 Main, 不要有任何 package xxx 信息 public class Main {public static void main(String args[]) throws Exception{BufferedReader reader new BufferedReader(n…

【RuoYi-Vue-Plus】扩展笔记 07 - CentOS 7 集成 Prometheus + Grafana 监控初体验

文章目录前言参考目录官方文档博客参考相关书目操作步骤1、Prometheus1.1、安装 Prometheus1.2、配置 Prometheus1.3、访问控制台2、Grafana2.1、安装 Grafana2.2、访问控制台3、Grafana 大屏配置3.1、添加 Prometheus 数据源3.2、导入 dashboards 仪表板3.3、配置 node_export…

你安全吗?丨沉默的“复仇”到底是什么东西?

作者&#xff1a;黑蛋 在电视剧《你安全吗&#xff1f;》第七集中&#xff0c;因为周游的死缠烂打&#xff0c;秦淮第一次提起了他和陈默以前的事情&#xff0c;也给出了之前虎迫公司开除陈默的原因&#xff1a;陈默妈妈被诈骗团伙骗掉所有积蓄&#xff0c;又因为此事走神出了…

【附源码】计算机毕业设计JAVA计算机专业在线学习评估软件-演示录像-

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat8.5 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; Springboot mybatis Maven Vue 等等组成&#xff0c;B/…

Java抽象类

什么是抽象类&#xff1f; 如果一个类不能够表示一个准确的对象&#xff0c;则使用abstract修饰&#xff0c;表示为抽象类&#xff0c;抽象类就是为了被继承。抽象类使用abstract修饰 abstract class Animal {abstract public void eat(); }抽象类不能被实例化 public static …

第四节.常用Linux命令—文件内容查询

第四节.常用Linux命令—文件内容查询 1.查看目录内容&#xff1a;cat,more,grep 序号命令作用01cat 文件名查看文件内容&#xff0c;more创建文件&#xff0c;合并文件&#xff0c;追加文件内容等02more 文件名分屏显示文本内容03grep 搜索文本文件名搜索文本文件内容(模式查找…

快速入门Servlet

前导 1、web概述 1.1、Web与JavaWeb的概念 Web&#xff1a;全球广域网 &#xff0c;也称为万维网(www)&#xff0c;能够通过浏览器访问的网站 JavaWeb&#xff1a;是用Java技术来解决相关web互联网领域的技术栈 1.2、JavaWeb技术栈 了解JavaWeb技术栈之前&#xf…

面试官:说说React-SSR的原理

前言 所谓同构&#xff0c;简而言之就是&#xff0c;第一次访问后台服务时&#xff0c;后台直接把前端要显示的界面全部返回&#xff0c;而不是像 SPA 项目只渲染一个 <div id"root"></div> 剩下的都是靠 JavaScript 脚本去加载。这样一来可以大大减少首…

SpringMVC之通过最简单的方法实现多文件上传(提供一种模板,可以在这种方法的基础上进行各种的改良)

上一篇博客主要介绍的SpringMVC中单文件进行上传的两种方法单文件上传的两种方法 单文件上传的方法我们解决了&#xff0c;那如何如何实现多文件进行上传输出呢&#xff1f; 这篇文章主要实现的方法就是通过数组的方法来实现多文件的上传 注意本篇文章的大部分内容与上一篇文章…

2022年11月华南师范大学计算机信息管理-专科-计算机信息管理课程实验(一)

《 计算机信息管理课程实验&#xff08;一&#xff09; 》课程试卷 试卷提交说明&#xff1a; 提交对应于三个题目的三个文档&#xff0c;请把三个文档放到一个文件夹&#xff0c;文档命名规则为题目号&#xff0c;文件夹命名为&#xff1a;“序号姓名课程名”。 此试卷总分…

Ubuntu18.04使用turblebot3

一、安装和测试 1、下载资源包 mkdir -p ~/turtlebot3_ws/src/ cd ~/turtlebot3_ws/src/ git clone https://github.com/ROBOTIS-GIT/turtlebot3_simulations.git git clone https://github.com/ROBOTIS-GIT/turtlebot3_msgs.git git clone https://github.com/ROBOTIS-GIT/t…

Mac系统每次更改vscode中的文件都提示权限不足

开发过程中遇到一个问题 当我在vscode修改文件 保存的时候vscode 右下角弹出 Failed to save index.jsx: Insufficient permissions. Select Retry as Sudo to retry as superuser.翻译成中文的意思就是 文件无法保存, 无权限, 请用超级管理员身份进行修改 其实我很纳闷 我已…

怎么查找Linux服务器是否有后门账户

在Linux系统里植入账户后门是一个极其简单高效的管理权限维持办法。hack在获得目标系统权限的情况下&#xff0c;利用建立一个操作系统账户当做持久化的聚集点&#xff0c;如此一来随时都可以利用工具链接到目标操作系统&#xff0c;实现对目标服务器进行长期操控的目的。依据获…

python基于PHP+MySQL的教学资源管理平台

随着时代发的发展,仅仅通过课堂上知识的传授,已经不能够满足当代大学生对知识的需求。现在很多大学都有了配套的在线教学资源和在线教育平台。通过这些平台可以帮助大学生更好的继续学习从而获取更多的知识。 PHP教学资源管理平台发分为前台和后台两部分,前台部分主要是让学生…

linux内核中听过就能记住的概念

前沿 1 内核中的内存都不分页&#xff0c;所以要珍惜每一个字节。同时可以想到&#xff0c;内核的栈是固定大小的。不能动态分配&#xff08;用户进程的栈是可以控制和动态增长的&#xff0c;因为无论如何他都是虚拟内存&#xff09; 2 linux内核必须使用自旋锁或者信号量来保…

【Java编程进阶】运算符与表达式

推荐学习专栏&#xff1a;Java 编程进阶之路【从入门到精通】 文章目录1. Java运算符1.1 算数运算符1.2 关系运算符1.3 位运算符1.4 逻辑运算符1.5 赋值运算符1.6 其他运算符2. 表达式3. Java运算符优先级1. Java运算符 计算机诞生的初衷是为了进行数学的运算&#xff0c;Java …